documents.py 4.2 KB

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