mirror of
https://github.com/jumpserver/jumpserver.git
synced 2025-10-22 08:19:04 +00:00
* [Feature] 1. perms actions - 添加 Action Model * [Feature] 2. perms actions - 添加 Action API * [Feature] 3. perms actions - 授权规则: 添加actions字段 * [Feature] 4. perms actions - 授权规则创建页面: 设置 actions 默认 all * [Feature] 5. perms actions - 资产授权工具: 动态给system_user设置actions属性; 修改授权相关的API-serializer类: 添加actions字段值 * [Feature] 6. perms actions - 更新API(用户使用系统用户连接资产时权限校验): 添加actions校验 * [Feature] 7. perms actions - 迁移文件中为已经存在的perms添加默认的action * [Feature] 8. perms actions - 创建授权规则时设置默认action(如果actions字段值为空) * [Feature] 9. check actions - 修改校验用户资产权限API逻辑(添加actions校验) * [Feature] 10. check actions - 修改注释 * [Feature] 11. check actions - 添加API: 获取用户指定资产和系统用户被授权的actions * [Feature] 12. check actions - 添加翻译信息
141 lines
3.8 KiB
Python
141 lines
3.8 KiB
Python
# -*- coding: utf-8 -*-
|
|
#
|
|
|
|
from rest_framework import serializers
|
|
|
|
from common.fields import StringManyToManyField
|
|
from .models import AssetPermission, Action
|
|
from assets.models import Node, Asset, SystemUser
|
|
from assets.serializers import AssetGrantedSerializer
|
|
|
|
__all__ = [
|
|
'AssetPermissionCreateUpdateSerializer', 'AssetPermissionListSerializer',
|
|
'AssetPermissionUpdateUserSerializer', 'AssetPermissionUpdateAssetSerializer',
|
|
'AssetPermissionNodeSerializer', 'GrantedNodeSerializer',
|
|
'GrantedAssetSerializer', 'GrantedSystemUserSerializer',
|
|
'ActionSerializer',
|
|
]
|
|
|
|
|
|
class ActionSerializer(serializers.ModelSerializer):
|
|
class Meta:
|
|
model = Action
|
|
fields = '__all__'
|
|
|
|
|
|
class AssetPermissionCreateUpdateSerializer(serializers.ModelSerializer):
|
|
class Meta:
|
|
model = AssetPermission
|
|
exclude = ('created_by', 'date_created')
|
|
|
|
|
|
class AssetPermissionListSerializer(serializers.ModelSerializer):
|
|
users = StringManyToManyField(many=True, read_only=True)
|
|
user_groups = StringManyToManyField(many=True, read_only=True)
|
|
assets = StringManyToManyField(many=True, read_only=True)
|
|
nodes = StringManyToManyField(many=True, read_only=True)
|
|
system_users = StringManyToManyField(many=True, read_only=True)
|
|
actions = StringManyToManyField(many=True, read_only=True)
|
|
is_valid = serializers.BooleanField()
|
|
is_expired = serializers.BooleanField()
|
|
|
|
class Meta:
|
|
model = AssetPermission
|
|
fields = '__all__'
|
|
|
|
|
|
class AssetPermissionUpdateUserSerializer(serializers.ModelSerializer):
|
|
|
|
class Meta:
|
|
model = AssetPermission
|
|
fields = ['id', 'users']
|
|
|
|
|
|
class AssetPermissionUpdateAssetSerializer(serializers.ModelSerializer):
|
|
|
|
class Meta:
|
|
model = AssetPermission
|
|
fields = ['id', 'assets']
|
|
|
|
|
|
class AssetPermissionNodeSerializer(serializers.ModelSerializer):
|
|
asset = AssetGrantedSerializer(required=False)
|
|
assets_amount = serializers.SerializerMethodField()
|
|
|
|
tree_id = serializers.SerializerMethodField()
|
|
tree_parent = serializers.SerializerMethodField()
|
|
|
|
class Meta:
|
|
model = Node
|
|
fields = [
|
|
'id', 'key', 'value', 'asset', 'is_node', 'org_id',
|
|
'tree_id', 'tree_parent', 'assets_amount',
|
|
]
|
|
|
|
@staticmethod
|
|
def get_assets_amount(obj):
|
|
return obj.assets_amount
|
|
|
|
@staticmethod
|
|
def get_tree_id(obj):
|
|
return obj.key
|
|
|
|
@staticmethod
|
|
def get_tree_parent(obj):
|
|
return obj.parent_key
|
|
|
|
|
|
class NodeGrantedSerializer(serializers.ModelSerializer):
|
|
"""
|
|
授权资产组
|
|
"""
|
|
assets_granted = AssetGrantedSerializer(many=True, read_only=True)
|
|
assets_amount = serializers.SerializerMethodField()
|
|
parent = serializers.SerializerMethodField()
|
|
name = serializers.SerializerMethodField()
|
|
|
|
class Meta:
|
|
model = Node
|
|
fields = [
|
|
'id', 'key', 'name', 'value', 'parent',
|
|
'assets_granted', 'assets_amount', 'org_id',
|
|
]
|
|
|
|
@staticmethod
|
|
def get_assets_amount(obj):
|
|
return len(obj.assets_granted)
|
|
|
|
@staticmethod
|
|
def get_name(obj):
|
|
return obj.name
|
|
|
|
@staticmethod
|
|
def get_parent(obj):
|
|
return obj.parent.id
|
|
|
|
|
|
class GrantedNodeSerializer(serializers.ModelSerializer):
|
|
class Meta:
|
|
model = Node
|
|
fields = [
|
|
'id', 'name', 'key', 'value',
|
|
]
|
|
|
|
|
|
class GrantedAssetSerializer(serializers.ModelSerializer):
|
|
class Meta:
|
|
model = Asset
|
|
fields = [
|
|
'id', 'hostname', 'ip', 'port', 'protocol', 'platform',
|
|
'domain', 'is_active', 'comment'
|
|
]
|
|
|
|
|
|
class GrantedSystemUserSerializer(serializers.ModelSerializer):
|
|
class Meta:
|
|
model = SystemUser
|
|
fields = [
|
|
'id', 'name', 'username', 'protocol', 'priority',
|
|
'login_mode', 'comment'
|
|
]
|