partner.py 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. from dbsynce.models import Company, Documents, DocumentFile
  2. from django.contrib import messages
  3. from django.core.files.storage import default_storage
  4. from django.db import transaction
  5. from django.shortcuts import get_object_or_404, redirect
  6. from django.urls import reverse_lazy
  7. from django.views.generic import DetailView
  8. from django.views.generic.edit import FormView
  9. from sharix_admin.forms import CompanyForm, DocumentUploadForm
  10. from sharix_admin.utils import *
  11. from .base import BaseView
  12. from django.contrib.auth.mixins import UserPassesTestMixin
  13. from django_tables2 import SingleTableView
  14. from sharix_admin.tables import PartnersTable
  15. class PartnerBaseView(BaseView):
  16. page_name = 'partner'
  17. # Проверяем состояит ли текущий пользователь в группе PARTNER-ADMIN
  18. def test_func(self):
  19. return "PARTNER-ADMIN" in self.user_groups
  20. class PartnerDetailView(PartnerBaseView, DetailView):
  21. model = Company
  22. template_name = 'sharix_admin/partner.html'
  23. context_object_name = 'company'
  24. page_title = 'О партнере'
  25. def get_object(self, queryset=None):
  26. return get_object_or_404(Company, repr=self.request.user)
  27. def get_context_data(self, **kwargs):
  28. context = super().get_context_data(**kwargs)
  29. if not pk:
  30. docs = Documents.objects.filter(
  31. user=pk,
  32. company=company.objects.filter(user=pk)
  33. ).prefetch_related('files').order_by('doc_type')
  34. #user=self.request.user,
  35. #company=self.object
  36. #).prefetch_related('files').order_by('doc_type')
  37. context.update({"docs": docs})
  38. else:
  39. docs = Documents.objects.filter(
  40. user=self.request.user,
  41. company=self.object
  42. ).prefetch_related('files').order_by('doc_type')
  43. context.update({"docs": docs})
  44. return context
  45. class PartnerEditView(PartnerBaseView, FormView):
  46. template_name = 'sharix_admin/partner_edit.html'
  47. form_class = CompanyForm
  48. success_url = reverse_lazy('partner_detail')
  49. page_title = 'Изменение данных партнера'
  50. def get_form_kwargs(self):
  51. kwargs = super().get_form_kwargs()
  52. kwargs['instance'] = get_object_or_404(Company, repr=self.request.user)
  53. return kwargs
  54. def form_valid(self, form):
  55. with transaction.atomic():
  56. # Сохраняем изменения
  57. form.save()
  58. # Получаем текущий объект компании и деактивируем ее
  59. current_company = form.instance
  60. current_company.deactivate()
  61. # Выполняем пересоздание тикета на активацию партнера
  62. current_company.ticket_status.archive()
  63. create_ticket_company_activation(self.request.user, current_company)
  64. # Отправляем полAьзователю уведомление на страницу об успехе операции
  65. messages.success(self.request, 'Данные успешно изменены и теперь проходят проверку!')
  66. return super().form_valid(form)
  67. class PartnerDocUploadView(PartnerBaseView, FormView):
  68. # FIXME: Загрузка новых документов должна деактивировать текущего партнера (предварительно это работа обработчиков)
  69. template_name = 'sharix_admin/partner/doc_upload.html'
  70. form_class = DocumentUploadForm
  71. success_url = reverse_lazy('partner_detail')
  72. def dispatch(self, request, *args, **kwargs):
  73. self.company = get_object_or_404(Company, repr=self.request.user)
  74. self.doc = Documents.objects.filter(
  75. user=self.request.user,
  76. company=self.company,
  77. doc_type=kwargs.get('doc_code')
  78. ).first()
  79. self.doc_name = self.doc.get_doc_type_display()
  80. self.page_title = "Изменение документа партнера: " + self.doc_name
  81. return super().dispatch(request, *args, **kwargs)
  82. def form_valid(self, form):
  83. with transaction.atomic():
  84. # Удаляем существующие файлы и записи из базы данных
  85. existing_files = DocumentFile.objects.filter(document=self.doc)
  86. for existing_file in existing_files:
  87. # Удаляем файл с сервера
  88. if default_storage.exists(existing_file.file.path):
  89. default_storage.delete(existing_file.file.path)
  90. # Удаляем запись о файле из базы данных
  91. existing_file.delete()
  92. # Загрузка новых файлов
  93. doc_file = self.request.FILES.getlist("doc_file")
  94. for file in doc_file:
  95. DocumentFile.objects.create(
  96. document=self.doc,
  97. file=file
  98. )
  99. # Создание нового тикета и архивация старого
  100. if self.doc.ticket_status:
  101. self.doc.ticket_status.archive()
  102. self.doc.expire_date = self.request.POST.get('doc_expire_date') if self.request.POST[
  103. 'doc_expire_date'] else None
  104. self.doc.ticket_status = create_ticket_company_docs_verification(self.request.user, self.company, self.doc)
  105. self.doc.save()
  106. # Отправляем пользователю уведомление на страницу об успехе операции
  107. messages.success(self.request,
  108. f'Файлы документа "{self.doc_name}" успешно загружены и теперь проходят проверку!')
  109. return super().form_valid(form)
  110. class PartnerDocView(PartnerBaseView, DetailView):
  111. model = Documents
  112. template_name = 'sharix_admin/partner/doc.html'
  113. context_object_name = 'doc'
  114. def dispatch(self, request, *args, **kwargs):
  115. self.company = get_object_or_404(Company, repr=self.request.user)
  116. self.doc = Documents.objects.filter(
  117. user=self.request.user,
  118. company=self.company,
  119. doc_type=kwargs.get('doc_code')
  120. ).first()
  121. if not self.doc:
  122. return self.handle_no_permission()
  123. self.doc_name = self.doc.get_doc_type_display()
  124. self.page_title = _("Детали документа: ") + self.doc_name
  125. return super().dispatch(request, *args, **kwargs)
  126. def get_object(self, queryset=None):
  127. return self.doc
  128. def get_context_data(self, **kwargs):
  129. context = super().get_context_data(**kwargs)
  130. doc_files = DocumentFile.objects.filter(document=self.doc)
  131. context.update({"doc_files": doc_files})
  132. return context
  133. class PartnersListView(UserPassesTestMixin, SingleTableView):
  134. table_class = PartnersTable
  135. queryset = Company.objects.all()
  136. template_name = 'sharix_admin/service_tariffs.html'
  137. def get_context_data(self, **kwargs):
  138. context = super().get_context_data(**kwargs)
  139. context.update(get_context(self.request, {
  140. 'title': _('Performers'),
  141. 'object_list': context['object_list'],
  142. }))
  143. return context
  144. def test_func(self) -> bool or None:
  145. group_names = ('PARTNER-ADMIN')
  146. if bool(self.request.user.groups.filter(name=group_names)) or self.request.user.is_superuser:
  147. return True
  148. return False