1
0

documents.py 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  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=METASERVICE_ID,
  36. help_text=HelpTexts.id_metaservice
  37. )
  38. # DATA
  39. check_date = models.DateTimeField(
  40. auto_now_add=True,
  41. help_text="timestamp проверки"
  42. )
  43. check_level = models.IntegerField(
  44. null=True,
  45. blank=True,
  46. help_text=HelpTexts.check_level
  47. )
  48. expire_date = models.DateField(
  49. null=True,
  50. blank=True,
  51. help_text=HelpTexts.expire_date
  52. )
  53. # FIXME: status должен иметь другое значение поумолчанию
  54. status = models.CharField(
  55. max_length=150,
  56. default="deactivated",
  57. help_text="активность на основе системы заявок"
  58. )
  59. data_path = models.CharField(
  60. max_length=1024,
  61. help_text=HelpTexts.data_path
  62. )
  63. doc_type = models.CharField(
  64. max_length=2,
  65. choices=DOC_TYPES,
  66. help_text=HelpTexts.doc_type
  67. )
  68. # OTHER
  69. is_global = models.CharField(
  70. max_length=1,
  71. default="f",
  72. help_text=HelpTexts.is_global
  73. )
  74. is_visible = models.CharField(
  75. max_length=1,
  76. default="f",
  77. help_text=HelpTexts.is_visible
  78. )
  79. # FK
  80. company = models.ForeignKey(
  81. Company,
  82. on_delete=models.DO_NOTHING,
  83. null=True,
  84. help_text=HelpTexts.company
  85. )
  86. user = models.ForeignKey(
  87. get_user_model(),
  88. related_name="user_doc",
  89. on_delete=models.DO_NOTHING,
  90. help_text=HelpTexts.user
  91. )
  92. ticket_status = models.ForeignKey(
  93. Ticket,
  94. null=True,
  95. blank=True,
  96. on_delete=models.SET_NULL,
  97. help_text=HelpTexts.ticket_status
  98. )
  99. checked_by = models.ForeignKey(
  100. get_user_model(),
  101. null=True,
  102. blank=True,
  103. related_name="checked_by_doc",
  104. on_delete=models.DO_NOTHING,
  105. help_text=HelpTexts.checked_by
  106. )
  107. class Meta:
  108. db_table = "documents"
  109. verbose_name = "Документ"
  110. verbose_name_plural = "Документы"
  111. class DocumentFile(models.Model):
  112. document = models.ForeignKey(Documents, related_name='files', on_delete=models.CASCADE)
  113. file = models.FileField(upload_to=f'uploads/partners_docs/')
  114. def __str__(self):
  115. return os.path.basename(self.file.name)