135 lines
4.9 KiB
Python
135 lines
4.9 KiB
Python
import re
|
|
from pathlib import Path
|
|
|
|
from django.db import models
|
|
from django.utils import timezone
|
|
|
|
from core.models import Aulario as CoreAulario
|
|
|
|
|
|
def _safe_segment(value: str) -> str:
|
|
return re.sub(r"[^A-Za-z0-9._-]", "", (value or ""))
|
|
|
|
|
|
def student_photo_upload_to(instance, filename: str) -> str:
|
|
ext = Path(filename or "").suffix.lower() or ".bin"
|
|
alumno = _safe_segment(instance.alumno) or "alumno"
|
|
org_id = _safe_segment(instance.org_id) or "org"
|
|
aulario_id = _safe_segment(instance.aulario_id) or "aulario"
|
|
return f"aulatek/{org_id}/{aulario_id}/{alumno}{ext}"
|
|
|
|
|
|
def _comedor_photo_upload_to(instance, filename: str, slot: str) -> str:
|
|
ext = Path(filename or "").suffix.lower() or ".bin"
|
|
org_id = _safe_segment(instance.org_id) or "org"
|
|
aulario_id = _safe_segment(instance.aulario_id) or "aulario"
|
|
menu_type = _safe_segment(getattr(instance, "menu_type", "")) or "menu"
|
|
menu_date = _safe_segment(str(getattr(instance, "menu_date", ""))) or "sin-fecha"
|
|
slot_name = _safe_segment(slot) or "plato"
|
|
return f"aulatek/{org_id}/{aulario_id}/comedor/{menu_date}/{menu_type}/{slot_name}{ext}"
|
|
|
|
|
|
def comedor_first_photo_upload_to(instance, filename: str) -> str:
|
|
return _comedor_photo_upload_to(instance, filename, "primero")
|
|
|
|
|
|
def comedor_second_photo_upload_to(instance, filename: str) -> str:
|
|
return _comedor_photo_upload_to(instance, filename, "segundo")
|
|
|
|
|
|
def comedor_dessert_photo_upload_to(instance, filename: str) -> str:
|
|
return _comedor_photo_upload_to(instance, filename, "postre")
|
|
|
|
|
|
class StudentAttachment(models.Model):
|
|
org_id = models.TextField()
|
|
aulario_id = models.TextField()
|
|
alumno = models.TextField()
|
|
data = models.JSONField(default=dict, blank=True)
|
|
photo = models.FileField(upload_to=student_photo_upload_to, blank=True, null=True)
|
|
created_at = models.DateTimeField(auto_now_add=True)
|
|
updated_at = models.DateTimeField(auto_now=True)
|
|
|
|
class Meta:
|
|
db_table = "aulatek_student_attachments"
|
|
unique_together = (("org_id", "aulario_id", "alumno"),)
|
|
|
|
def __str__(self):
|
|
return f"{self.org_id}/{self.aulario_id}/{self.alumno}"
|
|
|
|
|
|
class ComedorMenu(models.Model):
|
|
org_id = models.TextField()
|
|
aulario_id = models.TextField()
|
|
menu_name = models.TextField()
|
|
menu_type = models.TextField(default="Basal")
|
|
menu_date = models.DateField(default=timezone.localdate)
|
|
|
|
first_name = models.TextField()
|
|
first_photo = models.FileField(upload_to=comedor_first_photo_upload_to, blank=True, null=True)
|
|
second_name = models.TextField()
|
|
second_photo = models.FileField(upload_to=comedor_second_photo_upload_to, blank=True, null=True)
|
|
dessert_name = models.TextField()
|
|
dessert_photo = models.FileField(upload_to=comedor_dessert_photo_upload_to, blank=True, null=True)
|
|
shared_aularios = models.ManyToManyField("core.Aulario", blank=True, related_name="shared_comedor_menus")
|
|
|
|
created_by = models.TextField(default="")
|
|
created_at = models.DateTimeField(auto_now_add=True)
|
|
updated_at = models.DateTimeField(auto_now=True)
|
|
|
|
class Meta:
|
|
db_table = "aulatek_comedor_menus"
|
|
unique_together = (("org_id", "aulario_id", "menu_date", "menu_type"),)
|
|
|
|
def __str__(self):
|
|
return f"{self.org_id}/{self.aulario_id}/{self.menu_date}/{self.menu_type}"
|
|
|
|
|
|
class ComedorMenuType(models.Model):
|
|
org_id = models.TextField()
|
|
source_aulario_id = models.TextField()
|
|
type_id = models.TextField()
|
|
label = models.TextField()
|
|
color = models.TextField(default="#0d6efd")
|
|
shared_aularios = models.ManyToManyField("core.Aulario", blank=True, related_name="shared_comedor_menu_types")
|
|
created_by = models.TextField(default="")
|
|
created_at = models.DateTimeField(auto_now_add=True)
|
|
updated_at = models.DateTimeField(auto_now=True)
|
|
|
|
class Meta:
|
|
db_table = "aulatek_comedor_menu_types"
|
|
unique_together = (("org_id", "source_aulario_id", "type_id"),)
|
|
|
|
def __str__(self):
|
|
return f"{self.org_id}/{self.source_aulario_id}/{self.type_id}"
|
|
|
|
|
|
class Cuaderno(models.Model):
|
|
org_id = models.TextField()
|
|
aulario_id = models.TextField()
|
|
alumno = models.TextField(default="")
|
|
titulo = models.TextField(default="")
|
|
contenido_encriptado = models.TextField(default="")
|
|
pin_hash = models.TextField(default="")
|
|
pin_salt = models.TextField(default="")
|
|
created_by = models.TextField(default="")
|
|
updated_by = models.TextField(default="")
|
|
created_at = models.DateTimeField(auto_now_add=True)
|
|
updated_at = models.DateTimeField(auto_now=True)
|
|
|
|
class Meta:
|
|
db_table = "aulatek_cuadernos"
|
|
|
|
def __str__(self):
|
|
alumno = self.alumno or "sin-alumno"
|
|
titulo = self.titulo or "sin-titulo"
|
|
return f"{self.org_id}/{self.aulario_id}/{alumno}/{titulo}"
|
|
|
|
|
|
class Aulario(CoreAulario):
|
|
class Meta:
|
|
proxy = True
|
|
app_label = "aulatek"
|
|
verbose_name = "Aulario"
|
|
verbose_name_plural = "Aularios"
|