KTVManager_UI/templates/config_dashboard.html

158 lines
6.3 KiB
HTML
Raw Normal View History

2025-07-19 08:56:13 +01:00
{% extends "base.html" %}
{% block title %}Config Dashboard{% endblock %}
{% block content %}
<div class="container">
<h2>Configuration Dashboard</h2>
<p>Welcome to the configuration page.</p>
<button id="send-test-notification-btn" class="btn btn-primary">Send Test Notification</button>
2025-07-19 09:05:28 +01:00
<button id="check-expiring-accounts-btn" class="btn btn-info">Check Expiring Accounts</button>
2025-07-19 09:16:15 +01:00
<div class="card mt-4">
<div class="card-header">
DNS Manager
</div>
<div class="card-body">
2025-07-19 09:32:49 +01:00
<div class="input-group mb-3">
<input type="text" class="form-control" id="dns-entry-input" placeholder="Enter DNS entry">
<div class="input-group-append">
<button class="btn btn-primary" id="add-dns-btn">Add</button>
2025-07-19 09:16:15 +01:00
</div>
2025-07-19 09:32:49 +01:00
</div>
2025-07-19 09:16:15 +01:00
</div>
2025-07-19 10:20:47 +01:00
<table class="table table-striped mt-3">
<thead>
<tr>
<th>DNS Entry</th>
<th style="width: 10%;">Actions</th>
</tr>
</thead>
<tbody id="dns-list-table-body">
<!-- DNS entries will be loaded here -->
</tbody>
</table>
2025-07-19 09:16:15 +01:00
</div>
2025-07-19 08:56:13 +01:00
</div>
{% endblock %}
2025-07-19 09:32:49 +01:00
{% block scripts %}
{{ super() }}
<script>
document.addEventListener('DOMContentLoaded', function() {
2025-07-19 09:44:02 +01:00
// DNS Manager
2025-07-19 10:20:47 +01:00
const dnsListTableBody = document.getElementById('dns-list-table-body');
2025-07-19 09:32:49 +01:00
const addDnsBtn = document.getElementById('add-dns-btn');
const dnsEntryInput = document.getElementById('dns-entry-input');
function fetchDnsList() {
2025-07-19 11:05:09 +01:00
fetch("{{ url_for('proxy_dns') }}")
.then(response => {
if (!response.ok) {
// Log the error response text for debugging
response.text().then(text => console.error('Error response from proxy:', text));
throw new Error(`HTTP error! Status: ${response.status}`);
}
return response.json();
})
2025-07-19 09:32:49 +01:00
.then(data => {
2025-07-19 10:20:47 +01:00
dnsListTableBody.innerHTML = '';
2025-07-19 11:05:09 +01:00
if (!Array.isArray(data)) {
console.error("Received data is not an array:", data);
throw new Error("Invalid data format received from server.");
}
2025-07-19 09:32:49 +01:00
if (data.length === 0) {
2025-07-19 10:20:47 +01:00
const row = dnsListTableBody.insertRow();
const cell = row.insertCell();
cell.colSpan = 2;
cell.textContent = 'No DNS entries found.';
cell.classList.add('text-center');
2025-07-19 09:32:49 +01:00
} else {
data.forEach(entry => {
2025-07-19 10:20:47 +01:00
const row = dnsListTableBody.insertRow();
const entryCell = row.insertCell();
entryCell.textContent = entry;
const actionCell = row.insertCell();
2025-07-19 09:32:49 +01:00
const removeBtn = document.createElement('button');
removeBtn.className = 'btn btn-danger btn-sm';
2025-07-19 10:20:47 +01:00
removeBtn.textContent = 'Delete';
2025-07-19 09:32:49 +01:00
removeBtn.addEventListener('click', () => removeDnsEntry(entry));
2025-07-19 10:20:47 +01:00
actionCell.appendChild(removeBtn);
2025-07-19 09:32:49 +01:00
});
}
2025-07-19 11:05:09 +01:00
})
.catch(e => {
console.error('Error during fetchDnsList:', e);
dnsListTableBody.innerHTML = '';
const row = dnsListTableBody.insertRow();
const cell = row.insertCell();
cell.colSpan = 2;
cell.textContent = 'Error loading DNS entries. See browser console for details.';
cell.classList.add('text-center', 'text-danger');
2025-07-19 09:32:49 +01:00
});
}
function addDnsEntry() {
const dnsEntry = dnsEntryInput.value.trim();
if (dnsEntry) {
2025-07-19 11:05:09 +01:00
fetch("{{ url_for('proxy_dns') }}", {
2025-07-19 09:32:49 +01:00
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify({ dns_entry: dnsEntry })
}).then(() => {
dnsEntryInput.value = '';
fetchDnsList();
});
}
}
function removeDnsEntry(dnsEntry) {
2025-07-19 11:05:09 +01:00
fetch("{{ url_for('proxy_dns') }}", {
2025-07-19 09:32:49 +01:00
method: 'DELETE',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify({ dns_entry: dnsEntry })
}).then(() => {
fetchDnsList();
});
}
addDnsBtn.addEventListener('click', addDnsEntry);
fetchDnsList();
2025-07-19 09:44:02 +01:00
// Other buttons
document.getElementById('send-test-notification-btn').addEventListener('click', function() {
fetch('{{ url_for("send_test_notification") }}', {
method: 'POST'
}).then(response => {
if (response.ok) {
alert('Test notification sent successfully!');
} else {
alert('Failed to send test notification.');
}
}).catch(err => {
console.error('Error sending test notification:', err);
alert('An error occurred while sending the test notification.');
});
});
document.getElementById('check-expiring-accounts-btn').addEventListener('click', function() {
fetch('{{ url_for("check_expiring_accounts") }}', {
method: 'POST'
}).then(response => {
if (response.ok) {
alert('Expiring accounts check triggered successfully!');
} else {
alert('Failed to trigger expiring accounts check.');
}
}).catch(err => {
console.error('Error triggering expiring accounts check:', err);
alert('An error occurred while triggering the expiring accounts check.');
});
});
2025-07-19 09:32:49 +01:00
});
</script>
2025-07-19 08:56:13 +01:00
{% endblock %}