relationship.py 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. from .template import Template
  2. class Relationship(models.Model):
  3. """
  4. Relationship - описание связей
  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. neg_type = models.IntegerField(
  18. help_text="тип договорных отношений по его уникальному идентификатору"
  19. )
  20. requirements = models.CharField(
  21. max_length=150,
  22. help_text="код необходимого (самый строгий) для того, чтобы ресурс мог стать активным. Оно вставляется автоматом, в соответствии с профилем метасервиса. Далее, если кому-то из партнеров или пользователей надо строже - применяется более строгий вариант на данную связь."
  23. )
  24. status = models.CharField(
  25. max_length=150,
  26. help_text="(статус обработки заявки в системе заявок)"
  27. )
  28. # OTHER
  29. is_global = models.CharField(
  30. max_length=1,
  31. default="f",
  32. help_text="установленный тип договорных отношений между клиентами/пользователями/аккаунтами доступен для хранения в глобальном сервисе/нужна синхронизация"
  33. )
  34. is_visible = models.CharField(
  35. max_length=1,
  36. default="f",
  37. help_text="установленный тип договорных отношений между клиентами/пользователями/аккаунтами, доступен для планирования в цепочке с другими услугами в глобальном сервисе"
  38. )
  39. # FK
  40. user_id_who = models.ForeignKey(
  41. get_user_model(),
  42. related_name="user_id_who",
  43. on_delete=models.DO_NOTHING,
  44. help_text="уникальный идентификатор инициатора договорных отношений"
  45. )
  46. user_id_whom = models.ForeignKey(
  47. get_user_model(),
  48. related_name="user_id_whom",
  49. on_delete=models.DO_NOTHING,
  50. help_text=" уникальный идентификатор того с кем связываются"
  51. )
  52. ticket_status = models.ForeignKey(
  53. Ticket,
  54. on_delete=models.DO_NOTHING,
  55. help_text="id заявки, по которой происходит проверка статуса relationship. State меняется только в результате изменений в заявке."
  56. )