aboutsummaryrefslogtreecommitdiffstats
path: root/ctrack/caf/views.py
diff options
context:
space:
mode:
Diffstat (limited to 'ctrack/caf/views.py')
-rw-r--r--ctrack/caf/views.py67
1 files changed, 42 insertions, 25 deletions
diff --git a/ctrack/caf/views.py b/ctrack/caf/views.py
index 0cee746..7345319 100644
--- a/ctrack/caf/views.py
+++ b/ctrack/caf/views.py
@@ -1,22 +1,27 @@
-from django.contrib.auth.decorators import login_required
-from django.contrib.auth.mixins import LoginRequiredMixin
+from django.contrib.auth.decorators import login_required, permission_required
+from django.contrib.auth.mixins import LoginRequiredMixin, PermissionRequiredMixin
from django.http import HttpResponseRedirect
from django.shortcuts import render
-from django.urls import reverse_lazy, reverse
-from django.views.generic import ListView, DetailView, FormView
+from django.urls import reverse, reverse_lazy
+from django.views.generic import DetailView, FormView, ListView
from ctrack.assessments.models import CAFAssessmentOutcomeScore
-from ctrack.caf.forms import ApplicableSystemCreateFromOrgForm, ApplicableSystemCreateFromCafForm
-from ctrack.caf.models import ApplicableSystem, CAF
+from ctrack.caf.forms import (
+ ApplicableSystemCreateFromCafForm,
+ ApplicableSystemCreateFromOrgForm,
+)
+from ctrack.caf.models import CAF, ApplicableSystem
from ctrack.organisations.models import Organisation
-class ListCAF(LoginRequiredMixin, ListView):
+class ListCAF(LoginRequiredMixin, PermissionRequiredMixin, ListView):
model = CAF
+ permission_required = "caf.view_caf"
# Let's write a traditional function view!
@login_required()
+@permission_required("caf.view_caf")
def caf_detail_view(request, pk):
caf = CAF.objects.get(pk=pk)
# get any assessments that have been done on this caf
@@ -29,19 +34,20 @@ def caf_detail_view(request, pk):
lst_scores.append(CAFAssessmentOutcomeScore.objects.filter(caf_assessment=ass))
_scrs.append(lst_scores)
context = {
- 'object': caf,
- 'assessments_and_scores': _scrs,
- 'organisation': ApplicableSystem.objects.filter(caf=caf).first().organisation,
- 'systems': caf.applicable_systems.all()
+ "object": caf,
+ "assessments_and_scores": _scrs,
+ "organisation": ApplicableSystem.objects.filter(caf=caf).first().organisation,
+ "systems": caf.applicable_systems.all(),
}
- return render(request, 'caf/caf_detail.html', context)
+ return render(request, "caf/caf_detail.html", context)
-class ListApplicableSystem(LoginRequiredMixin, ListView):
+class ListApplicableSystem(LoginRequiredMixin, PermissionRequiredMixin, ListView):
model = ApplicableSystem
# apparently you can pass a list of model objects to a template if you name it
# here - otherwise you need to provide a QuerySet
template_name = "caf/applicablesystem_list.html"
+ permission_required = "caf.view_caf"
def get_queryset(self):
ess = ApplicableSystem.objects.all().order_by("organisation__name")
@@ -52,34 +58,45 @@ class ListApplicableSystem(LoginRequiredMixin, ListView):
return context
-class ApplicableSystemDetail(LoginRequiredMixin, DetailView):
+class ApplicableSystemDetail(LoginRequiredMixin, PermissionRequiredMixin, DetailView):
model = ApplicableSystem
template_name = "caf/applicablesystem_detail.html"
+ permission_required = "caf.view_applicablesystem"
@login_required
+@permission_required("caf.add_applicablesystem")
def applicable_system_create_from_caf(request, caf_id):
org_id = CAF.objects.get(pk=caf_id).organisation().id
caf = CAF.objects.get(id=caf_id)
- if request.method=="POST":
- form = ApplicableSystemCreateFromCafForm(request.POST, caf_id=caf_id, org_id=org_id)
+ if request.method == "POST":
+ form = ApplicableSystemCreateFromCafForm(
+ request.POST, caf_id=caf_id, org_id=org_id
+ )
if form.is_valid():
ApplicableSystem.objects.create(
name=form.cleaned_data["name"],
description=form.cleaned_data["description"],
caf=form.cleaned_data["caf"],
- organisation=form.cleaned_data["organisation"]
+ organisation=form.cleaned_data["organisation"],
)
return HttpResponseRedirect(reverse("caf:detail", args=[caf_id]))
else:
form = ApplicableSystemCreateFromCafForm(caf_id=caf_id, org_id=org_id)
- return render(request, "caf/applicable_system_create_from_caf.html", {"form": form, "caf": caf})
+ return render(
+ request,
+ "caf/applicable_system_create_from_caf.html",
+ {"form": form, "caf": caf},
+ )
-class ApplicableSystemCreateFromOrg(LoginRequiredMixin, FormView):
+class ApplicableSystemCreateFromOrg(
+ LoginRequiredMixin, PermissionRequiredMixin, FormView
+):
form_class = ApplicableSystemCreateFromOrgForm
template_name = "caf/applicable_system_create_from_org.html"
+ permission_required = "caf.add_applicablesystem"
def get_context_data(self, **kwargs):
context = super().get_context_data(**kwargs)
@@ -91,7 +108,7 @@ class ApplicableSystemCreateFromOrg(LoginRequiredMixin, FormView):
name=form.cleaned_data["name"],
description=form.cleaned_data["description"],
organisation=form.cleaned_data["organisation"],
- caf=form.cleaned_data["caf"]
+ caf=form.cleaned_data["caf"],
)
return super().form_valid(form)
@@ -100,11 +117,11 @@ class ApplicableSystemCreateFromOrg(LoginRequiredMixin, FormView):
org = Organisation.objects.get(slug=self.kwargs["slug"])
asses = org.applicablesystem_set.all()
org_cafs = {ass.caf for ass in asses}
- kwargs['org_id'] = org.id
- kwargs['slug'] = org.slug
- kwargs['org_name'] = org.name
- kwargs['org_cafs'] = list(org_cafs)
+ kwargs["org_id"] = org.id
+ kwargs["slug"] = org.slug
+ kwargs["org_name"] = org.name
+ kwargs["org_cafs"] = list(org_cafs)
return kwargs
def get_success_url(self):
- return reverse_lazy("organisations:detail", args=[self.kwargs['slug']])
+ return reverse_lazy("organisations:detail", args=[self.kwargs["slug"]])