resource.py 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. from django.db import models
  2. from django.contrib.auth import get_user_model
  3. from tickets.models import Ticket
  4. class Resource(models.Model):
  5. """
  6. Resource/Список ресурсов – автомобили/дома/объекты сервиса
  7. """
  8. # ID METASERVICE
  9. id_metaservice = models.PositiveIntegerField(
  10. null=True,
  11. help_text="уникальный идентификатор мета-сервиса, необходимый для синхронизации данных. Один и тот же провайдер может быть для нескольких мета-сервисов, соответственно если происходят изменения в одном, то либо форсируется изменение во всех (если возможно), либо снимается is_global. Соответственно при изменении is_global в true должно происходить согласование с остальными копиями в других сервисах. Нужен в том числе для того, чтобы выяснять, в каких еще сервисах есть этот провайдер."
  12. )
  13. # DATA
  14. resoure_type = models.CharField(
  15. max_length=10,
  16. help_text="определение типа ресурса по его уникальному идентификатору в соответствии с классификатором"
  17. )
  18. requirements = models.CharField(
  19. max_length=150,
  20. help_text="код необходимого (самый строгий) для того, чтобы ресурс мог стать активным"
  21. )
  22. status = models.CharField(
  23. max_length=150,
  24. help_text="статус ресурса в системе относительно прохождения проверок (activity_status) (может быть active только в том случае, если ticket, влияющий на статус - закрыт."
  25. )
  26. # OTHER
  27. is_global = models.BooleanField(
  28. default=False,
  29. help_text="доступны ли данные (по услугам или ресурсам?) для хранения в глобальном сервисе/необходима синхронизация"
  30. )
  31. is_visible = models.BooleanField(
  32. default=False,
  33. help_text="доступно ли для планирования в цепочке с другими услугами в глобальном сервисе"
  34. )
  35. # FK
  36. ticket_status = models.ForeignKey(
  37. Ticket,
  38. on_delete=models.DO_NOTHING,
  39. help_text="id последнего актуального тикета, касающийся статуса. Если он меняет статус на закрытый - вызывается проверка, которая смотрит, нет ли другого открытого по пользователю."
  40. )
  41. user_id = models.ForeignKey(
  42. get_user_model(),
  43. on_delete=models.DO_NOTHING,
  44. help_text="уникальный идентификатор ответственного (за состояние, доступность и так далее - то есть для договора) пользователя - идентификатор провайдера, по которому восстанавливается конкретный пользовательский аккаунт"
  45. )
  46. class Meta:
  47. db_table = "resource"
  48. verbose_name = "Ресурс"
  49. verbose_name_plural = "Ресурсы"