crafty-4/app/frontend/templates/panel/server_logs.html

195 lines
5.7 KiB
HTML
Raw Normal View History

{% extends ../base.html %}
{% block meta %}
{% end %}
{% block title %}Crafty Controller - {{ translate('serverDetails', 'serverDetails', data['lang']) }}{% end %}
{% block content %}
<div class="content-wrapper">
2022-06-21 19:59:34 +00:00
<!-- Page Title Header Starts-->
<div class="row page-title-header">
<div class="col-12">
<div class="page-header">
<h4 class="page-title">
2022-06-21 19:59:34 +00:00
{{ translate('serverDetails', 'serverDetails', data['lang']) }} - {{
data['server_stats']['server_id']['server_name'] }}
<br />
<small>UUID: {{ data['server_stats']['server_id']['server_uuid'] }}</small>
</h4>
</div>
</div>
</div>
<!-- Page Title Header Ends-->
2022-06-21 19:59:34 +00:00
{% include "parts/details_stats.html" %}
<div class="row">
<div class="col-sm-12 grid-margin">
<div class="card">
<div class="card-body pt-0">
2022-06-21 19:59:34 +00:00
<span class="d-none d-sm-block">
{% include "parts/server_controls_list.html %}
</span>
<span class="d-block d-sm-none">
{% include "parts/m_server_controls_list.html %}
</span>
<div class="col-md-12">
<div class="input-group">
<div id="virt_console" class=""
style="width: 100%; font-size: .8em; padding: 5px 10px; border: 1px solid var(--outline); background-color:var(--card-banner-bg);height:500px; overflow: scroll;">
</div>
2022-06-21 19:59:34 +00:00
</div>
<br />
<label for="ignore">{{ translate('serverDetails', 'filter', data['lang']) }}</label>
<input type="text" class="form-control" name="ignore" id="searchbox" value="" required>
<br />
<br />
<h4>{{ translate('serverDetails', 'filterList', data['lang']) }}</h4>
<ul id="ignored-words" style="list-style: None;"></ul>
<br />
2022-06-21 19:59:34 +00:00
</div>
</div>
</div>
</div>
</div>
<span class="is-hidden">secret</span>
</div>
<style>
.is-hidden {
display: none;
position: fixed !important;
}
</style>
<!-- content-wrapper ends -->
{% end %}
{% block js %}
<script>
var lines = [];
2022-10-18 04:22:06 +00:00
var words = [];
if (localStorage.getItem("words")) {
try {
2022-10-18 04:22:06 +00:00
words = JSON.parse(localStorage.getItem("words"));
} catch {
2022-10-18 04:22:06 +00:00
words = [];
}
}
const serverId = new URLSearchParams(document.location.search).get('id')
2022-06-21 19:59:34 +00:00
function get_server_log() {
if (!$("#stop_scroll").is(':checked')) {
$.ajax({
type: 'GET',
url: '/ajax/server_log?id=' + serverId + '&full=1',
dataType: 'text',
success: function (data) {
console.log('Got Log From Server')
$('#virt_console').html(data);
scroll();
lines = document.querySelectorAll('.box');
liveSearch();
},
});
}
}
//used to get cookies from browser - this is part of tornados xsrf protection - it's for extra security
function getCookie(name) {
var r = document.cookie.match("\\b" + name + "=([^;]*)\\b");
return r ? r[1] : undefined;
}
2022-06-21 19:59:34 +00:00
$(document).ready(function () {
console.log("ready!");
get_server_log();
populateWords();
});
2022-06-21 19:59:34 +00:00
function scroll() {
var logview = $('#virt_console');
2022-06-21 19:59:34 +00:00
if (logview.length)
logview.scrollTop(logview[0].scrollHeight - logview.height());
}
function liveSearch() {
for (let i = 0; i < lines.length; i++) {
2022-10-18 04:22:06 +00:00
// Reinitialise line visibility
lines[i].classList.remove("is-hidden");
2022-10-18 04:22:06 +00:00
// If we have no words to filter, continue.
if (!words.length) continue;
// If we find our target word hide the line
if (words.some(ai => lines[i].textContent.toLowerCase().includes(ai))) {
lines[i].classList.add("is-hidden");
}
}
}
//A little delay
let typingTimer;
let typeInterval = 500;
let searchInput = document.getElementById('searchbox');
searchInput.addEventListener('keyup', (e) => {
clearTimeout(typingTimer);
typingTimer = setTimeout(liveSearch, typeInterval);
2022-10-18 04:22:06 +00:00
// On Return/Enter key press
if (e.keyCode === 13) {
let word = document.getElementById("searchbox").value
word = word.toLowerCase();
2022-10-20 17:52:16 +00:00
safe_word = sanitize(word)
if (word === "\\n") {
window.alert("Nice try...");
document.getElementById("searchbox").value = "";
return;
}
2022-10-20 17:52:16 +00:00
if (!safe_word) {
window.alert("Illegal character detected")
return;
}
words.push(word);
$("#ignored-words").append("<li id=" + safe_word.replaceAll(" ", "-") + "><div class='card-header header-sm d-flex justify-content-between align-items-center'>" + word + "&nbsp;<button class='btn btn-danger' onclick='deleteItem(" + '"' + word + '"' + ")' ><i class='fas fa-trash'></i></button></div></li>")
document.getElementById("searchbox").value = "";
localStorage.setItem("words", JSON.stringify(words))
}
});
function sanitize(string) {
2022-10-20 17:52:16 +00:00
return string.replace(/[`~!@#$%^&*()_|+\-=?;:'",.<>\{\}\[\]\\\/]/gi, '');
}
function deleteItem(item) {
2022-10-18 04:22:06 +00:00
let safe_item = sanitize(item);
2022-10-13 04:01:53 +00:00
words.splice(words.indexOf(item), 1);
2022-10-20 17:52:16 +00:00
if (safe_item) {
$("#" + safe_item.replaceAll(" ", "-")).remove();
}
liveSearch();
localStorage.setItem("words", JSON.stringify(words))
}
function populateWords() {
2022-10-18 04:22:06 +00:00
for (let i = 0; i < words.length; i++) {
let safe_word = sanitize(words[i]);
2022-10-20 17:52:16 +00:00
$("#ignored-words").append("<li id=" + safe_word.replaceAll(" ", "-") + "><div class='card-header header-sm d-flex justify-content-between align-items-center'>" + words[i] + "&nbsp;<button class='btn btn-danger' onclick='deleteItem(" + '"' + words[i] + '"' + ")' ><i class='fas fa-trash'></i></button></div></li > ")
}
}
</script>
2022-06-21 19:59:34 +00:00
{% end %}