company.py 4.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. from django.db import models
  2. from django.urls import reverse
  3. from django.contrib.auth import get_user_model
  4. from django.contrib.contenttypes.models import ContentType
  5. from tickets.models import Ticket
  6. class Company(models.Model):
  7. legal_name = models.CharField("Название организации", max_length=150, help_text="Настоящее имя юридического лица")
  8. # FIXME: Нет уверенности, что после удаления пользователя следует оставлять `models.DO_NOTHING`
  9. repr_id =models.ForeignKey(get_user_model(), blank=True, verbose_name="Представитель организации", on_delete=models.DO_NOTHING, help_text="Уникальный идентификатор представителя компании")
  10. requirements = models.CharField("Ограничения", max_length=150, default="DS01y04y05y06y07yMPUCS13MPUB", help_text="Код необходимый для того, чтобы ресурс мог стать активным")
  11. status = models.CharField("Статус", max_length=150, default="deactivated", help_text="Cтатус обработки заявки")
  12. # FIXME: Нет уверенности, что после удаления заявки следует оставлять `models.DO_NOTHING`
  13. ticket_status = models.ForeignKey(Ticket, on_delete=models.SET_NULL, blank=True, null=True, help_text="ID заявки, привязанной к текущей записи", verbose_name="Связанный тикет")
  14. inn = models.CharField("ИНН компании", max_length=10, unique=True)
  15. kpp = models.CharField("КПП компании", max_length=9)
  16. ogrn = models.CharField("ОГРН компании", max_length=13)
  17. bank_name = models.CharField("Название банка", max_length=150, help_text="Название банка с расчетным счетом")
  18. bik = models.CharField("БИК компании", max_length=9)
  19. rs = models.CharField("Расчетный счет", max_length=50)
  20. ks = models.CharField("Корреспондентский счет", max_length=50, help_text="Корреспондентский счет (счет, открываемый банковской организацией в подразделении самого банка)")
  21. address = models.CharField("Юридический адрес", max_length=150)
  22. is_global = models.CharField(max_length=1, default="f", help_text="Доступно ли для хранения в глобальном сервисе / Нужна синхронизация данных")
  23. is_visible = models.CharField(max_length=1, default="f", help_text="Доступно ли для планирования в цепочке с другими услугами в глобальном сервисе")
  24. # FIXME: id_metaservice должно принимать текущий идентификатор метасервиса, на котором происходит создание записи
  25. id_metaservice = models.PositiveBigIntegerField(default=1, help_text="Уникальный идентификатор метасервиса, необходимый для синхронизации данных. Один и тот же провайдер может быть для нескольких метасервисов, соответственно если происходят изменения в одном, то либо форсируется изменение во всех (если возможно), либо снимается is_global. Соответственно при изменении is_global в true должно происходить согласование с остальными копиями в других сервисах. Нужен в том числе для того, чтобы выяснять, в каких еще сервисах есть этот провайдер.")
  26. def get_admin_url(self):
  27. """
  28. Возвращает URL-адрес текущего объекта в административной панели Django.
  29. Returns:
  30. str: URL-адрес текущего объекта в административной панели Django
  31. """
  32. content_type = ContentType.objects.get_for_model(self.__class__)
  33. return reverse("admin:%s_%s_change" % (content_type.app_label, content_type.model), args=(self.id,))
  34. def deactivate(self):
  35. self.status = "deactivated"
  36. self.save()
  37. class Meta:
  38. db_table = "company"
  39. verbose_name = "Компания"
  40. verbose_name_plural = "Компании"