network_inventory/src/licenses/models.py

65 lines
1.9 KiB
Python
Raw Normal View History

2019-12-29 23:54:27 +01:00
from django.db import models
2020-01-10 00:01:06 +01:00
from customers.models import Customer
2020-01-12 14:36:44 +01:00
from computers.models import Computer
2020-01-10 00:01:06 +01:00
from users.models import User
2020-01-12 12:43:01 +01:00
from softwares.models import Software
2019-12-29 23:54:27 +01:00
class License(models.Model):
customer = models.ForeignKey(Customer, on_delete=models.CASCADE)
key = models.CharField(max_length=50, null=True, blank=True)
2022-03-27 14:50:44 +02:00
software = models.ForeignKey(Software, null=True, on_delete=models.CASCADE)
2019-12-29 23:54:27 +01:00
def __str__(self):
return str(self.customer) + ": " + str(self.software)
class Meta:
abstract = True
class UserLicense(License):
max_allowed_users = models.IntegerField(null=True, blank=True)
user = models.ManyToManyField(User, through="LicenseWithUser")
2020-07-07 22:12:57 +02:00
class Meta:
2022-03-27 14:50:44 +02:00
ordering = ["software"]
2020-07-07 22:12:57 +02:00
2019-12-29 23:54:27 +01:00
@property
def used_licenses(self):
2020-05-25 22:57:30 +02:00
return LicenseWithUser.objects.filter(license=self).count()
2019-12-29 23:54:27 +01:00
class ComputerLicense(License):
max_allowed_computers = models.IntegerField(null=True, blank=True)
computer = models.ManyToManyField(Computer, through="LicenseWithComputer")
2020-07-07 22:12:57 +02:00
class Meta:
2022-03-27 14:50:44 +02:00
ordering = ["software"]
2020-07-07 22:12:57 +02:00
2019-12-29 23:54:27 +01:00
@property
def used_licenses(self):
return LicenseWithComputer.objects.filter(license=self).count()
class LicenseWithUser(models.Model):
user = models.ForeignKey(User, on_delete=models.CASCADE)
license = models.ForeignKey(UserLicense, on_delete=models.CASCADE)
class Meta:
constraints = [
2023-07-10 16:47:01 +02:00
models.UniqueConstraint(fields=["user", "license"], name="user per license")
]
2019-12-29 23:54:27 +01:00
class LicenseWithComputer(models.Model):
computer = models.ForeignKey(Computer, on_delete=models.CASCADE)
license = models.ForeignKey(ComputerLicense, on_delete=models.CASCADE)
class Meta:
constraints = [
2022-03-27 14:50:44 +02:00
models.UniqueConstraint(
fields=["computer", "license"], name="computer per license"
)
]