orders.py 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. from django.db import models
  2. from django.contrib.auth import get_user_model
  3. from dbsynce.models.client import Client
  4. from dbsynce.models.provider import Provider
  5. from dbsynce.models.service import Service
  6. from dbsynce.models.servicetype import ServiceType
  7. from tickets.models import Ticket
  8. class Orders(models.Model):
  9. """
  10. Orders - таблица с заказами
  11. """
  12. service = models.ForeignKey(
  13. Service,
  14. null=True,
  15. on_delete=models.DO_NOTHING,
  16. help_text="спецификатор услуги провайдера, нужен для установления цены (id_service - уникальный идентификатор шаблона услуги, необходим для установления цены и исполнителей."
  17. )
  18. service_type = models.ForeignKey(
  19. ServiceType,
  20. null=True,
  21. on_delete=models.DO_NOTHING,
  22. help_text="тип заказа по классификатору услу"
  23. )
  24. state = models.CharField(
  25. max_length=150,
  26. help_text="текущий статус заказа из возможных на платформе"
  27. )
  28. id_metaservice = models.BigIntegerField(
  29. null=True,
  30. help_text="уникальный идентификатор мета-сервиса, необходимый для синхронизации данных. Если при синхронизации возникает конфликт (несовместимость) с другим сервисом, предлагается или форсировать изменения везде (если возможно), либо is_global выставляется как false."
  31. )
  32. provider = models.ForeignKey(
  33. Provider,
  34. null=True,
  35. on_delete=models.DO_NOTHING,
  36. help_text="уникальный идентификатор поставщика услуги/аккаунта, который оказывает услугу. Если несколько провайдеров собираются мета-сервисом в цепочку, где на уровне связи с клиентом нельзя установить одно ответственное лицо, то указывается вспомогательный мета-провайдер сервиса, и это означает, что мета-сервис несет ответственность перед пользователем за сборку услуги воедино."
  37. )
  38. receiver = models.ForeignKey(
  39. get_user_model(),
  40. null=True,
  41. related_name="user_id",
  42. on_delete=models.DO_NOTHING,
  43. help_text="пользователь/аккаунт, который принимает оказываемые услуги"
  44. )
  45. client_id = models.ForeignKey(
  46. Client,
  47. null=True,
  48. on_delete=models.DO_NOTHING,
  49. help_text="клиент/аккаунт, который оплачивает все оказанные услуги"
  50. )
  51. time_created = models.DateTimeField(
  52. auto_now_add=True,
  53. help_text="время создания заказа"
  54. )
  55. time_placed = models.DateTimeField(
  56. help_text="время размещения заказа"
  57. )
  58. time_start = models.DateTimeField(
  59. null=True,
  60. help_text="время начала оказания услуги"
  61. )
  62. time_start_real = models.DateTimeField(
  63. null=True,
  64. help_text=""
  65. )
  66. time_start_predicted = models.DateTimeField(
  67. null=True,
  68. help_text=""
  69. )
  70. time_finish_predicted = models.DateTimeField(
  71. help_text="предварительное/расчетное время до окончания оказания услуги"
  72. )
  73. time_finish_real = models.DateTimeField(
  74. null=True,
  75. help_text="фактическое время окончания (точное установленное время)"
  76. )
  77. ticket = models.ForeignKey(
  78. Ticket,
  79. null=True,
  80. on_delete=models.DO_NOTHING
  81. )
  82. predicted_price = models.FloatField(
  83. help_text="расчетная цена с учетом тарифа поставщика услуг"
  84. )
  85. real_price = models.FloatField(
  86. help_text="цена с учетом тарифа поставщика услуг по факту оказания услуги"
  87. )
  88. is_global = models.BooleanField(
  89. default=False,
  90. help_text="доступна ли информация по заказу для хранения в глобальном сервисе/нужна синхронизация данных. Если is_global = false, то и is_visible для заказа и вглубь по цепочке для всех исполнителей и ресурсов - тоже false."
  91. )
  92. is_visible = models.BooleanField(
  93. default=False,
  94. help_text="доступна ли информация по заказу (время, место) для планирования иных цепочек. Если нет, то все действующие исполнители и ресурсы считаются занятыми на неопределенное время, пока не завершится заказ. Если да - то ресурсы могут использоваться для построения цепочек после планируемого времени завершения, с учетом места."
  95. )
  96. class Meta:
  97. db_table = "orders"
  98. verbose_name = "Заказ"
  99. verbose_name_plural = "Заказы"