mirror of
https://github.com/eduardogsilva/wireguard_webadmin.git
synced 2026-03-15 13:36:18 +00:00
100 lines
3.7 KiB
Python
100 lines
3.7 KiB
Python
import uuid
|
|
|
|
from django.db import models
|
|
from django.utils.translation import gettext_lazy as _
|
|
|
|
from gatekeeper.models import GatekeeperGroup, AuthMethod
|
|
|
|
|
|
class Application(models.Model):
|
|
name = models.SlugField(max_length=64, unique=True)
|
|
display_name = models.CharField(max_length=128)
|
|
upstream = models.CharField(max_length=255, help_text=_("Upstream address, e.g.: http://10.188.18.27:3000"))
|
|
|
|
created = models.DateTimeField(auto_now_add=True)
|
|
updated = models.DateTimeField(auto_now=True)
|
|
uuid = models.UUIDField(unique=True, default=uuid.uuid4, editable=False)
|
|
|
|
def __str__(self):
|
|
return self.display_name
|
|
|
|
class Meta:
|
|
ordering = ['name']
|
|
|
|
|
|
class ApplicationHost(models.Model):
|
|
application = models.ForeignKey(Application, on_delete=models.CASCADE, related_name='hosts')
|
|
hostname = models.CharField(max_length=255, unique=True)
|
|
|
|
created = models.DateTimeField(auto_now_add=True)
|
|
updated = models.DateTimeField(auto_now=True)
|
|
uuid = models.UUIDField(unique=True, default=uuid.uuid4, editable=False)
|
|
|
|
def __str__(self):
|
|
return self.hostname
|
|
|
|
class Meta:
|
|
ordering = ['hostname']
|
|
|
|
|
|
class AccessPolicy(models.Model):
|
|
POLICY_TYPE_CHOICES = [
|
|
('bypass', _('Bypass (public)')),
|
|
('one_factor', _('One Factor')),
|
|
('two_factor', _('Two Factor')),
|
|
('deny', _('Deny')),
|
|
]
|
|
|
|
name = models.SlugField(max_length=64, unique=True)
|
|
policy_type = models.CharField(max_length=32, choices=POLICY_TYPE_CHOICES)
|
|
groups = models.ManyToManyField(GatekeeperGroup, blank=True, related_name='policies')
|
|
methods = models.ManyToManyField(AuthMethod, blank=True, related_name='policies')
|
|
|
|
created = models.DateTimeField(auto_now_add=True)
|
|
updated = models.DateTimeField(auto_now=True)
|
|
uuid = models.UUIDField(unique=True, default=uuid.uuid4, editable=False)
|
|
|
|
def __str__(self):
|
|
return f"{self.name} ({self.get_policy_type_display()})"
|
|
|
|
class Meta:
|
|
ordering = ['name']
|
|
verbose_name = 'Access Policy'
|
|
verbose_name_plural = 'Access Policies'
|
|
|
|
|
|
class ApplicationPolicy(models.Model):
|
|
application = models.OneToOneField(Application, on_delete=models.CASCADE, related_name='default_policy_config')
|
|
default_policy = models.ForeignKey(AccessPolicy, on_delete=models.PROTECT, related_name='application_defaults')
|
|
|
|
created = models.DateTimeField(auto_now_add=True)
|
|
updated = models.DateTimeField(auto_now=True)
|
|
uuid = models.UUIDField(unique=True, default=uuid.uuid4, editable=False)
|
|
|
|
def __str__(self):
|
|
return f"{self.application} → default: {self.default_policy}"
|
|
|
|
class Meta:
|
|
verbose_name = 'Application Policy'
|
|
verbose_name_plural = 'Application Policies'
|
|
|
|
|
|
class ApplicationRoute(models.Model):
|
|
application = models.ForeignKey(Application, on_delete=models.CASCADE, related_name='routes')
|
|
name = models.SlugField(max_length=64, help_text=_("Route identifier, used in export (e.g.: public_area)"))
|
|
path_prefix = models.CharField(max_length=255)
|
|
policy = models.ForeignKey(AccessPolicy, on_delete=models.PROTECT, related_name='routes')
|
|
order = models.PositiveIntegerField(default=0, help_text=_("Evaluation order — lower value means higher priority"))
|
|
|
|
created = models.DateTimeField(auto_now_add=True)
|
|
updated = models.DateTimeField(auto_now=True)
|
|
uuid = models.UUIDField(unique=True, default=uuid.uuid4, editable=False)
|
|
|
|
def __str__(self):
|
|
return f"{self.application} {self.path_prefix} → {self.policy}"
|
|
|
|
class Meta:
|
|
ordering = ['application', 'order', 'path_prefix']
|
|
unique_together = [('application', 'path_prefix'), ('application', 'name')]
|
|
verbose_name = 'Application Route'
|
|
verbose_name_plural = 'Application Routes' |