service.py 10.0 KB

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