added model constraints

This commit is contained in:
Thomas Nahuel Rusiecki 2024-12-01 17:47:10 -03:00 committed by Cayo Puigdefabregas
parent 4561c5fb72
commit bbc856cafc

View file

@ -1,22 +1,33 @@
from django.db import models, connection from django.db import models, connection
from user.models import User, Institution from user.models import User, Institution
from django.core.exceptions import ValidationError
class StateDefinition(models.Model):
institution = models.ForeignKey(Institution, on_delete=models.CASCADE)
order = models.PositiveIntegerField()
state = models.CharField(max_length=255)
def __str__(self):
return f"{self.institution.name} - {self.state}"
class State(models.Model): class State(models.Model):
date = models.DateTimeField(auto_now_add=True) date = models.DateTimeField(auto_now_add=True)
institution = models.ForeignKey(Institution, on_delete=models.CASCADE) institution = models.ForeignKey(Institution, on_delete=models.CASCADE)
user = models.ForeignKey(User, on_delete=models.SET_NULL, null=True) user = models.ForeignKey(User, on_delete=models.SET_NULL, null=True)
state = models.CharField(max_length=255) state = models.CharField(max_length=50)
snapshot_uuid = models.UUIDField() snapshot_uuid = models.UUIDField()
class Meta:
unique_together = ('institution', 'state')
def __str__(self): def __str__(self):
return f"{self.institution.name} - {self.state} - {self.snapshot_uuid}" return f"{self.institution.name} - {self.state} - {self.snapshot_uuid}"
class StateDefinition(models.Model):
institution = models.ForeignKey(Institution, on_delete=models.CASCADE)
order = models.AutoField(primary_key=True)
state = models.CharField(max_length=50)
def clean(self):
if not StateDefinition.objects.filter(institution=self.institution, state=self.state).exists():
raise ValidationError(f"The state '{self.state}' is not valid for the institution '{self.institution.name}'.")
def save(self, *args, **kwargs):
self.clean()
super().save(*args, **kwargs)
def __str__(self):
return f"{self.institution.name} - {self.state}"