mirror of
https://github.com/eduardogsilva/wireguard_webadmin.git
synced 2026-01-31 03:26:17 +00:00
Add 'Enforce Route Policy' field to WireGuardInstance model and forms
This commit is contained in:
@@ -1,9 +1,10 @@
|
||||
{% extends 'base.html' %}
|
||||
{% load crispy_forms_tags %}
|
||||
{% load i18n %}
|
||||
|
||||
{% block content %}
|
||||
<div class="row">
|
||||
<div class="{% if form_size %}{{ form_size }}{% else %}col-lg-12{% endif %}">
|
||||
<div class="col-lg-6">
|
||||
<div class="card card-primary card-outline">
|
||||
{% if page_title %}
|
||||
<div class="card-header">
|
||||
@@ -17,6 +18,69 @@
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-lg-6">
|
||||
<div class="card card-primary card-outline">
|
||||
<div class="card-body row">
|
||||
<div class="col-lg-12">
|
||||
<h5>{% trans "Display Name" %}</h5>
|
||||
<p>
|
||||
{% blocktrans %}
|
||||
Optional name used only for display in the web interface.
|
||||
{% endblocktrans %}
|
||||
</p>
|
||||
<h5>{% trans "Web Refresh Interval" %}</h5>
|
||||
<p>
|
||||
{% blocktrans %}
|
||||
Interval used to refresh WireGuard status information in the web UI.
|
||||
{% endblocktrans %}
|
||||
</p>
|
||||
<h5>{% trans "Public Address" %}</h5>
|
||||
<p>
|
||||
{% blocktrans %}
|
||||
Public hostname or IP address and UDP port used by peers to connect.
|
||||
<br>
|
||||
The <b>listen port</b> must be exposed and mapped in your Docker compose (YAML) file.
|
||||
{% endblocktrans %}
|
||||
</p>
|
||||
<h5>{% trans "Interface Keys" %}</h5>
|
||||
<p>
|
||||
{% blocktrans %}
|
||||
WireGuard private and public keys for this interface.
|
||||
<br>
|
||||
The private key must remain secret.
|
||||
Changing it requires updating all peer configurations.
|
||||
{% endblocktrans %}
|
||||
</p>
|
||||
<h5>{% trans "Internal Network" %}</h5>
|
||||
<p>
|
||||
{% blocktrans %}
|
||||
Internal IP address and netmask used by the WireGuard interface.
|
||||
{% endblocktrans %}
|
||||
</p>
|
||||
<h5>{% trans "DNS Configuration" %}</h5>
|
||||
<p>
|
||||
{% blocktrans %}
|
||||
DNS servers pushed to peers.
|
||||
<br>
|
||||
Using the internal IP as primary DNS enables internal name resolution
|
||||
and DNS filtering.
|
||||
{% endblocktrans %}
|
||||
</p>
|
||||
<h5>{% trans "Enforce Route Policy" %}</h5>
|
||||
<p>
|
||||
{% blocktrans %}
|
||||
Enforces routing rules defined by routing templates using firewall rules.
|
||||
<br>
|
||||
Peers with a default route (0.0.0.0/0) are not restricted.
|
||||
<br><br>
|
||||
Note: depending on the number of routes and peers, this option may generate
|
||||
a large number of firewall rules.
|
||||
{% endblocktrans %}
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
{% endblock %}
|
||||
|
||||
|
||||
@@ -23,12 +23,13 @@ class WireGuardInstanceForm(forms.ModelForm):
|
||||
peer_list_refresh_interval = forms.IntegerField(label=_('Web Refresh Interval'), initial=10)
|
||||
dns_primary = forms.GenericIPAddressField(label=_('Primary DNS'), initial='1.1.1.1', required=False)
|
||||
dns_secondary = forms.GenericIPAddressField(label=_('Secondary DNS'), initial='', required=False)
|
||||
enforce_route_policy = forms.BooleanField(label=_('Enforce Route Policy'), required=False)
|
||||
|
||||
class Meta:
|
||||
model = WireGuardInstance
|
||||
fields = [
|
||||
'name', 'instance_id', 'private_key', 'public_key','hostname', 'listen_port', 'address',
|
||||
'netmask', 'peer_list_refresh_interval', 'dns_primary', 'dns_secondary'
|
||||
'netmask', 'peer_list_refresh_interval', 'dns_primary', 'dns_secondary', 'enforce_route_policy'
|
||||
]
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
@@ -86,6 +87,10 @@ class WireGuardInstanceForm(forms.ModelForm):
|
||||
Column('dns_secondary', css_class='form-group col-md-6 mb-0'),
|
||||
css_class='form-row'
|
||||
),
|
||||
Row(
|
||||
Column('enforce_route_policy', css_class='form-group col-md-12 mb-0'),
|
||||
css_class='form-row'
|
||||
),
|
||||
css_class='col-lg-12'
|
||||
),
|
||||
css_class='row'
|
||||
|
||||
@@ -0,0 +1,18 @@
|
||||
# Generated by Django 5.2.9 on 2026-01-27 13:07
|
||||
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('wireguard', '0028_peer_routing_template'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.AddField(
|
||||
model_name='wireguardinstance',
|
||||
name='enforce_route_policy',
|
||||
field=models.BooleanField(default=False),
|
||||
),
|
||||
]
|
||||
@@ -64,6 +64,7 @@ class WireGuardInstance(models.Model):
|
||||
dns_secondary = models.GenericIPAddressField(unique=False, protocol='IPv4', default='1.0.0.1', blank=True, null=True)
|
||||
pending_changes = models.BooleanField(default=True)
|
||||
legacy_firewall = models.BooleanField(default=False)
|
||||
enforce_route_policy = models.BooleanField(default=False)
|
||||
|
||||
created = models.DateTimeField(auto_now_add=True)
|
||||
updated = models.DateTimeField(auto_now=True)
|
||||
|
||||
Reference in New Issue
Block a user