Mehrere Subdomains pro Benutzer + README
- subdomains-Tabelle (n DNS-Namen je Benutzer) inkl. Migration vom alten Einzel-Subdomain-Schema in database.init_db() - Benutzeranlage/Verwaltung: mehrere Subdomains hinzufuegen/entfernen - /nic/update aktualisiert alle Subdomains des Benutzers bzw. die per ?hostname= gewaehlte(n); eine Antwortzeile je Subdomain - Dashboard/Users-Templates auf das neue Modell umgestellt - README.md mit Setup, Plesk-Konfig, Router-Einrichtung und Endpoint-Doku - .gitignore: __pycache__/ und *.pyc Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -10,19 +10,19 @@
|
||||
<div class="row g-3 mb-4">
|
||||
<div class="col-sm-4">
|
||||
<div class="card text-center p-3">
|
||||
<div class="fs-2 fw-bold text-primary">{{ users|length }}</div>
|
||||
<div class="fs-2 fw-bold text-primary">{{ user_count }}</div>
|
||||
<div class="text-muted small">Benutzer gesamt</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-sm-4">
|
||||
<div class="card text-center p-3">
|
||||
<div class="fs-2 fw-bold text-success">{{ users|selectattr('active', 'equalto', 1)|list|length }}</div>
|
||||
<div class="text-muted small">Aktiv</div>
|
||||
<div class="fs-2 fw-bold text-success">{{ subdomains|length }}</div>
|
||||
<div class="text-muted small">Subdomains</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-sm-4">
|
||||
<div class="card text-center p-3">
|
||||
<div class="fs-2 fw-bold text-info">{{ users|sum(attribute='update_count') }}</div>
|
||||
<div class="fs-2 fw-bold text-info">{{ subdomains|sum(attribute='update_count') }}</div>
|
||||
<div class="text-muted small">Updates gesamt</div>
|
||||
</div>
|
||||
</div>
|
||||
@@ -31,15 +31,15 @@
|
||||
<!-- User table -->
|
||||
<div class="card mb-4">
|
||||
<div class="card-header d-flex justify-content-between align-items-center">
|
||||
<span class="fw-semibold">Benutzer & aktuelle IPs</span>
|
||||
<span class="fw-semibold">Subdomains & aktuelle IPs</span>
|
||||
<a href="{{ url_for('users') }}" class="btn btn-sm btn-outline-primary">Verwalten</a>
|
||||
</div>
|
||||
<div class="card-body p-0">
|
||||
<table class="table table-hover mb-0">
|
||||
<thead class="table-light">
|
||||
<tr>
|
||||
<th>Subdomain</th>
|
||||
<th>Hostname</th>
|
||||
<th>DynDNS-User</th>
|
||||
<th>Aktuelle IP</th>
|
||||
<th>Letztes Update</th>
|
||||
<th>Updates</th>
|
||||
@@ -47,23 +47,23 @@
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
{% for u in users %}
|
||||
{% for s in subdomains %}
|
||||
<tr>
|
||||
<td class="fw-semibold">{{ u.subdomain }}</td>
|
||||
<td class="text-muted small">
|
||||
{% if base_domain %}{{ u.subdomain }}.{{ base_domain }}{% else %}—{% endif %}
|
||||
<td class="fw-semibold font-monospace small">
|
||||
{% if base_domain %}{{ s.subdomain }}.{{ base_domain }}{% else %}{{ s.subdomain }}{% endif %}
|
||||
</td>
|
||||
<td>{{ s.username }}</td>
|
||||
<td>
|
||||
{% if u.current_ip %}
|
||||
<span class="badge bg-secondary badge-ip">{{ u.current_ip }}</span>
|
||||
{% if s.current_ip %}
|
||||
<span class="badge bg-secondary badge-ip">{{ s.current_ip }}</span>
|
||||
{% else %}
|
||||
<span class="text-muted">noch kein Update</span>
|
||||
{% endif %}
|
||||
</td>
|
||||
<td class="text-muted small">{{ u.last_updated or '—' }}</td>
|
||||
<td>{{ u.update_count }}</td>
|
||||
<td class="text-muted small">{{ s.last_updated or '—' }}</td>
|
||||
<td>{{ s.update_count }}</td>
|
||||
<td>
|
||||
{% if u.active %}
|
||||
{% if s.active %}
|
||||
<span class="badge bg-success">Aktiv</span>
|
||||
{% else %}
|
||||
<span class="badge bg-secondary">Inaktiv</span>
|
||||
@@ -71,7 +71,7 @@
|
||||
</td>
|
||||
</tr>
|
||||
{% else %}
|
||||
<tr><td colspan="6" class="text-center text-muted py-4">Noch keine Benutzer angelegt.</td></tr>
|
||||
<tr><td colspan="6" class="text-center text-muted py-4">Noch keine Subdomains angelegt.</td></tr>
|
||||
{% endfor %}
|
||||
</tbody>
|
||||
</table>
|
||||
@@ -96,7 +96,7 @@
|
||||
{% for l in logs %}
|
||||
<tr>
|
||||
<td class="text-muted small">{{ l.timestamp }}</td>
|
||||
<td>{{ l.subdomain }} <span class="text-muted small">({{ l.dyndns_username }})</span></td>
|
||||
<td>{{ l.subdomain or '—' }} <span class="text-muted small">({{ l.dyndns_username }})</span></td>
|
||||
<td class="badge-ip text-muted small">{{ l.old_ip or '—' }}</td>
|
||||
<td><span class="badge bg-secondary badge-ip">{{ l.new_ip }}</span></td>
|
||||
<td>
|
||||
|
||||
Reference in New Issue
Block a user