service.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  1. from dbsynce.models import Service
  2. from django.contrib.auth.decorators import login_required
  3. from django.http import JsonResponse
  4. from django.http import Http404
  5. from django.shortcuts import render
  6. from django.contrib.auth.mixins import UserPassesTestMixin
  7. from django.utils.translation import gettext as _
  8. from django_tables2 import SingleTableView
  9. from django.views.generic import DetailView
  10. #from sharix_admin.tables import ServiceTable
  11. from sharix_admin.utils import group_required
  12. from dbsynce.models import Documents, DocumentFile
  13. from sharix_admin.forms import DocumentUploadForm
  14. from django.shortcuts import get_object_or_404, redirect
  15. from django.core.files.storage import default_storage
  16. from django.views.generic.edit import UpdateView, CreateView, DeleteView
  17. from sharix_admin.forms import ServiceTariffCreateForm, ServiceTariffUpdateForm
  18. from sharix_admin.tables import ServiceTariffsTable
  19. from sharix_admin.tables import ProvidersTable
  20. from .base import BaseView
  21. from sharix_admin.utils import group_required
  22. from django.contrib.auth.decorators import login_required
  23. from django.urls import reverse_lazy
  24. from django.views.generic.edit import FormView
  25. from django.db import transaction
  26. from django.contrib import messages
  27. from django.db.models import Q
  28. from django.contrib.auth.mixins import UserPassesTestMixin
  29. from tickets.models import Ticket, TicketList
  30. from sharix_admin.utils import *
  31. from dbsynce.lib.data import *
  32. from dbsynce.docs.database.service import Service as ServiceHelpTexts
  33. from dbsynce.docs.verbose_names.service import Service as ServiceVerboseNames
  34. class ServiceTariffCreate(BaseView, FormView):
  35. form_class = ServiceTariffCreateForm
  36. template_name = "sharix_admin/service_tariff_form.html"
  37. success_url = reverse_lazy("sharix_admin:service_tariffs")
  38. page_title = 'Добавить тариф к категории услуг'
  39. page_name = 'service_tariff/add/'
  40. # Проверяем не состояит ли текущий пользователь в группе METASERVICE-ADMIN
  41. def test_func(self):
  42. group_names = ('PARTNER-ADMIN')
  43. #group_names = ('PARTNER-ADMIN', 'PARTNER-SUPERVISOR')
  44. if bool(self.request.user.groups.filter(name=group_names)): #or self.request.user.is_superuser:
  45. return True
  46. return False
  47. #return not "METASERVICE-ADMIN" in self.user_groups
  48. def form_valid(self, form):
  49. with transaction.atomic():
  50. # Сохраняем форму, чтобы получить объект компании
  51. instance = form.save(commit=False)
  52. #TODO Присвоить по аналогии company?
  53. # Присваиваем полю repr идентификатор текущего пользователя
  54. #instance.repr = self.request.user
  55. # Создаем новую запись в БД, чтобы иметь доступ к ID
  56. instance.save()
  57. #TODO ADD INTEGRATION WITH PLATFORM!
  58. # Создание тикета на активацию Категории услуг на Платформе.
  59. # Создаем объект тикета и присваиваем его полю ticket_status
  60. instance.ticket_status = create_ticket_service_activation(self.request.user, instance)
  61. # Создание тикета на утверждение прав пользователя
  62. #create_ticket_role_activation_partner_admin(self.request.user, instance)
  63. # Сохраняем новые изменения
  64. instance.save()
  65. #TODO! Это делать на платформе!
  66. # Создаем необходимые объекты документов по requirements указанных в созданной company
  67. # Используем bulk_create для создания всех объектов одновременно
  68. #doc_codes = parse_requirements(instance.requirements)
  69. #Documents.objects.bulk_create([
  70. # Documents(
  71. # company=instance,
  72. # user=self.request.user,
  73. # doc_type=doc_code
  74. # ) for doc_code in doc_codes
  75. #])
  76. # Отправляем пользователю уведомление на страницу о успехе операции
  77. messages.success(
  78. self.request,
  79. 'Ваша заявка на добавление категории услуг успешно отправлена на Платформу и теперь проходит проверку! Если Сервис не подключен к Платформе, можете активировать категорию услуг в списке вручную.'
  80. )
  81. return super().form_valid(form) # Возвращаем успешный ответ
  82. #class ServiceListView(UserPassesTestMixin, SingleTableView):
  83. class ServiceTariffsListView(BaseView, SingleTableView):
  84. page_title = _('Тарифы сервиса')
  85. page_name = 'service_tariffs'
  86. table_class = ServiceTariffsTable
  87. queryset = Service.objects.all()
  88. template_name = 'sharix_admin/service_tariffs.html'
  89. def get_queryset(self):
  90. queryset = super().get_queryset()
  91. search_query = self.request.GET.get('q', '').strip()
  92. if search_query:
  93. queryset = queryset.filter(
  94. Q(id__icontains=search_query) |
  95. Q(service_category__icontains=search_query) |
  96. Q(resource__icontains=search_query) |
  97. Q(company__icontains=search_query)
  98. ).distinct()
  99. return queryset
  100. def get_context_data(self, **kwargs):
  101. context = super().get_context_data(**kwargs)
  102. context.update({
  103. 'object_list': context['object_list'],
  104. })
  105. return context
  106. def testing(self, queryset, is_descending):
  107. queryset = queryset.annotate.order_by("-" if is_descending else "")
  108. return (queryset, True)
  109. def test_func(self) -> bool or None:
  110. return True
  111. # group_names = ('METASERVICE-ADMIN')
  112. # if bool(self.request.user.groups.filter(name=group_names)) or self.request.user.is_superuser:
  113. # return True
  114. # return False
  115. class ServiceTariffUpdateView(BaseView, UpdateView):
  116. model = Service
  117. page_title = _('Редактирование тарифов услуг Сервиса')
  118. form_class = ServiceTariffUpdateForm
  119. success_url = reverse_lazy("sharix_admin:service_tariffs")
  120. template_name = "sharix_admin/service_tariff_form.html"
  121. page_name = 'service_tariff/edit/'
  122. def get_context_data(self, **kwargs):
  123. context = super().get_context_data(**kwargs)
  124. context.update({
  125. 'title': _('Тарифы услуг сервиса'),
  126. 'object': self.object,
  127. "current_page": "sharix_admin:service_tariffs"
  128. })
  129. return context
  130. def test_func(self) -> bool or None:
  131. #TODO: Add a check a user belongs to a company!
  132. group_names = ('PARTNER-ADMIN')
  133. #group_names = ('METASERVICE-SUPERVISOR','PARTNER-ADMIN')
  134. if bool(self.request.user.groups.filter(name=group_names)):
  135. return True
  136. return False
  137. #def get_success_url(self):
  138. # return success_url
  139. #return reverse_lazy('sharix_admin:service_categories')
  140. def form_valid(self, form):
  141. with transaction.atomic():
  142. # Сохраняем форму, чтобы получить объект
  143. instance = form.save(commit=False)
  144. #деактивируем измененную сущность
  145. instance.status = "1"
  146. # Создаем новую запись в БД, чтобы иметь доступ к ID
  147. instance.save()
  148. # Создание тикета на активацию тарифа услуги.
  149. # Создаем объект тикета и присваиваем его полю ticket_status
  150. instance.ticket_status = create_ticket_service_activation(self.request.user, instance)
  151. # Создание тикета на утверждение прав пользователя
  152. # create_ticket_role_activation_partner_admin(self.request.user, instance)
  153. # Сохраняем новые изменения
  154. instance.save()
  155. #TODO CHECK IF DOCUMENTS NEEDED
  156. # Создаем необходимые объекты документов по requirements указанных в созданной company
  157. # Используем bulk_create для создания всех объектов одновременно
  158. #doc_codes = parse_requirements(instance.requirements)
  159. #Documents.objects.bulk_create([
  160. # Documents(
  161. # company=instance,
  162. # user=self.request.user,
  163. # doc_type=doc_code
  164. # ) for doc_code in doc_codes
  165. #])
  166. # Отправляем пользователю уведомление на страницу о успехе операции
  167. messages.success(
  168. self.request,
  169. 'Ваша заявка на изменение тарифов услуг успешно отправлена и теперь проходит проверку!'
  170. )
  171. return super().form_valid(form) # Возвращаем успешный ответ
  172. class ServiceTariffsMyListView(BaseView, SingleTableView):
  173. #class ServiceListView(UserPassesTestMixin, SingleTableView):
  174. table_class = ServiceTariffsTable
  175. #TODO change to concrete company
  176. #queryset = Service.objects.all()
  177. template_name = 'sharix_admin/service.html'
  178. def get_context_data(self, **kwargs):
  179. context = super().get_context_data(**kwargs)
  180. context.update({
  181. 'title': _('Rates'),
  182. 'object_list': context['object_list']
  183. })
  184. return context
  185. def test_func(self) -> bool or None:
  186. group_names = ('PARTNER-ADMIN','PARTNER-SUPERVISOR','PROVIDER')
  187. if bool(self.request.user.groups.filter(name=group_names)):
  188. return True
  189. return False
  190. #@login_required
  191. #@group_required('METASERVICE_SUPERVISOR')
  192. def change_service_status(request):
  193. if request.method == 'POST':
  194. service_id = request.POST.get('service_id')
  195. new_status = request.POST.get('new_status')
  196. service = Service.objects.get(pk=service_id)
  197. service.status = new_status
  198. service.save()
  199. return JsonResponse({'status': 'success'})
  200. else:
  201. return JsonResponse({'status': 'error'})
  202. class ServiceTariffDetailView(BaseView, DetailView):
  203. model = Service
  204. template_name = 'sharix_admin/service_detail.html'
  205. context_object_name = 'service'
  206. page_title = 'О тарифе'
  207. page_name = 'service_tariff_detail'
  208. def detail_view(self, request, primary_key):
  209. try:
  210. service = Service.objects.get(pk=primary_key)
  211. except Service.DoesNotExist:
  212. raise Http404('Service does not exist')
  213. return render(request, self.template_name, context={
  214. 'help_texts': ServiceHelpTexts,
  215. 'captions': ServiceVerboseNames,
  216. })
  217. def get_context_data(self, **kwargs):
  218. context = super().get_context_data(**kwargs)
  219. context['help_texts'] = ServiceHelpTexts
  220. context['captions'] = ServiceVerboseNames
  221. return context