mirror of
https://github.com/eduardogsilva/wireguard_webadmin.git
synced 2026-01-01 06:16:16 +00:00
add dns_version tracking to cluster settings and worker status
This commit is contained in:
@@ -17,6 +17,6 @@ class WorkerAdmin(admin.ModelAdmin):
|
|||||||
|
|
||||||
@admin.register(WorkerStatus)
|
@admin.register(WorkerStatus)
|
||||||
class WorkerStatusAdmin(admin.ModelAdmin):
|
class WorkerStatusAdmin(admin.ModelAdmin):
|
||||||
list_display = ('worker', 'last_seen', 'config_version', 'config_pending', 'last_reload', 'last_restart')
|
list_display = ('worker', 'last_seen', 'config_version', 'last_reload', 'last_restart')
|
||||||
list_filter = ('config_pending', 'last_seen', 'last_reload', 'last_restart')
|
list_filter = ('last_seen', 'last_reload', 'last_restart')
|
||||||
|
|
||||||
|
|||||||
@@ -30,6 +30,7 @@ def get_worker(request):
|
|||||||
try:
|
try:
|
||||||
worker_config_version = int(request.GET.get('worker_config_version'))
|
worker_config_version = int(request.GET.get('worker_config_version'))
|
||||||
worker_version = int(request.GET.get('worker_version'))
|
worker_version = int(request.GET.get('worker_version'))
|
||||||
|
worker_dns_version = int(request.GET.get('dns_version'))
|
||||||
except:
|
except:
|
||||||
worker.error_status = 'missing_version'
|
worker.error_status = 'missing_version'
|
||||||
worker.save()
|
worker.save()
|
||||||
@@ -51,6 +52,8 @@ def get_worker(request):
|
|||||||
worker_status.config_version = worker_config_version
|
worker_status.config_version = worker_config_version
|
||||||
if worker_status.worker_version != worker_version:
|
if worker_status.worker_version != worker_version:
|
||||||
worker_status.worker_version = worker_version
|
worker_status.worker_version = worker_version
|
||||||
|
if worker_status.dns_version != worker_dns_version:
|
||||||
|
worker_status.dns_version = worker_dns_version
|
||||||
worker_status.last_seen = timezone.now()
|
worker_status.last_seen = timezone.now()
|
||||||
worker_status.save()
|
worker_status.save()
|
||||||
|
|
||||||
@@ -128,6 +131,7 @@ def api_get_worker_config_files(request):
|
|||||||
'cluster_mode': cluster_settings.cluster_mode,
|
'cluster_mode': cluster_settings.cluster_mode,
|
||||||
'restart_mode': cluster_settings.restart_mode,
|
'restart_mode': cluster_settings.restart_mode,
|
||||||
'config_version': cluster_settings.config_version,
|
'config_version': cluster_settings.config_version,
|
||||||
|
'dns_version': cluster_settings.dns_version,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
status=200
|
status=200
|
||||||
@@ -155,6 +159,7 @@ def api_cluster_status(request):
|
|||||||
'cluster_mode': cluster_settings.cluster_mode,
|
'cluster_mode': cluster_settings.cluster_mode,
|
||||||
'restart_mode': cluster_settings.restart_mode,
|
'restart_mode': cluster_settings.restart_mode,
|
||||||
'config_version': cluster_settings.config_version,
|
'config_version': cluster_settings.config_version,
|
||||||
|
'dns_version': cluster_settings.dns_version,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,23 @@
|
|||||||
|
# Generated by Django 5.2.9 on 2025-12-31 21:15
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('cluster', '0010_alter_worker_error_status_and_more'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='clustersettings',
|
||||||
|
name='dns_version',
|
||||||
|
field=models.PositiveIntegerField(default=0),
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='workerstatus',
|
||||||
|
name='dns_version',
|
||||||
|
field=models.PositiveIntegerField(default=0),
|
||||||
|
),
|
||||||
|
]
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
# Generated by Django 5.2.9 on 2025-12-31 21:27
|
||||||
|
|
||||||
|
from django.db import migrations
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('cluster', '0011_clustersettings_dns_version_workerstatus_dns_version'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='workerstatus',
|
||||||
|
name='config_pending',
|
||||||
|
),
|
||||||
|
]
|
||||||
@@ -19,6 +19,7 @@ class ClusterSettings(models.Model):
|
|||||||
)
|
)
|
||||||
)
|
)
|
||||||
config_version = models.PositiveIntegerField(default=0)
|
config_version = models.PositiveIntegerField(default=0)
|
||||||
|
dns_version = models.PositiveIntegerField(default=0)
|
||||||
|
|
||||||
updated = models.DateTimeField(auto_now=True)
|
updated = models.DateTimeField(auto_now=True)
|
||||||
created = models.DateTimeField(auto_now_add=True)
|
created = models.DateTimeField(auto_now_add=True)
|
||||||
@@ -47,7 +48,7 @@ class Worker(models.Model):
|
|||||||
('ip_lock', _('IP lock is enabled, but the worker is attempting to access from a different IP address.')),
|
('ip_lock', _('IP lock is enabled, but the worker is attempting to access from a different IP address.')),
|
||||||
('worker_disabled', _('Worker is not enabled')),
|
('worker_disabled', _('Worker is not enabled')),
|
||||||
('cluster_disabled', _('Cluster is not enabled')),
|
('cluster_disabled', _('Cluster is not enabled')),
|
||||||
('missing_version', _('Please report worker_config_version and worker_version in the API request.')),
|
('missing_version', _('Please report worker_config_version, worker_dns_version and worker_version in the API request.')),
|
||||||
('update_required', _('Worker update is required.'))
|
('update_required', _('Worker update is required.'))
|
||||||
))
|
))
|
||||||
|
|
||||||
@@ -61,8 +62,8 @@ class WorkerStatus(models.Model):
|
|||||||
last_seen = models.DateTimeField(auto_now=True)
|
last_seen = models.DateTimeField(auto_now=True)
|
||||||
last_reload = models.DateTimeField(blank=True, null=True)
|
last_reload = models.DateTimeField(blank=True, null=True)
|
||||||
last_restart = models.DateTimeField(blank=True, null=True)
|
last_restart = models.DateTimeField(blank=True, null=True)
|
||||||
|
dns_version = models.PositiveIntegerField(default=0)
|
||||||
config_version = models.PositiveIntegerField(default=0)
|
config_version = models.PositiveIntegerField(default=0)
|
||||||
config_pending = models.BooleanField(default=False)
|
|
||||||
worker_version = models.PositiveIntegerField(default=0)
|
worker_version = models.PositiveIntegerField(default=0)
|
||||||
active_peers = models.PositiveIntegerField(default=0)
|
active_peers = models.PositiveIntegerField(default=0)
|
||||||
wireguard_status = models.JSONField(default=dict)
|
wireguard_status = models.JSONField(default=dict)
|
||||||
|
|||||||
@@ -8,8 +8,11 @@ from .models import DNSSettings, StaticHost, DNSFilterList
|
|||||||
def compress_dnsmasq_config():
|
def compress_dnsmasq_config():
|
||||||
output_file = "/etc/dnsmasq/dnsmasq_config.tar.gz"
|
output_file = "/etc/dnsmasq/dnsmasq_config.tar.gz"
|
||||||
base_dir = "/etc/dnsmasq"
|
base_dir = "/etc/dnsmasq"
|
||||||
|
cluster_settings = ClusterSettings.objects.filter(enabled=True, name='cluster_settings').first()
|
||||||
if not ClusterSettings.objects.filter(enabled=True, name='cluster_settings').exists():
|
if cluster_settings:
|
||||||
|
cluster_settings.dns_version += 1
|
||||||
|
cluster_settings.save()
|
||||||
|
else:
|
||||||
if os.path.exists(output_file):
|
if os.path.exists(output_file):
|
||||||
os.remove(output_file)
|
os.remove(output_file)
|
||||||
return None
|
return None
|
||||||
|
|||||||
@@ -24,7 +24,7 @@
|
|||||||
<i class="fas fa-exclamation-triangle text-danger blink" title="{{ worker.get_error_status_display }}"></i>
|
<i class="fas fa-exclamation-triangle text-danger blink" title="{{ worker.get_error_status_display }}"></i>
|
||||||
{% else %}
|
{% else %}
|
||||||
{% if worker.enabled %}
|
{% if worker.enabled %}
|
||||||
{% if cluster_settings.config_version != worker.workerstatus.config_version %}
|
{% if cluster_settings.config_version != worker.workerstatus.config_version or cluster_settings.dns_version != worker.workerstatus.dns_version %}
|
||||||
<i class="fas fa-sync text-primary blink" {% trans 'Configuration sync in progress' %}></i>
|
<i class="fas fa-sync text-primary blink" {% trans 'Configuration sync in progress' %}></i>
|
||||||
{% else %}
|
{% else %}
|
||||||
<i class="fas fa-check text-green"></i>
|
<i class="fas fa-check text-green"></i>
|
||||||
@@ -63,10 +63,7 @@
|
|||||||
</td>
|
</td>
|
||||||
<td style="width: 1%; white-space: nowrap;">
|
<td style="width: 1%; white-space: nowrap;">
|
||||||
{% if worker.workerstatus %}
|
{% if worker.workerstatus %}
|
||||||
{{ worker.workerstatus.config_version }}
|
{{ worker.workerstatus.config_version }}/{{ worker.workerstatus.dns_version }}
|
||||||
{% if worker.workerstatus.config_pending %}
|
|
||||||
<i class="fas fa-clock text-warning" title="{% trans 'Config Pending' %}"></i>
|
|
||||||
{% endif %}
|
|
||||||
{% else %}
|
{% else %}
|
||||||
|
|
||||||
{% endif %}
|
{% endif %}
|
||||||
@@ -110,6 +107,11 @@
|
|||||||
<th>{% trans 'Config Version' %}</th>
|
<th>{% trans 'Config Version' %}</th>
|
||||||
<td>{{ cluster_settings.config_version }}</td>
|
<td>{{ cluster_settings.config_version }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>{% trans 'DNS Version' %}</th>
|
||||||
|
<td>{{ cluster_settings.dns_version }}</td>
|
||||||
|
</tr>
|
||||||
|
|
||||||
<tr>
|
<tr>
|
||||||
<th>{% trans 'Stats Sync Interval' %}</th>
|
<th>{% trans 'Stats Sync Interval' %}</th>
|
||||||
<td>{{ cluster_settings.stats_sync_interval }}s</td>
|
<td>{{ cluster_settings.stats_sync_interval }}s</td>
|
||||||
|
|||||||
Reference in New Issue
Block a user