company.py 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. from django.db import models
  2. from django.contrib.auth import get_user_model
  3. from tickets.models import Ticket
  4. class Company(models.Model):
  5. # ID METASERVICE
  6. # FIXME: id_metaservice должно принимать текущий идентификатор метасервиса, на котором происходит создание записи
  7. id_metaservice = models.PositiveIntegerField(
  8. default=1,
  9. help_text="Уникальный идентификатор метасервиса, необходимый для синхронизации данных. Один и тот же провайдер может быть для нескольких метасервисов, соответственно если происходят изменения в одном, то либо форсируется изменение во всех (если возможно), либо снимается is_global. Соответственно при изменении is_global в true должно происходить согласование с остальными копиями в других сервисах. Нужен в том числе для того, чтобы выяснять, в каких еще сервисах есть этот провайдер."
  10. )
  11. # DATA
  12. requirements = models.CharField(
  13. "Ограничения",
  14. max_length=150,
  15. default="DS01y04y05y06y07yMPUCS13MPUB",
  16. help_text="Код необходимый для того, чтобы ресурс мог стать активным"
  17. )
  18. status = models.CharField(
  19. "Статус",
  20. max_length=150,
  21. default="deactivated",
  22. help_text="Cтатус обработки заявки"
  23. )
  24. legal_name = models.CharField(
  25. "Название организации",
  26. max_length=150,
  27. help_text="Настоящее имя юридического лица"
  28. )
  29. address = models.CharField(
  30. "Юридический адрес",
  31. max_length=150
  32. )
  33. inn = models.CharField(
  34. "ИНН компании",
  35. max_length=12,
  36. unique=True
  37. )
  38. kpp = models.CharField(
  39. "КПП компании",
  40. max_length=9
  41. )
  42. ogrn = models.CharField(
  43. "ОГРН компании",
  44. max_length=13
  45. )
  46. bank_name = models.CharField(
  47. "Название банка",
  48. max_length=150,
  49. help_text="Название банка с расчетным счетом"
  50. )
  51. bik = models.CharField(
  52. "БИК компании",
  53. max_length=9
  54. )
  55. rs = models.CharField(
  56. "Расчетный счет",
  57. max_length=50
  58. )
  59. ks = models.CharField(
  60. "Корреспондентский счет",
  61. max_length=50,
  62. help_text="Корреспондентский счет (счет, открываемый банковской организацией в подразделении самого банка)"
  63. )
  64. # FIXME: tax_method field not exist
  65. # OTHER
  66. is_global = models.CharField(
  67. max_length=1,
  68. default="f",
  69. help_text="Доступно ли для хранения в глобальном сервисе / Нужна синхронизация данных"
  70. )
  71. is_visible = models.CharField(
  72. max_length=1,
  73. default="f",
  74. help_text="Доступно ли для планирования в цепочке с другими услугами в глобальном сервисе"
  75. )
  76. # FK
  77. # FIXME: Нет уверенности, что после удаления пользователя следует оставлять `models.DO_NOTHING`
  78. repr_id =models.ForeignKey(
  79. get_user_model(),
  80. blank=True,
  81. verbose_name="Представитель организации",
  82. on_delete=models.DO_NOTHING,
  83. help_text="Уникальный идентификатор представителя компании"
  84. )
  85. # FIXME: Нет уверенности, что после удаления заявки следует оставлять `models.DO_NOTHING`
  86. ticket_status = models.ForeignKey(
  87. Ticket,
  88. on_delete=models.SET_NULL,
  89. blank=True,
  90. null=True,
  91. help_text="ID заявки, привязанной к текущей записи",
  92. verbose_name="Связанный тикет"
  93. )
  94. def deactivate(self):
  95. self.status = "deactivated"
  96. self.save()
  97. class Meta:
  98. db_table = "company"
  99. verbose_name = "Компания"
  100. verbose_name_plural = "Компании"