relationship.py 4.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. from django.db import models
  2. from django.contrib.auth import get_user_model
  3. from tickets.models import Ticket
  4. class Relationship(models.Model):
  5. """
  6. Relationship - описание связей
  7. (желательных - как имеющиеся договорные отношения,
  8. и нежелательных - как пожелание любой из сторон)
  9. """
  10. # ID METASERVICE
  11. id_metaservice = models.PositiveIntegerField(
  12. null=True,
  13. help_text="уникальный идентификатор мета-сервиса, необходимый для синхронизации данных. Один и тот же провайдер может быть для нескольких мета-сервисов, соответственно если происходят изменения в одном, то либо форсируется изменение во всех (если возможно), либо снимается is_global. Соответственно при изменении is_global в true должно происходить согласование с остальными копиями в других сервисах. Нужен в том числе для того, чтобы выяснять, в каких еще сервисах есть этот провайдер."
  14. )
  15. # DATA
  16. neg_type = models.IntegerField(
  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="(статус обработки заявки в системе заявок)"
  26. )
  27. # OTHER
  28. is_global = models.BooleanField(
  29. default=False,
  30. help_text="установленный тип договорных отношений между клиентами/пользователями/аккаунтами доступен для хранения в глобальном сервисе/нужна синхронизация"
  31. )
  32. is_visible = models.BooleanField(
  33. default=False,
  34. help_text="установленный тип договорных отношений между клиентами/пользователями/аккаунтами, доступен для планирования в цепочке с другими услугами в глобальном сервисе"
  35. )
  36. # FK
  37. user_id_who = models.ForeignKey(
  38. get_user_model(),
  39. related_name="user_id_who",
  40. on_delete=models.DO_NOTHING,
  41. help_text="уникальный идентификатор инициатора договорных отношений"
  42. )
  43. user_id_whom = models.ForeignKey(
  44. get_user_model(),
  45. related_name="user_id_whom",
  46. on_delete=models.DO_NOTHING,
  47. help_text=" уникальный идентификатор того с кем связываются"
  48. )
  49. ticket_status = models.ForeignKey(
  50. Ticket,
  51. on_delete=models.DO_NOTHING,
  52. help_text="id заявки, по которой происходит проверка статуса relationship. State меняется только в результате изменений в заявке."
  53. )
  54. class Meta:
  55. db_table = "relationship"
  56. verbose_name = "Связь (Договорное отношение)"
  57. verbose_name_plural = "Связи (Договорные отношения)"