jumpserver/apps/perms/views/asset_permission.py

175 lines
5.9 KiB
Python
Raw Normal View History

2016-09-10 13:08:10 +00:00
# ~*~ coding: utf-8 ~*~
2016-08-08 16:43:11 +00:00
2016-09-10 13:08:10 +00:00
from __future__ import unicode_literals, absolute_import
2017-03-09 06:55:33 +00:00
2016-09-11 01:50:42 +00:00
from django.utils.translation import ugettext as _
2018-07-27 08:21:55 +00:00
from django.views.generic import ListView, CreateView, UpdateView, DetailView, TemplateView
from django.views.generic.edit import DeleteView, SingleObjectMixin
2016-09-11 01:50:42 +00:00
from django.urls import reverse_lazy
2018-04-07 16:16:37 +00:00
from django.conf import settings
2016-09-10 13:08:10 +00:00
from common.permissions import PermissionsMixin, IsOrgAdmin
from orgs.utils import current_org
2019-07-02 08:45:26 +00:00
from perms.hands import Node, Asset, SystemUser, UserGroup
from perms.models import AssetPermission
from perms.forms import AssetPermissionForm
__all__ = [
'AssetPermissionListView', 'AssetPermissionCreateView',
'AssetPermissionUpdateView', 'AssetPermissionDetailView',
'AssetPermissionDeleteView', 'AssetPermissionUserView',
'AssetPermissionAssetView',
]
2016-09-10 13:08:10 +00:00
class AssetPermissionListView(PermissionsMixin, TemplateView):
2016-09-11 14:45:24 +00:00
template_name = 'perms/asset_permission_list.html'
permission_classes = [IsOrgAdmin]
2018-04-07 16:16:37 +00:00
2016-09-10 13:08:10 +00:00
def get_context_data(self, **kwargs):
context = {
2016-09-11 01:50:42 +00:00
'app': _('Perms'),
2016-09-11 14:45:24 +00:00
'action': _('Asset permission list'),
2016-09-10 13:08:10 +00:00
}
kwargs.update(context)
return super().get_context_data(**kwargs)
class AssetPermissionCreateView(PermissionsMixin, CreateView):
2018-04-07 16:16:37 +00:00
model = AssetPermission
2016-09-11 14:45:24 +00:00
form_class = AssetPermissionForm
2016-09-11 15:20:14 +00:00
template_name = 'perms/asset_permission_create_update.html'
2016-09-11 14:45:24 +00:00
success_url = reverse_lazy('perms:asset-permission-list')
permission_classes = [IsOrgAdmin]
2017-03-09 06:55:33 +00:00
2018-04-10 12:29:06 +00:00
def get_form(self, form_class=None):
form = super().get_form(form_class=form_class)
2018-04-10 12:45:01 +00:00
nodes_id = self.request.GET.get("nodes")
assets_id = self.request.GET.get("assets")
2018-04-10 12:29:06 +00:00
if nodes_id:
2018-04-10 12:45:01 +00:00
nodes_id = nodes_id.split(",")
nodes = Node.objects.filter(id__in=nodes_id)\
.exclude(id=Node.org_root().id)
2019-09-12 09:58:52 +00:00
form.set_nodes_initial(nodes)
2018-04-10 12:29:06 +00:00
if assets_id:
2018-04-10 12:45:01 +00:00
assets_id = assets_id.split(",")
2018-04-10 12:29:06 +00:00
assets = Asset.objects.filter(id__in=assets_id)
2019-09-12 09:58:52 +00:00
form.set_assets_initial(assets)
2018-04-10 12:29:06 +00:00
return form
2016-09-11 08:59:19 +00:00
def get_context_data(self, **kwargs):
context = {
'app': _('Perms'),
2016-09-11 14:45:24 +00:00
'action': _('Create asset permission'),
2019-06-30 12:10:34 +00:00
'api_action': "create",
2016-09-11 08:59:19 +00:00
}
kwargs.update(context)
return super().get_context_data(**kwargs)
2016-09-11 15:20:14 +00:00
class AssetPermissionUpdateView(PermissionsMixin, UpdateView):
2018-04-07 16:16:37 +00:00
model = AssetPermission
2016-09-11 15:20:14 +00:00
form_class = AssetPermissionForm
template_name = 'perms/asset_permission_create_update.html'
2017-05-15 15:39:54 +00:00
success_url = reverse_lazy("perms:asset-permission-list")
permission_classes = [IsOrgAdmin]
2016-09-11 15:20:14 +00:00
def get_context_data(self, **kwargs):
context = {
'app': _('Perms'),
2019-06-30 12:10:34 +00:00
'action': _('Update asset permission'),
'api_action': "update",
2016-09-11 15:20:14 +00:00
}
kwargs.update(context)
return super().get_context_data(**kwargs)
2016-09-11 15:20:14 +00:00
class AssetPermissionDetailView(PermissionsMixin, DetailView):
2018-04-10 12:29:06 +00:00
model = AssetPermission
form_class = AssetPermissionForm
template_name = 'perms/asset_permission_detail.html'
success_url = reverse_lazy("perms:asset-permission-list")
permission_classes = [IsOrgAdmin]
2018-04-10 12:29:06 +00:00
def get_context_data(self, **kwargs):
context = {
'app': _('Perms'),
'action': _('Asset permission detail'),
'system_users_remain': SystemUser.objects.exclude(
granted_by_permissions=self.object
),
2018-04-10 12:29:06 +00:00
}
kwargs.update(context)
return super().get_context_data(**kwargs)
class AssetPermissionDeleteView(PermissionsMixin, DeleteView):
2016-09-11 15:20:14 +00:00
model = AssetPermission
template_name = 'delete_confirm.html'
2016-09-11 15:20:14 +00:00
success_url = reverse_lazy('perms:asset-permission-list')
permission_classes = [IsOrgAdmin]
class AssetPermissionUserView(PermissionsMixin,
SingleObjectMixin,
ListView):
template_name = 'perms/asset_permission_user.html'
context_object_name = 'asset_permission'
paginate_by = settings.DISPLAY_PER_PAGE
object = None
permission_classes = [IsOrgAdmin]
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 = list(self.object.get_all_users())
return queryset
def get_context_data(self, **kwargs):
超级管理员可创建超级审计员并可设置审计员为组织审计员 (#3141) * [Update] 超级管理员可创建超级审计员并可设置审计员为组织审计员 * [Update] 修改小问题 * [Update] 修改普通用户角色可以是组织审计员 * [Update] 更改组织审计员切换组织问题 * [Update] 修改小问题 * [Update] 普通用户是组织审计员的页面左侧栏显示 * [Update] 修改删除权限问题和组织显示问题 * [Update] 优化逻辑 * [Update] 优化类名 * [Update] 修改小问题 * [Update] 优化逻辑 * [Update] 优化切换到某一个组织逻辑 * [Update] 修改用户详情页的 删除/更新 按钮是否可点击 * [Update] 优化代码 * [Update] 组织管理列表增加审计员显示 * [Update] 优化代码细节 * [Update] 优化权限类逻辑 * [Update] 优化导航菜单控制 * [Update] 优化页面控制逻辑 * [Update] 修改变量名错误问题 * [Update] 修改页面上的小问题 * [Update] 审计员或组织审计员能够更新个人部分信息 * [Update] 用户名为admin的用户不能被删除 * [Update] 不同用户在不同组织下扮演不同角色的权限不同,为了避免切换组织时出现403,重定向到index * [Update] 一个用户在同一个组织既是管理员又是审计员,隐藏个人信息模块,仅当是审计员,在当前组织显示个人信息模块 * [Update] 修改方法命名 * [Update] 优化代码细节 * [Update] 修改命令执行列表方法 * [Update] 优化用户之间操作的权限逻辑;添加 UserModel 的 property 属性;修改 Organization 的 related name 名称; * [Update] 修改OrgProcessor Anonymous问题 * [Update] 修改用户序列类校验组织和转换raw密码的逻辑
2019-09-12 10:56:26 +00:00
user_remain = current_org.get_org_members(exclude=('Auditor',)).exclude(
assetpermission=self.object)
user_groups_remain = UserGroup.objects.exclude(
assetpermission=self.object)
context = {
'app': _('Perms'),
'action': _('Asset permission user list'),
超级管理员可创建超级审计员并可设置审计员为组织审计员 (#3141) * [Update] 超级管理员可创建超级审计员并可设置审计员为组织审计员 * [Update] 修改小问题 * [Update] 修改普通用户角色可以是组织审计员 * [Update] 更改组织审计员切换组织问题 * [Update] 修改小问题 * [Update] 普通用户是组织审计员的页面左侧栏显示 * [Update] 修改删除权限问题和组织显示问题 * [Update] 优化逻辑 * [Update] 优化类名 * [Update] 修改小问题 * [Update] 优化逻辑 * [Update] 优化切换到某一个组织逻辑 * [Update] 修改用户详情页的 删除/更新 按钮是否可点击 * [Update] 优化代码 * [Update] 组织管理列表增加审计员显示 * [Update] 优化代码细节 * [Update] 优化权限类逻辑 * [Update] 优化导航菜单控制 * [Update] 优化页面控制逻辑 * [Update] 修改变量名错误问题 * [Update] 修改页面上的小问题 * [Update] 审计员或组织审计员能够更新个人部分信息 * [Update] 用户名为admin的用户不能被删除 * [Update] 不同用户在不同组织下扮演不同角色的权限不同,为了避免切换组织时出现403,重定向到index * [Update] 一个用户在同一个组织既是管理员又是审计员,隐藏个人信息模块,仅当是审计员,在当前组织显示个人信息模块 * [Update] 修改方法命名 * [Update] 优化代码细节 * [Update] 修改命令执行列表方法 * [Update] 优化用户之间操作的权限逻辑;添加 UserModel 的 property 属性;修改 Organization 的 related name 名称; * [Update] 修改OrgProcessor Anonymous问题 * [Update] 修改用户序列类校验组织和转换raw密码的逻辑
2019-09-12 10:56:26 +00:00
'users_remain': user_remain,
'user_groups_remain': user_groups_remain,
}
kwargs.update(context)
return super().get_context_data(**kwargs)
class AssetPermissionAssetView(PermissionsMixin,
SingleObjectMixin,
ListView):
template_name = 'perms/asset_permission_asset.html'
context_object_name = 'asset_permission'
paginate_by = settings.DISPLAY_PER_PAGE
object = None
permission_classes = [IsOrgAdmin]
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 = list(self.object.get_all_assets())
return queryset
def get_context_data(self, **kwargs):
2019-07-18 05:01:07 +00:00
nodes_remain = Node.objects.exclude(
id__in=self.object.nodes.all().values_list('id', flat=True)
).only('key')
context = {
'app': _('Perms'),
'action': _('Asset permission asset list'),
'nodes_remain': nodes_remain,
}
kwargs.update(context)
return super().get_context_data(**kwargs)