add wireguard instance public_key

This commit is contained in:
Eduardo Silva
2024-02-15 12:08:46 -03:00
parent f036daf779
commit 19d5e665ec
8 changed files with 43 additions and 11 deletions

View File

@@ -7,18 +7,19 @@ class WireGuardInstanceForm(forms.ModelForm):
name = forms.CharField(label='Display Name', required=False)
instance_id = forms.IntegerField(label='Instance ID')
private_key = forms.CharField(label='Private Key')
public_key = forms.CharField(label='Public Key')
hostname = forms.CharField(label='Public Address')
listen_port = forms.IntegerField(label='Listen Port')
address = forms.GenericIPAddressField(label='VPN IP Address')
netmask = forms.ChoiceField(choices=NETMASK_CHOICES, label='Netmask')
post_up = forms.CharField(label='Post Up', required=False)
post_down = forms.CharField(label='Post Down', required=False)
persistent_keepalive = forms.IntegerField(label='Persistent Keepalive')
persistent_keepalive = forms.IntegerField(label='Keepalive')
class Meta:
model = WireGuardInstance
fields = [
'name', 'instance_id', 'private_key', 'hostname', 'listen_port', 'address', 'netmask', 'post_up', 'post_down', 'persistent_keepalive'
'name', 'instance_id', 'private_key', 'public_key','hostname', 'listen_port', 'address', 'netmask', 'post_up', 'post_down', 'persistent_keepalive'
]
def clean(self):

View File

@@ -0,0 +1,19 @@
# Generated by Django 5.0.1 on 2024-02-15 14:29
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('wireguard', '0003_peerallowedip_missing_from_wireguard'),
]
operations = [
migrations.AddField(
model_name='wireguardinstance',
name='public_key',
field=models.CharField(default=' ', max_length=100),
preserve_default=False,
),
]

View File

@@ -33,6 +33,7 @@ class WireGuardInstance(models.Model):
name = models.CharField(max_length=100, blank=True, null=True)
instance_id = models.PositiveIntegerField(unique=True, default=0)
private_key = models.CharField(max_length=100)
public_key = models.CharField(max_length=100)
hostname = models.CharField(max_length=100)
listen_port = models.IntegerField(default=51820, unique=True)
address = models.GenericIPAddressField(unique=True, protocol='IPv4')

View File

@@ -17,6 +17,7 @@ def generate_instance_defaults():
new_listen_port = (max_listen_port + 1) if max_listen_port is not None else 51820
new_private_key = subprocess.check_output('wg genkey', shell=True).decode('utf-8').strip()
new_public_key = subprocess.check_output(f'echo {new_private_key} | wg pubkey', shell=True).decode('utf-8').strip()
new_address = f'10.188.{new_instance_id}.1'
@@ -52,6 +53,7 @@ def generate_instance_defaults():
'instance_id': new_instance_id,
'listen_port': new_listen_port,
'private_key': new_private_key,
'public_key': new_public_key,
'address': new_address,
'netmask': 24,
'persistent_keepalive': 25,