create and manage peer groups

This commit is contained in:
Eduardo Silva
2025-01-20 11:41:02 -03:00
parent 797058b29b
commit eefc573c61
9 changed files with 222 additions and 11 deletions

View File

@@ -3,6 +3,7 @@ from django.contrib.auth.forms import UserCreationForm
from django.contrib.auth.models import User
from .models import UserAcl
from django.core.exceptions import ValidationError
from wireguard.models import PeerGroup
class UserAclForm(UserCreationForm):
@@ -44,3 +45,34 @@ class UserAclForm(UserCreationForm):
)
return user
class PeerGroupForm(forms.ModelForm):
class Meta:
model = PeerGroup
fields = ['name', 'peer', 'server_instance']
def __init__(self, *args, **kwargs):
self.user_id = kwargs.pop('user_id', None)
super().__init__(*args, **kwargs)
def clean(self):
cleaned_data = super().clean()
name = cleaned_data.get('name')
peers = cleaned_data.get('peer')
server_instances = cleaned_data.get('server_instance')
if PeerGroup.objects.filter(name=name).exclude(pk=self.instance.pk if self.instance else None).exists():
raise ValidationError("A peer group with that name already exists.")
return cleaned_data
def save(self, commit=True):
peer_group = super().save(commit=False)
if commit:
peer_group.save()
return peer_group

View File

@@ -5,6 +5,54 @@ from .forms import UserAclForm
from django.contrib.auth.models import User
from django.contrib import messages
from django.contrib.sessions.models import Session
from wireguard.models import PeerGroup
from .forms import PeerGroupForm
@login_required
def view_peer_group_list(request):
if not UserAcl.objects.filter(user=request.user).filter(user_level__gte=50).exists():
return render(request, 'access_denied.html', {'page_title': 'Access Denied'})
page_title = 'Peer Group Manager'
peer_group_list = PeerGroup.objects.all().order_by('name')
context = {'page_title': page_title, 'peer_group_list': peer_group_list}
return render(request, 'user_manager/peer_group_list.html', context)
@login_required
def view_peer_group_manage(request):
if not UserAcl.objects.filter(user=request.user).filter(user_level__gte=50).exists():
return render(request, 'access_denied.html', {'page_title': 'Access Denied'})
peer_group = None
if 'uuid' in request.GET:
peer_group = get_object_or_404(PeerGroup, uuid=request.GET['uuid'])
form = PeerGroupForm(instance=peer_group, user_id=request.user.id)
page_title = 'Edit Peer Group ' + peer_group.name
if request.GET.get('action') == 'delete':
group_name = peer_group.name
if request.GET.get('confirmation') == group_name:
peer_group.delete()
messages.success(request, 'Peer Group deleted|The peer group ' + group_name + ' has been deleted.')
return redirect('/user/peer-group/list/')
return redirect('/user/peer-group/list/')
else:
form = PeerGroupForm(user_id=request.user.id)
page_title = 'Add Peer Group'
if request.method == 'POST':
if peer_group:
form = PeerGroupForm(request.POST, instance=peer_group, user_id=request.user.id)
else:
form = PeerGroupForm(request.POST, user_id=request.user.id)
if form.is_valid():
peer_group = form.save()
form.save_m2m()
return redirect('/user/peer-group/list/')
context = {'page_title': page_title, 'form': form, 'peer_group': peer_group}
return render(request, 'user_manager/manage_peer_group.html', context)
@login_required
def view_user_list(request):