documents.py 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. import os
  2. from django.contrib.auth import get_user_model
  3. from django.db import models
  4. from dbsynce.models.company import Company
  5. from tickets.models import Ticket
  6. from dbsynce.docs.database.documents import Documents as HelpTexts
  7. from core.settings_vars import METASERVICE_ID
  8. class Documents(models.Model):
  9. """
  10. Documents - это одна таблица со всеми документами.
  11. Вообще в концепции предполагалось, что таких таблиц должно быть много под каждый тип для удобства поиска.
  12. То есть отдельно таблица с паспортами, отдельно с правами, отдельно с какими-нибудь разрешениями и так далее.
  13. Что пока непонятно - документов может быть много разных.
  14. """
  15. DOC_TYPES = [
  16. ("01", "Паспорт"),
  17. ("02", "ИНН"),
  18. ("03", "СНИЛС"),
  19. ("04", "Cвидетельство о регистрации компании"),
  20. ("05", "Cистема налогообложения"),
  21. ("06", "Доверенность / Приказ"),
  22. ("07", "Права / Лицензия"),
  23. ("08", "Документ, подтверждающий собственность"),
  24. ("09", "Документ об образовании"),
  25. ("10", "Медицинская книжка"),
  26. ("11", "Cправка об отсутствии судимости"),
  27. ("12", "Договор (в том числе о трудоустройстве)"),
  28. ("13", "Фотография"),
  29. ("99", "Иное"),
  30. ]
  31. DOC_TYPES_DICT = dict(DOC_TYPES)
  32. # ID METASERVICE
  33. # FIXME: id_metaservice должно принимать текущий идентификатор метасервиса, на котором происходит создание записи
  34. id_metaservice = models.PositiveIntegerField(
  35. default=1,
  36. default=METASERVICE_ID,
  37. help_text=HelpTexts.id_metaservice
  38. )
  39. # DATA
  40. check_date = models.DateTimeField(
  41. auto_now_add=True,
  42. help_text="timestamp проверки"
  43. )
  44. check_level = models.IntegerField(
  45. null=True,
  46. blank=True,
  47. help_text=HelpTexts.check_level
  48. )
  49. expire_date = models.DateField(
  50. null=True,
  51. blank=True,
  52. help_text=HelpTexts.expire_date
  53. )
  54. # FIXME: status должен иметь другое значение поумолчанию
  55. status = models.CharField(
  56. max_length=150,
  57. default="deactivated",
  58. help_text="активность на основе системы заявок"
  59. )
  60. data_path = models.CharField(
  61. max_length=1024,
  62. help_text=HelpTexts.data_path
  63. )
  64. doc_type = models.CharField(
  65. max_length=2,
  66. choices=DOC_TYPES,
  67. help_text=HelpTexts.doc_type
  68. )
  69. # OTHER
  70. is_global = models.CharField(
  71. max_length=1,
  72. default="f",
  73. help_text=HelpTexts.is_global
  74. )
  75. is_visible = models.CharField(
  76. max_length=1,
  77. default="f",
  78. help_text=HelpTexts.is_visible
  79. )
  80. # FK
  81. company = models.ForeignKey(
  82. Company,
  83. on_delete=models.DO_NOTHING,
  84. null=True,
  85. help_text=HelpTexts.company
  86. )
  87. user = models.ForeignKey(
  88. get_user_model(),
  89. related_name="user_doc",
  90. on_delete=models.DO_NOTHING,
  91. help_text=HelpTexts.user
  92. )
  93. ticket_status = models.ForeignKey(
  94. Ticket,
  95. null=True,
  96. blank=True,
  97. on_delete=models.SET_NULL,
  98. help_text=HelpTexts.ticket_status
  99. )
  100. checked_by = models.ForeignKey(
  101. get_user_model(),
  102. null=True,
  103. blank=True,
  104. related_name="checked_by_doc",
  105. on_delete=models.DO_NOTHING,
  106. help_text=HelpTexts.checked_by
  107. )
  108. class Meta:
  109. db_table = "documents"
  110. verbose_name = "Документ"
  111. verbose_name_plural = "Документы"
  112. class DocumentFile(models.Model):
  113. document = models.ForeignKey(Documents, related_name='files', on_delete=models.CASCADE)
  114. file = models.FileField(upload_to=f'uploads/partners_docs/')
  115. def __str__(self):
  116. return os.path.basename(self.file.name)