resource.py 3.7 KB

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