provider.py 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. from django.db import models
  2. from django.contrib.auth import get_user_model
  3. from dbsynce.models.company import Company
  4. from tickets.models import Ticket
  5. class Provider(models.Model):
  6. """
  7. Provider – единица описания поставщика услуг/ответственного лица за определенный ресурс (например, машину).
  8. По сути - это надстройка к клиентскому аккаунту, иллюстрирующая, что данный пользователь может выступать не только в роли потребителя.
  9. То есть, по тому, какие “провайдеры” находятся по идентификатору пользователя - можно установить конкретный список услуг данного пользователя.
  10. """
  11. id = models.IntegerField(
  12. primary_key=True
  13. )
  14. # ID METASERVICE
  15. id_metaservice = models.PositiveIntegerField(
  16. null=True,
  17. help_text="уникальный идентификатор мета-сервиса, необходимый для синхронизации данных. Один и тот же провайдер может быть для нескольких мета-сервисов, соответственно если происходят изменения в одном, то либо форсируется изменение во всех (если возможно), либо снимается is_global. Соответственно при изменении is_global в true должно происходить согласование с остальными копиями в других сервисах. Нужен в том числе для того, чтобы выяснять, в каких еще сервисах есть этот провайдер."
  18. )
  19. # DATA
  20. type = models.CharField(
  21. max_length=150,
  22. help_text="тип поставщика (партнер/ответственное лицо/поставщик услуг). Смысл такой - провайдер это статус пользователя, который, в зависимости от применения, может нести разный смысл и подразумевает под собой какой-то тип действия. Обычные исполнители - это провайдеры услуг (код 3). Ответственные за какое-то имущество, которые сдают его в аренду - это тоже провайдеры (код 2). Ответственные за набор услуг перед метасервисом (фактически - назначенные админы) - это провайдеры-партнеры (код 1)"
  23. )
  24. requirements = models.CharField(
  25. max_length=300,
  26. help_text="требования для того, чтобы можно было предоставлять услуги любые в этом метасервисе в целом (самые строгие)"
  27. )
  28. status = models.CharField(
  29. max_length=150,
  30. help_text="статус пользователя в системе относительно прохождения проверок (activity_status) (может быть active только в том случае, если ticket, влияющий на статус - закрыт."
  31. )
  32. location_type = models.CharField(
  33. max_length=300,
  34. help_text="статическая или динамическая локация оказания услуги. Если статическая, а исполнитель находится существенно за пределами локации - то тогда статус автоматом оффлайн для приема новых заявок."
  35. )
  36. default_location = models.CharField(
  37. max_length=300,
  38. help_text="локация по умолчанию для объекта."
  39. )
  40. # OTHER
  41. is_global = models.BooleanField(
  42. default=False,
  43. help_text="(аккаунт поставщика услуг) – доступен для планирования в цепочке с другими услугами в глобальном сервисе"
  44. )
  45. is_visible = models.BooleanField(
  46. default=False,
  47. help_text="(аккаунт поставщика услуг) – доступен для хранения в глобальном сервисе/необходима синхронизация"
  48. )
  49. # FK
  50. user_id = models.ForeignKey(
  51. get_user_model(),
  52. on_delete=models.DO_NOTHING,
  53. null=True,
  54. help_text="уникальный идентификатор конкретного пользователя системы (meta-user), который будет оказывать услугу. Один пользователь может быть провайдером нескольких услуг. Статус провайдера означает, что с данным пользователем может быть установлена связь, как с исполнителем."
  55. )
  56. company_id = models.ForeignKey(
  57. Company,
  58. on_delete=models.DO_NOTHING,
  59. null=True,
  60. help_text="уникальный идентификатор компании, от лица которой выступает провайдер. Смысл такой - ответственны могут быть только одушевленные лица, компании - не одушевленные. Все услуги предоставляются через компании-партнеры, самозанятые или ИП являются единицами таких компаний."
  61. )
  62. ticket_status = models.ForeignKey(
  63. Ticket,
  64. on_delete=models.DO_NOTHING,
  65. null=True,
  66. help_text="id последнего актуального тикета, касающийся статуса. Если он меняет статус на закрытый - вызывается проверка, которая смотрит, нет ли другого открытого по пользователю."
  67. )
  68. # FIXME: service_id filed not exist
  69. class Meta:
  70. db_table = "provider"
  71. verbose_name = "Поставщик"
  72. verbose_name_plural = "Поставщики"