2019-02-16 09:24:31 +00:00
|
|
|
"""passbook Policy administration"""
|
|
|
|
from django.contrib import messages
|
2019-10-10 11:01:49 +00:00
|
|
|
from django.contrib.auth.mixins import LoginRequiredMixin
|
|
|
|
from django.contrib.auth.mixins import \
|
|
|
|
PermissionRequiredMixin as DjangoPermissionRequiredMixin
|
2019-02-16 09:24:31 +00:00
|
|
|
from django.contrib.messages.views import SuccessMessageMixin
|
|
|
|
from django.http import Http404
|
|
|
|
from django.urls import reverse_lazy
|
|
|
|
from django.utils.translation import ugettext as _
|
2019-10-10 11:05:03 +00:00
|
|
|
from django.views.generic import DeleteView, FormView, ListView, UpdateView
|
2019-02-16 09:24:31 +00:00
|
|
|
from django.views.generic.detail import DetailView
|
2019-10-10 11:01:49 +00:00
|
|
|
from guardian.mixins import PermissionListMixin, PermissionRequiredMixin
|
2019-02-16 09:24:31 +00:00
|
|
|
|
|
|
|
from passbook.admin.forms.policies import PolicyTestForm
|
|
|
|
from passbook.core.models import Policy
|
|
|
|
from passbook.lib.utils.reflection import path_to_class
|
2019-10-10 11:01:49 +00:00
|
|
|
from passbook.lib.views import CreateAssignPermView
|
2019-10-07 14:33:48 +00:00
|
|
|
from passbook.policies.engine import PolicyEngine
|
2019-02-16 09:24:31 +00:00
|
|
|
|
|
|
|
|
2019-10-10 11:01:49 +00:00
|
|
|
class PolicyListView(LoginRequiredMixin, PermissionListMixin, ListView):
|
2019-02-16 10:13:00 +00:00
|
|
|
"""Show list of all policies"""
|
2019-02-16 09:24:31 +00:00
|
|
|
|
|
|
|
model = Policy
|
2019-10-10 11:01:49 +00:00
|
|
|
permission_required = 'passbook_core.view_policy'
|
|
|
|
|
2019-02-16 09:24:31 +00:00
|
|
|
template_name = 'administration/policy/list.html'
|
|
|
|
|
|
|
|
def get_context_data(self, **kwargs):
|
|
|
|
kwargs['types'] = {
|
|
|
|
x.__name__: x._meta.verbose_name for x in Policy.__subclasses__()}
|
|
|
|
return super().get_context_data(**kwargs)
|
|
|
|
|
|
|
|
def get_queryset(self):
|
|
|
|
return super().get_queryset().order_by('order').select_subclasses()
|
|
|
|
|
|
|
|
|
2019-10-10 11:01:49 +00:00
|
|
|
class PolicyCreateView(SuccessMessageMixin, LoginRequiredMixin,
|
|
|
|
DjangoPermissionRequiredMixin, CreateAssignPermView):
|
2019-02-16 09:24:31 +00:00
|
|
|
"""Create new Policy"""
|
|
|
|
|
2019-10-10 11:01:49 +00:00
|
|
|
model = Policy
|
|
|
|
permission_required = 'passbook_core.add_policy'
|
|
|
|
permissions = [
|
|
|
|
'passbook_core.view_policy',
|
|
|
|
'passbook_core.change_policy',
|
|
|
|
'passbook_core.delete_policy',
|
|
|
|
]
|
|
|
|
|
2019-02-27 15:06:20 +00:00
|
|
|
template_name = 'generic/create.html'
|
2019-02-16 10:13:00 +00:00
|
|
|
success_url = reverse_lazy('passbook_admin:policies')
|
2019-02-16 09:24:31 +00:00
|
|
|
success_message = _('Successfully created Policy')
|
|
|
|
|
|
|
|
def get_form_class(self):
|
|
|
|
policy_type = self.request.GET.get('type')
|
|
|
|
model = next(x for x in Policy.__subclasses__()
|
|
|
|
if x.__name__ == policy_type)
|
|
|
|
if not model:
|
|
|
|
raise Http404
|
|
|
|
return path_to_class(model.form)
|
|
|
|
|
|
|
|
|
2019-10-10 11:01:49 +00:00
|
|
|
class PolicyUpdateView(SuccessMessageMixin, LoginRequiredMixin,
|
|
|
|
PermissionRequiredMixin, UpdateView):
|
2019-02-16 09:24:31 +00:00
|
|
|
"""Update policy"""
|
|
|
|
|
|
|
|
model = Policy
|
2019-10-10 11:01:49 +00:00
|
|
|
permission_required = 'passbook_core.change_policy'
|
|
|
|
|
2019-02-16 09:24:31 +00:00
|
|
|
template_name = 'generic/update.html'
|
2019-02-16 10:13:00 +00:00
|
|
|
success_url = reverse_lazy('passbook_admin:policies')
|
2019-02-16 09:24:31 +00:00
|
|
|
success_message = _('Successfully updated Policy')
|
|
|
|
|
|
|
|
def get_form_class(self):
|
|
|
|
form_class_path = self.get_object().form
|
|
|
|
form_class = path_to_class(form_class_path)
|
|
|
|
return form_class
|
|
|
|
|
|
|
|
def get_object(self, queryset=None):
|
|
|
|
return Policy.objects.filter(pk=self.kwargs.get('pk')).select_subclasses().first()
|
|
|
|
|
|
|
|
|
2019-10-10 11:01:49 +00:00
|
|
|
class PolicyDeleteView(SuccessMessageMixin, LoginRequiredMixin,
|
|
|
|
PermissionRequiredMixin, DeleteView):
|
2019-02-16 09:24:31 +00:00
|
|
|
"""Delete policy"""
|
|
|
|
|
|
|
|
model = Policy
|
2019-10-10 11:01:49 +00:00
|
|
|
permission_required = 'passbook_core.delete_policy'
|
|
|
|
|
2019-02-16 09:24:31 +00:00
|
|
|
template_name = 'generic/delete.html'
|
2019-02-16 10:13:00 +00:00
|
|
|
success_url = reverse_lazy('passbook_admin:policies')
|
2019-02-26 08:46:44 +00:00
|
|
|
success_message = _('Successfully deleted Policy')
|
2019-02-16 09:24:31 +00:00
|
|
|
|
|
|
|
def get_object(self, queryset=None):
|
|
|
|
return Policy.objects.filter(pk=self.kwargs.get('pk')).select_subclasses().first()
|
|
|
|
|
2019-02-26 08:46:44 +00:00
|
|
|
def delete(self, request, *args, **kwargs):
|
|
|
|
messages.success(self.request, self.success_message)
|
|
|
|
return super().delete(request, *args, **kwargs)
|
|
|
|
|
2019-02-16 09:24:31 +00:00
|
|
|
|
2019-10-10 11:01:49 +00:00
|
|
|
class PolicyTestView(LoginRequiredMixin, DetailView, PermissionRequiredMixin, FormView):
|
2019-02-16 09:24:31 +00:00
|
|
|
"""View to test policy(s)"""
|
|
|
|
|
|
|
|
model = Policy
|
|
|
|
form_class = PolicyTestForm
|
2019-10-10 11:01:49 +00:00
|
|
|
permission_required = 'passbook_core.view_policy'
|
2019-02-16 09:24:31 +00:00
|
|
|
template_name = 'administration/policy/test.html'
|
|
|
|
object = None
|
|
|
|
|
|
|
|
def get_object(self, queryset=None):
|
|
|
|
return Policy.objects.filter(pk=self.kwargs.get('pk')).select_subclasses().first()
|
|
|
|
|
|
|
|
def get_context_data(self, **kwargs):
|
|
|
|
kwargs['policy'] = self.get_object()
|
|
|
|
return super().get_context_data(**kwargs)
|
|
|
|
|
|
|
|
def post(self, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
return super().post(*args, **kwargs)
|
|
|
|
|
|
|
|
def form_valid(self, form):
|
|
|
|
policy = self.get_object()
|
|
|
|
user = form.cleaned_data.get('user')
|
2019-03-10 01:07:18 +00:00
|
|
|
policy_engine = PolicyEngine([policy])
|
|
|
|
policy_engine.for_user(user).with_request(self.request).build()
|
|
|
|
result = policy_engine.passing
|
2019-02-16 09:24:31 +00:00
|
|
|
if result:
|
|
|
|
messages.success(self.request, _('User successfully passed policy.'))
|
|
|
|
else:
|
|
|
|
messages.error(self.request, _("User didn't pass policy."))
|
|
|
|
return self.render_to_response(self.get_context_data(form=form, result=result))
|