documents.py 4.3 KB

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