Files
OutFleet/vpn/models.py

87 lines
3.5 KiB
Python
Raw Normal View History

2024-10-20 21:57:12 +00:00
import uuid
from django.db import models
from vpn.tasks import sync_user
from django.db.models.signals import post_save, pre_delete
from django.dispatch import receiver
from .server_plugins import Server
import shortuuid
2024-10-27 01:06:37 +00:00
from django.contrib.auth.models import AbstractUser
2024-10-28 17:15:49 +00:00
class AccessLog(models.Model):
user = models.CharField(max_length=256, blank=True, null=True, editable=False)
server = models.CharField(max_length=256, blank=True, null=True, editable=False)
action = models.CharField(max_length=100, editable=False)
data = models.TextField(default="", blank=True, editable=False)
timestamp = models.DateTimeField(auto_now_add=True)
def __str__(self):
return f"{self.action} {self.user} request for {self.server} at {self.timestamp}"
2024-10-27 01:06:37 +00:00
class User(AbstractUser):
2024-10-27 01:18:06 +00:00
#is_active = False
2024-10-28 17:15:49 +00:00
comment = models.TextField(default="", blank=True, help_text="Free form user comment")
registration_date = models.DateTimeField(auto_now_add=True, verbose_name="Created")
servers = models.ManyToManyField('Server', through='ACL', blank=True, help_text="Servers user has access to")
2024-10-20 21:57:12 +00:00
last_access = models.DateTimeField(null=True, blank=True)
2024-10-28 17:15:49 +00:00
hash = models.CharField(max_length=64, unique=True, help_text="Random user hash. It's using for client config generation.")
2024-10-20 21:57:12 +00:00
def get_servers(self):
return Server.objects.filter(acl__user=self)
def save(self, *args, **kwargs):
if not self.hash:
self.hash = shortuuid.ShortUUID().random(length=16)
super().save(*args, **kwargs)
def __str__(self):
2024-10-27 01:06:37 +00:00
return self.username
2024-10-20 21:57:12 +00:00
class ACL(models.Model):
user = models.ForeignKey('User', on_delete=models.CASCADE)
server = models.ForeignKey('Server', on_delete=models.CASCADE)
2024-10-28 17:15:49 +00:00
created_at = models.DateTimeField(auto_now_add=True, verbose_name="Created")
2024-10-20 21:57:12 +00:00
class Meta:
constraints = [
models.UniqueConstraint(fields=['user', 'server'], name='unique_user_server')
]
def __str__(self):
2024-10-27 01:06:37 +00:00
return f"{self.user.username} - {self.server.name}"
2024-10-28 17:32:06 +00:00
def save(self, *args, **kwargs):
2025-06-27 16:02:13 +03:00
# Check if this is a new ACL and if auto_create_link should be enabled
is_new = self.pk is None
auto_create_link = kwargs.pop('auto_create_link', True)
2024-10-28 17:32:06 +00:00
super().save(*args, **kwargs)
2025-06-27 16:02:13 +03:00
# Only create default link for new ACLs when auto_create_link is True
# This happens when ACL is created through admin interface or initial user setup
if is_new and auto_create_link and not self.links.exists():
2024-10-28 17:32:06 +00:00
ACLLink.objects.create(acl=self, link=shortuuid.ShortUUID().random(length=16))
2024-10-20 21:57:12 +00:00
@receiver(post_save, sender=ACL)
def acl_created_or_updated(sender, instance, created, **kwargs):
2024-10-26 12:22:19 +00:00
sync_user.delay_on_commit(instance.user.id, instance.server.id)
2024-10-20 21:57:12 +00:00
@receiver(pre_delete, sender=ACL)
def acl_deleted(sender, instance, **kwargs):
2024-10-28 17:15:49 +00:00
sync_user.delay_on_commit(instance.user.id, instance.server.id)
class ACLLink(models.Model):
acl = models.ForeignKey(ACL, related_name='links', on_delete=models.CASCADE)
2025-01-09 17:24:12 +00:00
comment = models.TextField(default="", blank=True, help_text="ACL link comment, device name, etc...")
link = models.CharField(max_length=1024, default="", unique=True, blank=True, null=True, verbose_name="Access link", help_text="Access link to get dynamic configuration")
2024-10-28 17:15:49 +00:00
def save(self, *args, **kwargs):
2024-10-28 17:32:06 +00:00
if self.link == "":
2024-10-28 17:15:49 +00:00
self.link = shortuuid.ShortUUID().random(length=16)
super().save(*args, **kwargs)
def __str__(self):
2025-06-27 16:02:13 +03:00
return self.link