asdasd
This commit is contained in:
@@ -41,12 +41,20 @@
|
||||
modal.classList.add('is-open');
|
||||
modal.setAttribute('aria-hidden', 'false');
|
||||
loadList();
|
||||
startRefresh();
|
||||
};
|
||||
const close = () => {
|
||||
modal.classList.remove('is-open');
|
||||
modal.setAttribute('aria-hidden', 'true');
|
||||
if (refreshTimer) {
|
||||
clearInterval(refreshTimer);
|
||||
refreshTimer = null;
|
||||
}
|
||||
};
|
||||
|
||||
let activeFile = null;
|
||||
let refreshTimer = null;
|
||||
|
||||
const loadList = async () => {
|
||||
try {
|
||||
const res = await fetch('/debug?list=1', { cache: 'no-store' });
|
||||
@@ -71,13 +79,37 @@
|
||||
};
|
||||
|
||||
const loadFile = async (name) => {
|
||||
activeFile = name;
|
||||
try {
|
||||
const res = await fetch(`/debug?raw=1&file=${encodeURIComponent(name)}`, { cache: 'no-store' });
|
||||
const res = await fetch(`/debug?raw=1&file=${encodeURIComponent(name)}&tail=200`, { cache: 'no-store' });
|
||||
const text = await res.text();
|
||||
contentEl.textContent = text;
|
||||
contentEl.textContent = formatLog(text);
|
||||
} catch (e) {}
|
||||
};
|
||||
|
||||
const formatLog = (text) => {
|
||||
const lines = text.split(/\\r?\\n/).filter(Boolean);
|
||||
const pretty = lines.map((line) => {
|
||||
try {
|
||||
const obj = JSON.parse(line);
|
||||
return JSON.stringify(obj, null, 2);
|
||||
} catch (e) {
|
||||
return line;
|
||||
}
|
||||
});
|
||||
return pretty.join('\\n\\n');
|
||||
};
|
||||
|
||||
const startRefresh = () => {
|
||||
if (refreshTimer) clearInterval(refreshTimer);
|
||||
refreshTimer = setInterval(() => {
|
||||
if (activeFile) loadFile(activeFile);
|
||||
}, 3000);
|
||||
};
|
||||
|
||||
openBtn.addEventListener('click', open);
|
||||
closeEls.forEach((el) => el.addEventListener('click', close));
|
||||
if (modal.classList.contains('is-open')) {
|
||||
startRefresh();
|
||||
}
|
||||
})();
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
<?php
|
||||
require_auth();
|
||||
require_admin();
|
||||
|
||||
if (!defined('APP_DEBUG_TOOL') || !APP_DEBUG_TOOL) {
|
||||
echo '<div class="card">Debug-Tool ist deaktiviert.</div>';
|
||||
@@ -36,6 +36,11 @@ if (isset($_GET['list']) && $_GET['list'] === '1') {
|
||||
|
||||
if (isset($_GET['raw']) && $_GET['raw'] === '1') {
|
||||
header('Content-Type: text/plain; charset=utf-8');
|
||||
$tail = isset($_GET['tail']) ? (int)$_GET['tail'] : 0;
|
||||
if ($tail > 0 && $content !== null) {
|
||||
$lines = preg_split('/\\R/', $content) ?: [];
|
||||
$content = implode(PHP_EOL, array_slice($lines, -$tail));
|
||||
}
|
||||
echo $content ?? '';
|
||||
return;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user