service.py 11 KB

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