78 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
"""passbook CertificateKeyPair administration"""
 | 
						|
from django.contrib import messages
 | 
						|
from django.contrib.auth.mixins import LoginRequiredMixin
 | 
						|
from django.contrib.auth.mixins import (
 | 
						|
    PermissionRequiredMixin as DjangoPermissionRequiredMixin,
 | 
						|
)
 | 
						|
from django.contrib.messages.views import SuccessMessageMixin
 | 
						|
from django.urls import reverse_lazy
 | 
						|
from django.utils.translation import ugettext as _
 | 
						|
from django.views.generic import DeleteView, ListView, UpdateView
 | 
						|
from guardian.mixins import PermissionListMixin, PermissionRequiredMixin
 | 
						|
 | 
						|
from passbook.crypto.forms import CertificateKeyPairForm
 | 
						|
from passbook.crypto.models import CertificateKeyPair
 | 
						|
from passbook.lib.views import CreateAssignPermView
 | 
						|
 | 
						|
 | 
						|
class CertificateKeyPairListView(LoginRequiredMixin, PermissionListMixin, ListView):
 | 
						|
    """Show list of all keypairs"""
 | 
						|
 | 
						|
    model = CertificateKeyPair
 | 
						|
    permission_required = "passbook_crypto.view_certificatekeypair"
 | 
						|
    ordering = "name"
 | 
						|
    paginate_by = 40
 | 
						|
    template_name = "administration/certificatekeypair/list.html"
 | 
						|
 | 
						|
 | 
						|
class CertificateKeyPairCreateView(
 | 
						|
    SuccessMessageMixin,
 | 
						|
    LoginRequiredMixin,
 | 
						|
    DjangoPermissionRequiredMixin,
 | 
						|
    CreateAssignPermView,
 | 
						|
):
 | 
						|
    """Create new CertificateKeyPair"""
 | 
						|
 | 
						|
    model = CertificateKeyPair
 | 
						|
    form_class = CertificateKeyPairForm
 | 
						|
    permission_required = "passbook_crypto.add_certificatekeypair"
 | 
						|
 | 
						|
    template_name = "generic/create.html"
 | 
						|
    success_url = reverse_lazy("passbook_admin:certificate_key_pair")
 | 
						|
    success_message = _("Successfully created CertificateKeyPair")
 | 
						|
 | 
						|
    def get_context_data(self, **kwargs):
 | 
						|
        kwargs["type"] = "Certificate-Key Pair"
 | 
						|
        return super().get_context_data(**kwargs)
 | 
						|
 | 
						|
 | 
						|
class CertificateKeyPairUpdateView(
 | 
						|
    SuccessMessageMixin, LoginRequiredMixin, PermissionRequiredMixin, UpdateView
 | 
						|
):
 | 
						|
    """Update certificatekeypair"""
 | 
						|
 | 
						|
    model = CertificateKeyPair
 | 
						|
    form_class = CertificateKeyPairForm
 | 
						|
    permission_required = "passbook_crypto.change_certificatekeypair"
 | 
						|
 | 
						|
    template_name = "generic/update.html"
 | 
						|
    success_url = reverse_lazy("passbook_admin:certificate_key_pair")
 | 
						|
    success_message = _("Successfully updated Certificate-Key Pair")
 | 
						|
 | 
						|
 | 
						|
class CertificateKeyPairDeleteView(
 | 
						|
    SuccessMessageMixin, LoginRequiredMixin, PermissionRequiredMixin, DeleteView
 | 
						|
):
 | 
						|
    """Delete certificatekeypair"""
 | 
						|
 | 
						|
    model = CertificateKeyPair
 | 
						|
    permission_required = "passbook_crypto.delete_certificatekeypair"
 | 
						|
 | 
						|
    template_name = "generic/delete.html"
 | 
						|
    success_url = reverse_lazy("passbook_admin:certificate_key_pair")
 | 
						|
    success_message = _("Successfully deleted Certificate-Key Pair")
 | 
						|
 | 
						|
    def delete(self, request, *args, **kwargs):
 | 
						|
        messages.success(self.request, self.success_message)
 | 
						|
        return super().delete(request, *args, **kwargs)
 |