provider.py 6.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. from .template import Template
  2. class Provider(models.Model):
  3. """
  4. Provider – единица описания поставщика услуг/ответственного лица за определенный ресурс (например, машину).
  5. По сути - это надстройка к клиентскому аккаунту, иллюстрирующая, что данный пользователь может выступать не только в роли потребителя.
  6. То есть, по тому, какие “провайдеры” находятся по идентификатору пользователя - можно установить конкретный список услуг данного пользователя.
  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. type = models.CharField(
  18. max_length=150,
  19. help_text="тип поставщика (партнер/ответственное лицо/поставщик услуг). Смысл такой - провайдер это статус пользователя, который, в зависимости от применения, может нести разный смысл и подразумевает под собой какой-то тип действия. Обычные исполнители - это провайдеры услуг (код 3). Ответственные за какое-то имущество, которые сдают его в аренду - это тоже провайдеры (код 2). Ответственные за набор услуг перед метасервисом (фактически - назначенные админы) - это провайдеры-партнеры (код 1)"
  20. )
  21. requirements = models.CharField(
  22. max_length=300,
  23. help_text="требования для того, чтобы можно было предоставлять услуги любые в этом метасервисе в целом (самые строгие)"
  24. )
  25. status = models.CharField(
  26. max_length=150,
  27. help_text="статус пользователя в системе относительно прохождения проверок (activity_status) (может быть active только в том случае, если ticket, влияющий на статус - закрыт."
  28. )
  29. location_type = models.CharField(
  30. max_length=300,
  31. help_text="статическая или динамическая локация оказания услуги. Если статическая, а исполнитель находится существенно за пределами локации - то тогда статус автоматом оффлайн для приема новых заявок."
  32. )
  33. default_location = models.CharField(
  34. max_length=300,
  35. help_text="локация по умолчанию для объекта."
  36. )
  37. # OTHER
  38. is_global = models.CharField(
  39. max_length=1,
  40. default="f",
  41. help_text="(аккаунт поставщика услуг) – доступен для планирования в цепочке с другими услугами в глобальном сервисе"
  42. )
  43. is_visible = models.CharField(
  44. max_length=1,
  45. default="f",
  46. help_text="(аккаунт поставщика услуг) – доступен для хранения в глобальном сервисе/необходима синхронизация"
  47. )
  48. # FK
  49. user_id = models.ForeignKey(
  50. get_user_model(),
  51. on_delete=models.DO_NOTHING,
  52. null=True,
  53. help_text="уникальный идентификатор конкретного пользователя системы (meta-user), который будет оказывать услугу. Один пользователь может быть провайдером нескольких услуг. Статус провайдера означает, что с данным пользователем может быть установлена связь, как с исполнителем."
  54. )
  55. company_id = models.ForeignKey(
  56. Company,
  57. on_delete=models.DO_NOTHING,
  58. null=True,
  59. help_text="уникальный идентификатор компании, от лица которой выступает провайдер. Смысл такой - ответственны могут быть только одушевленные лица, компании - не одушевленные. Все услуги предоставляются через компании-партнеры, самозанятые или ИП являются единицами таких компаний."
  60. )
  61. ticket_status = models.ForeignKey(
  62. Ticket,
  63. on_delete=models.DO_NOTHING,
  64. null=True,
  65. help_text="id последнего актуального тикета, касающийся статуса. Если он меняет статус на закрытый - вызывается проверка, которая смотрит, нет ли другого открытого по пользователю."
  66. )
  67. service = models.ForeignKey(
  68. Service,
  69. on_delete=models.DO_NOTHING,
  70. null=True,
  71. help_text="id услуги, которую предостовляют"
  72. )