resource.py 3.5 KB

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