2019-07-01 11:30:18 +00:00
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
#
|
|
|
|
|
|
|
|
|
|
from rest_framework import serializers
|
2019-07-11 10:12:14 +00:00
|
|
|
|
from django.utils.translation import ugettext_lazy as _
|
2019-07-01 11:30:18 +00:00
|
|
|
|
|
2019-07-11 10:12:14 +00:00
|
|
|
|
from assets.models import Node, SystemUser, Asset
|
|
|
|
|
from assets.serializers import ProtocolsField
|
2019-07-02 09:51:50 +00:00
|
|
|
|
from .asset_permission import ActionsField
|
2019-07-01 11:30:18 +00:00
|
|
|
|
|
|
|
|
|
__all__ = [
|
2019-07-11 10:12:14 +00:00
|
|
|
|
'GrantedNodeSerializer',
|
2019-07-01 11:30:18 +00:00
|
|
|
|
'NodeGrantedSerializer', 'AssetGrantedSerializer',
|
2019-07-11 10:12:14 +00:00
|
|
|
|
'ActionsSerializer', 'AssetSystemUserSerializer',
|
2019-07-01 11:30:18 +00:00
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class AssetSystemUserSerializer(serializers.ModelSerializer):
|
|
|
|
|
"""
|
|
|
|
|
查看授权的资产系统用户的数据结构,这个和AssetSerializer不同,字段少
|
|
|
|
|
"""
|
2019-07-02 09:51:50 +00:00
|
|
|
|
actions = ActionsField(read_only=True)
|
2019-07-01 11:30:18 +00:00
|
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
model = SystemUser
|
2019-07-11 10:12:14 +00:00
|
|
|
|
only_fields = (
|
|
|
|
|
'id', 'name', 'username', 'priority',
|
2019-07-01 11:30:18 +00:00
|
|
|
|
'protocol', 'login_mode',
|
|
|
|
|
)
|
2019-07-11 10:12:14 +00:00
|
|
|
|
fields = list(only_fields) + ["actions"]
|
|
|
|
|
read_only_fields = fields
|
2019-07-01 11:30:18 +00:00
|
|
|
|
|
|
|
|
|
|
2019-07-11 10:12:14 +00:00
|
|
|
|
class AssetGrantedSerializer(serializers.ModelSerializer):
|
2019-07-01 11:30:18 +00:00
|
|
|
|
"""
|
|
|
|
|
被授权资产的数据结构
|
|
|
|
|
"""
|
2019-07-11 10:12:14 +00:00
|
|
|
|
protocols = ProtocolsField(label=_('Protocols'), required=False, read_only=True)
|
2019-07-01 11:30:18 +00:00
|
|
|
|
system_users_granted = AssetSystemUserSerializer(many=True, read_only=True)
|
|
|
|
|
system_users_join = serializers.SerializerMethodField()
|
2019-07-11 10:12:14 +00:00
|
|
|
|
system_users_only_fields = AssetSystemUserSerializer.Meta.only_fields
|
2019-07-01 11:30:18 +00:00
|
|
|
|
|
|
|
|
|
class Meta:
|
2019-07-11 10:12:14 +00:00
|
|
|
|
model = Asset
|
|
|
|
|
only_fields = [
|
|
|
|
|
"id", "hostname", "ip", "protocols", "os", 'domain',
|
|
|
|
|
"platform", "org_id",
|
2019-07-01 11:30:18 +00:00
|
|
|
|
]
|
2019-07-11 10:12:14 +00:00
|
|
|
|
fields = only_fields + ['system_users_granted', 'system_users_join', "org_name"]
|
|
|
|
|
read_only_fields = fields
|
2019-07-01 11:30:18 +00:00
|
|
|
|
|
|
|
|
|
@staticmethod
|
2019-07-11 10:12:14 +00:00
|
|
|
|
def get_system_users_join(obj):
|
|
|
|
|
system_users = [s.username for s in obj.system_users_granted]
|
|
|
|
|
return ', '.join(system_users)
|
2019-07-01 11:30:18 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class NodeGrantedSerializer(serializers.ModelSerializer):
|
|
|
|
|
"""
|
|
|
|
|
授权资产组
|
|
|
|
|
"""
|
|
|
|
|
assets_granted = AssetGrantedSerializer(many=True, read_only=True)
|
2019-07-11 10:12:14 +00:00
|
|
|
|
assets_amount = serializers.ReadOnlyField()
|
|
|
|
|
name = serializers.ReadOnlyField(source='value')
|
|
|
|
|
|
|
|
|
|
assets_only_fields = AssetGrantedSerializer.Meta.only_fields
|
|
|
|
|
system_users_only_fields = AssetGrantedSerializer.system_users_only_fields
|
2019-07-01 11:30:18 +00:00
|
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
model = Node
|
2019-07-11 10:12:14 +00:00
|
|
|
|
only_fields = ['id', 'key', 'value', "org_id"]
|
|
|
|
|
fields = only_fields + [
|
|
|
|
|
'name', 'assets_granted', 'assets_amount',
|
2019-07-01 11:30:18 +00:00
|
|
|
|
]
|
2019-07-11 10:12:14 +00:00
|
|
|
|
read_only_fields = fields
|
2019-07-01 11:30:18 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class GrantedNodeSerializer(serializers.ModelSerializer):
|
|
|
|
|
class Meta:
|
|
|
|
|
model = Node
|
|
|
|
|
fields = [
|
|
|
|
|
'id', 'name', 'key', 'value',
|
2019-07-02 02:51:48 +00:00
|
|
|
|
]
|
2019-07-11 10:12:14 +00:00
|
|
|
|
read_only_fields = fields
|
2019-07-02 02:51:48 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class ActionsSerializer(serializers.Serializer):
|
2019-07-02 09:51:50 +00:00
|
|
|
|
actions = ActionsField(read_only=True)
|