|
|
|
@ -7,7 +7,6 @@ from django.conf import settings
|
|
|
|
|
from django.views.generic import ListView, CreateView, UpdateView
|
|
|
|
|
from django.views.generic.edit import DeleteView
|
|
|
|
|
from django.urls import reverse_lazy
|
|
|
|
|
from django.contrib.messages.views import SuccessMessageMixin
|
|
|
|
|
from django.views.generic.detail import DetailView, SingleObjectMixin
|
|
|
|
|
|
|
|
|
|
from common.utils import get_object_or_none
|
|
|
|
@ -61,6 +60,11 @@ class AssetPermissionUpdateView(AdminUserRequiredMixin, UpdateView):
|
|
|
|
|
template_name = 'perms/asset_permission_create_update.html'
|
|
|
|
|
success_url = reverse_lazy("perms:asset-permission-list")
|
|
|
|
|
|
|
|
|
|
def get_form(self, form_class=None):
|
|
|
|
|
form = super().get_form(form_class=form_class)
|
|
|
|
|
form['node'].initial = form.instance.node
|
|
|
|
|
return form
|
|
|
|
|
|
|
|
|
|
def get_context_data(self, **kwargs):
|
|
|
|
|
context = {
|
|
|
|
|
'app': _('Perms'),
|
|
|
|
@ -70,22 +74,22 @@ class AssetPermissionUpdateView(AdminUserRequiredMixin, UpdateView):
|
|
|
|
|
return super().get_context_data(**kwargs)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class AssetPermissionDetailView(AdminUserRequiredMixin, DetailView):
|
|
|
|
|
template_name = 'perms/asset_permission_detail.html'
|
|
|
|
|
context_object_name = 'asset_permission'
|
|
|
|
|
model = AssetPermission
|
|
|
|
|
|
|
|
|
|
def get_context_data(self, **kwargs):
|
|
|
|
|
context = {
|
|
|
|
|
'app': _('Perms'),
|
|
|
|
|
'action': _('Asset permission detail'),
|
|
|
|
|
'system_users_remain': [
|
|
|
|
|
system_user for system_user in SystemUser.objects.all()
|
|
|
|
|
if system_user not in self.object.system_users.all()],
|
|
|
|
|
'system_users': self.object.system_users.all(),
|
|
|
|
|
}
|
|
|
|
|
kwargs.update(context)
|
|
|
|
|
return super().get_context_data(**kwargs)
|
|
|
|
|
# class AssetPermissionDetailView(AdminUserRequiredMixin, DetailView):
|
|
|
|
|
# template_name = 'perms/asset_permission_detail.html'
|
|
|
|
|
# context_object_name = 'asset_permission'
|
|
|
|
|
# model = AssetPermission
|
|
|
|
|
#
|
|
|
|
|
# def get_context_data(self, **kwargs):
|
|
|
|
|
# context = {
|
|
|
|
|
# 'app': _('Perms'),
|
|
|
|
|
# 'action': _('Asset permission detail'),
|
|
|
|
|
# 'system_users_remain': [
|
|
|
|
|
# system_user for system_user in SystemUser.objects.all()
|
|
|
|
|
# if system_user not in self.object.system_users.all()],
|
|
|
|
|
# 'system_users': self.object.system_users.all(),
|
|
|
|
|
# }
|
|
|
|
|
# kwargs.update(context)
|
|
|
|
|
# return super().get_context_data(**kwargs)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class AssetPermissionDeleteView(AdminUserRequiredMixin, DeleteView):
|
|
|
|
@ -94,61 +98,61 @@ class AssetPermissionDeleteView(AdminUserRequiredMixin, DeleteView):
|
|
|
|
|
success_url = reverse_lazy('perms:asset-permission-list')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class AssetPermissionUserView(AdminUserRequiredMixin,
|
|
|
|
|
SingleObjectMixin,
|
|
|
|
|
ListView):
|
|
|
|
|
template_name = 'perms/asset_permission_user.html'
|
|
|
|
|
context_object_name = 'asset_permission'
|
|
|
|
|
paginate_by = settings.DISPLAY_PER_PAGE
|
|
|
|
|
object = None
|
|
|
|
|
|
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
|
|
|
self.object = self.get_object(queryset=AssetPermission.objects.all())
|
|
|
|
|
return super().get(request, *args, **kwargs)
|
|
|
|
|
|
|
|
|
|
def get_queryset(self):
|
|
|
|
|
queryset = self.object.get_granted_users()
|
|
|
|
|
return queryset
|
|
|
|
|
|
|
|
|
|
def get_context_data(self, **kwargs):
|
|
|
|
|
users_granted = self.get_queryset()
|
|
|
|
|
groups_granted = self.object.user_groups.all()
|
|
|
|
|
context = {
|
|
|
|
|
'app': _('Perms'),
|
|
|
|
|
'action': _('Asset permission user list'),
|
|
|
|
|
'users_remain': User.objects.exclude(id__in=[user.id for user in users_granted]),
|
|
|
|
|
'user_groups': self.object.user_groups.all(),
|
|
|
|
|
'user_groups_remain': UserGroup.objects.exclude(id__in=[group.id for group in groups_granted])
|
|
|
|
|
}
|
|
|
|
|
kwargs.update(context)
|
|
|
|
|
return super().get_context_data(**kwargs)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class AssetPermissionAssetView(AdminUserRequiredMixin,
|
|
|
|
|
SingleObjectMixin,
|
|
|
|
|
ListView):
|
|
|
|
|
template_name = 'perms/asset_permission_asset.html'
|
|
|
|
|
context_object_name = 'asset_permission'
|
|
|
|
|
paginate_by = settings.DISPLAY_PER_PAGE
|
|
|
|
|
object = None
|
|
|
|
|
|
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
|
|
|
self.object = self.get_object(queryset=AssetPermission.objects.all())
|
|
|
|
|
return super().get(request, *args, **kwargs)
|
|
|
|
|
|
|
|
|
|
def get_queryset(self):
|
|
|
|
|
queryset = self.object.get_granted_assets()
|
|
|
|
|
return queryset
|
|
|
|
|
|
|
|
|
|
def get_context_data(self, **kwargs):
|
|
|
|
|
assets_granted = self.get_queryset()
|
|
|
|
|
groups_granted = self.object.asset_groups.all()
|
|
|
|
|
context = {
|
|
|
|
|
'app': _('Perms'),
|
|
|
|
|
'action': _('Asset permission asset list'),
|
|
|
|
|
'assets_remain': Asset.objects.exclude(id__in=[asset.id for asset in assets_granted]),
|
|
|
|
|
'asset_groups': self.object.asset_groups.all(),
|
|
|
|
|
'asset_groups_remain': AssetGroup.objects.exclude(id__in=[group.id for group in groups_granted])
|
|
|
|
|
}
|
|
|
|
|
kwargs.update(context)
|
|
|
|
|
return super().get_context_data(**kwargs)
|
|
|
|
|
# class AssetPermissionUserView(AdminUserRequiredMixin,
|
|
|
|
|
# SingleObjectMixin,
|
|
|
|
|
# ListView):
|
|
|
|
|
# template_name = 'perms/asset_permission_user.html'
|
|
|
|
|
# context_object_name = 'asset_permission'
|
|
|
|
|
# paginate_by = settings.DISPLAY_PER_PAGE
|
|
|
|
|
# object = None
|
|
|
|
|
#
|
|
|
|
|
# def get(self, request, *args, **kwargs):
|
|
|
|
|
# self.object = self.get_object(queryset=AssetPermission.objects.all())
|
|
|
|
|
# return super().get(request, *args, **kwargs)
|
|
|
|
|
#
|
|
|
|
|
# def get_queryset(self):
|
|
|
|
|
# queryset = self.object.get_granted_users()
|
|
|
|
|
# return queryset
|
|
|
|
|
#
|
|
|
|
|
# def get_context_data(self, **kwargs):
|
|
|
|
|
# users_granted = self.get_queryset()
|
|
|
|
|
# groups_granted = self.object.user_groups.all()
|
|
|
|
|
# context = {
|
|
|
|
|
# 'app': _('Perms'),
|
|
|
|
|
# 'action': _('Asset permission user list'),
|
|
|
|
|
# 'users_remain': User.objects.exclude(id__in=[user.id for user in users_granted]),
|
|
|
|
|
# 'user_groups': self.object.user_groups.all(),
|
|
|
|
|
# 'user_groups_remain': UserGroup.objects.exclude(id__in=[group.id for group in groups_granted])
|
|
|
|
|
# }
|
|
|
|
|
# kwargs.update(context)
|
|
|
|
|
# return super().get_context_data(**kwargs)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# class AssetPermissionAssetView(AdminUserRequiredMixin,
|
|
|
|
|
# SingleObjectMixin,
|
|
|
|
|
# ListView):
|
|
|
|
|
# template_name = 'perms/asset_permission_asset.html'
|
|
|
|
|
# context_object_name = 'asset_permission'
|
|
|
|
|
# paginate_by = settings.DISPLAY_PER_PAGE
|
|
|
|
|
# object = None
|
|
|
|
|
#
|
|
|
|
|
# def get(self, request, *args, **kwargs):
|
|
|
|
|
# self.object = self.get_object(queryset=AssetPermission.objects.all())
|
|
|
|
|
# return super().get(request, *args, **kwargs)
|
|
|
|
|
#
|
|
|
|
|
# def get_queryset(self):
|
|
|
|
|
# queryset = self.object.get_granted_assets()
|
|
|
|
|
# return queryset
|
|
|
|
|
#
|
|
|
|
|
# def get_context_data(self, **kwargs):
|
|
|
|
|
# assets_granted = self.get_queryset()
|
|
|
|
|
# groups_granted = self.object.asset_groups.all()
|
|
|
|
|
# context = {
|
|
|
|
|
# 'app': _('Perms'),
|
|
|
|
|
# 'action': _('Asset permission asset list'),
|
|
|
|
|
# 'assets_remain': Asset.objects.exclude(id__in=[asset.id for asset in assets_granted]),
|
|
|
|
|
# 'asset_groups': self.object.asset_groups.all(),
|
|
|
|
|
# 'asset_groups_remain': AssetGroup.objects.exclude(id__in=[group.id for group in groups_granted])
|
|
|
|
|
# }
|
|
|
|
|
# kwargs.update(context)
|
|
|
|
|
# return super().get_context_data(**kwargs)
|
|
|
|
|