provider.py 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. from dbsynce.models import Provider
  2. from django.contrib.auth.decorators import login_required
  3. from django.contrib.auth.mixins import UserPassesTestMixin
  4. from django.http import JsonResponse
  5. from django.utils.translation import gettext as _
  6. from django_tables2 import SingleTableView
  7. from sharix_admin.tables import ProvidersTable
  8. from sharix_admin.utils import group_required
  9. from .base import BaseView
  10. from sharix_admin.utils import group_required
  11. from django.contrib.auth.decorators import login_required
  12. from django.urls import reverse_lazy
  13. from django.views.generic.edit import FormView
  14. from django.db import transaction
  15. from django.contrib import messages
  16. from tickets.models import Ticket, TicketList
  17. from sharix_admin.forms import CompanyForm
  18. from sharix_admin.utils import *
  19. from dbsynce.lib.data import *
  20. from dbsynce.lib.dicts import *
  21. from sharix_admin.forms import ProviderCreateForm
  22. #from sharix_admin.forms import ProviderUpdateForm
  23. class ProviderCreate(BaseView, FormView):
  24. form_class = ProviderCreateForm
  25. template_name = "sharix_admin/provider_form.html"
  26. success_url = reverse_lazy("sharix_admin:providers")
  27. page_title = 'Добавить услугу к исполнению'
  28. page_name = 'providers/add/'
  29. # Проверяем не состояит ли текущий пользователь в группе METASERVICE-ADMIN
  30. def test_func(self):
  31. group_names = ('PROVIDER')
  32. if bool(self.request.user.groups.filter(name=group_names)): #or self.request.user.is_superuser:
  33. return True
  34. return False
  35. #return not "METASERVICE-ADMIN" in self.user_groups
  36. def form_valid(self, form):
  37. with transaction.atomic():
  38. # Сохраняем форму, чтобы получить объект компании
  39. instance = form.save(commit=False)
  40. # Присваиваем полю repr идентификатор текущего пользователя
  41. #instance.repr = self.request.user
  42. # Создаем новую запись в БД, чтобы иметь доступ к ID
  43. instance.save()
  44. #TODO ADD INTEGRATION WITH PLATFORM!
  45. # Создание тикета на активацию Категории услуг на Платформе.
  46. # Создаем объект тикета и присваиваем его полю ticket_status
  47. #instance.ticket_status = create_ticket_company_activation(self.request.user, instance)
  48. instance.ticket_status = create_ticket_provider_activation_by_partner_admin(self.request.user, instance)
  49. # Создание тикета на утверждение прав пользователя
  50. #create_ticket_role_activation_partner_admin(self.request.user, instance)
  51. # Сохраняем новые изменения
  52. instance.save()
  53. #TODO! Это делать на платформе!
  54. # Создаем необходимые объекты документов по requirements указанных в созданной company
  55. # Используем bulk_create для создания всех объектов одновременно
  56. #doc_codes = parse_requirements(instance.requirements)
  57. #Documents.objects.bulk_create([
  58. # Documents(
  59. # company=instance,
  60. # user=self.request.user,
  61. # doc_type=doc_code
  62. # ) for doc_code in doc_codes
  63. #])
  64. # Отправляем пользователю уведомление на страницу о успехе операции
  65. messages.success(
  66. self.request,
  67. 'Ваша заявка на добавление категории услуг успешно отправлена на Платформу и теперь проходит проверку! Если Сервис не подключен к Платформе, можете активировать категорию услуг в списке вручную.'
  68. )
  69. return super().form_valid(form) # Возвращаем успешный ответ
  70. class ProvidersListView(BaseView, UserPassesTestMixin, SingleTableView):
  71. page_title = _('Исполнители по видам услуг')
  72. page_name = 'providers'
  73. table_class = ProvidersTable
  74. queryset = Provider.objects.all()
  75. template_name = 'sharix_admin/providers.html'
  76. def get_queryset(self):
  77. queryset = super().get_queryset()
  78. search_query = self.request.GET.get('q', '').strip()
  79. if search_query:
  80. queryset = queryset.filter(
  81. Q(id__icontains=search_query) |
  82. Q(service_status__icontains=search_query) |
  83. Q(service__icontains=search_query) |
  84. Q(resource__icontains=search_query)
  85. ).distinct()
  86. return queryset
  87. def get_context_data(self, **kwargs):
  88. context = super().get_context_data(**kwargs)
  89. context.update({
  90. 'title': _('Performers'),
  91. 'object_list': context['object_list'],
  92. })
  93. return context
  94. def test_func(self) -> bool or None:
  95. # group_names = ('PARTNER-ADMIN')
  96. # if bool(self.request.user.groups.filter(name=group_names)) or self.request.user.is_superuser:
  97. # return True
  98. # return False
  99. return True
  100. @login_required
  101. @group_required('PARTNER-ADMIN')
  102. def change_provider_status(request):
  103. if request.method == 'POST':
  104. provider_id = request.POST.get('provider_id')
  105. new_status = request.POST.get('new_status')
  106. provider = Provider.objects.get(pk=provider_id)
  107. provider.status = new_status
  108. provider.save()
  109. return JsonResponse({'status': 'success'})
  110. else:
  111. return JsonResponse({'status': 'error'})