2022-07-11 10:09:06 +00:00
|
|
|
from rest_framework import serializers
|
|
|
|
|
|
|
|
from django.utils.translation import ugettext_lazy as _
|
|
|
|
from orgs.mixins.serializers import OrgResourceModelSerializerMixin
|
|
|
|
from authentication.models import ConnectionToken
|
|
|
|
from common.utils import pretty_string
|
|
|
|
from common.utils.random import random_string
|
2022-10-28 07:58:05 +00:00
|
|
|
from assets.models import Asset, Gateway, Domain, CommandFilterRule, Account
|
2022-07-11 10:09:06 +00:00
|
|
|
from users.models import User
|
2022-09-07 09:35:23 +00:00
|
|
|
from perms.serializers.permission import ActionsField
|
2022-07-11 10:09:06 +00:00
|
|
|
|
|
|
|
|
|
|
|
__all__ = [
|
|
|
|
'ConnectionTokenSerializer', 'ConnectionTokenSecretSerializer',
|
2022-07-11 11:34:08 +00:00
|
|
|
'SuperConnectionTokenSerializer', 'ConnectionTokenDisplaySerializer'
|
2022-07-11 10:09:06 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
class ConnectionTokenSerializer(OrgResourceModelSerializerMixin):
|
2022-07-12 10:27:07 +00:00
|
|
|
is_valid = serializers.BooleanField(read_only=True, label=_('Validity'))
|
|
|
|
expire_time = serializers.IntegerField(read_only=True, label=_('Expired time'))
|
2022-07-11 10:09:06 +00:00
|
|
|
|
|
|
|
class Meta:
|
|
|
|
model = ConnectionToken
|
2022-10-26 09:56:37 +00:00
|
|
|
fields_mini = ['id']
|
2022-07-11 10:09:06 +00:00
|
|
|
fields_small = fields_mini + [
|
2022-10-28 07:58:05 +00:00
|
|
|
'secret', 'account_username', 'date_expired',
|
|
|
|
'date_created', 'date_updated',
|
2022-07-20 05:13:40 +00:00
|
|
|
'created_by', 'updated_by', 'org_id', 'org_name',
|
2022-07-11 10:09:06 +00:00
|
|
|
]
|
|
|
|
fields_fk = [
|
2022-10-28 07:58:05 +00:00
|
|
|
'user', 'asset',
|
2022-07-11 10:09:06 +00:00
|
|
|
]
|
|
|
|
read_only_fields = [
|
|
|
|
# 普通 Token 不支持指定 user
|
2022-07-12 10:27:07 +00:00
|
|
|
'user', 'is_valid', 'expire_time',
|
2022-10-28 07:58:05 +00:00
|
|
|
'user_display', 'asset_display',
|
2022-07-11 10:09:06 +00:00
|
|
|
]
|
|
|
|
fields = fields_small + fields_fk + read_only_fields
|
|
|
|
|
2022-10-28 07:58:05 +00:00
|
|
|
def get_request_user(self):
|
|
|
|
request = self.context.get('request')
|
|
|
|
user = request.user if request else None
|
|
|
|
return user
|
|
|
|
|
|
|
|
def get_user(self, attrs):
|
|
|
|
return self.get_request_user()
|
|
|
|
|
2022-07-11 10:09:06 +00:00
|
|
|
def validate(self, attrs):
|
|
|
|
fields_attrs = self.construct_internal_fields_attrs(attrs)
|
|
|
|
attrs.update(fields_attrs)
|
|
|
|
return attrs
|
|
|
|
|
|
|
|
def construct_internal_fields_attrs(self, attrs):
|
|
|
|
asset = attrs.get('asset') or ''
|
2022-10-27 12:01:50 +00:00
|
|
|
asset_display = pretty_string(str(asset), max_length=128)
|
|
|
|
user = self.get_user(attrs)
|
|
|
|
user_display = pretty_string(str(user), max_length=128)
|
2022-07-14 09:41:14 +00:00
|
|
|
secret = attrs.get('secret') or random_string(16)
|
2022-07-11 10:09:06 +00:00
|
|
|
date_expired = attrs.get('date_expired') or ConnectionToken.get_default_date_expired()
|
2022-10-27 12:01:50 +00:00
|
|
|
org_id = asset.org_id
|
|
|
|
if not isinstance(asset, Asset):
|
|
|
|
error = ''
|
|
|
|
raise serializers.ValidationError(error)
|
2022-10-28 07:58:05 +00:00
|
|
|
attrs = {
|
2022-07-11 10:09:06 +00:00
|
|
|
'user': user,
|
|
|
|
'secret': secret,
|
2022-10-27 12:01:50 +00:00
|
|
|
'user_display': user_display,
|
|
|
|
'asset_display': asset_display,
|
2022-07-11 10:09:06 +00:00
|
|
|
'date_expired': date_expired,
|
|
|
|
'org_id': org_id,
|
|
|
|
}
|
2022-10-28 07:58:05 +00:00
|
|
|
return attrs
|
2022-07-11 10:09:06 +00:00
|
|
|
|
|
|
|
|
2022-07-11 11:34:08 +00:00
|
|
|
class ConnectionTokenDisplaySerializer(ConnectionTokenSerializer):
|
|
|
|
class Meta(ConnectionTokenSerializer.Meta):
|
|
|
|
extra_kwargs = {
|
|
|
|
'secret': {'write_only': True},
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-07-11 10:09:06 +00:00
|
|
|
#
|
|
|
|
# SuperConnectionTokenSerializer
|
|
|
|
#
|
|
|
|
|
|
|
|
|
|
|
|
class SuperConnectionTokenSerializer(ConnectionTokenSerializer):
|
|
|
|
|
|
|
|
class Meta(ConnectionTokenSerializer.Meta):
|
|
|
|
read_only_fields = [
|
2022-07-20 05:13:40 +00:00
|
|
|
'validity', 'user_display', 'system_user_display',
|
|
|
|
'asset_display', 'application_display',
|
2022-07-11 10:09:06 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
def get_user(self, attrs):
|
2022-10-28 07:58:05 +00:00
|
|
|
return attrs.get('user') or self.get_request_user()
|
2022-07-11 10:09:06 +00:00
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Connection Token Secret
|
|
|
|
#
|
|
|
|
|
|
|
|
|
|
|
|
class ConnectionTokenUserSerializer(serializers.ModelSerializer):
|
2022-10-28 07:58:05 +00:00
|
|
|
""" User """
|
2022-07-11 10:09:06 +00:00
|
|
|
class Meta:
|
|
|
|
model = User
|
|
|
|
fields = ['id', 'name', 'username', 'email']
|
|
|
|
|
|
|
|
|
|
|
|
class ConnectionTokenAssetSerializer(serializers.ModelSerializer):
|
2022-10-28 07:58:05 +00:00
|
|
|
""" Asset """
|
2022-07-11 10:09:06 +00:00
|
|
|
class Meta:
|
|
|
|
model = Asset
|
2022-10-31 11:27:45 +00:00
|
|
|
fields = ['id', 'name', 'address', 'protocols', 'org_id']
|
2022-07-11 10:09:06 +00:00
|
|
|
|
|
|
|
|
2022-10-28 07:58:05 +00:00
|
|
|
class ConnectionTokenAccountSerializer(serializers.ModelSerializer):
|
|
|
|
""" Account """
|
|
|
|
class Meta:
|
|
|
|
model = Account
|
|
|
|
fields = [
|
|
|
|
'id', 'name', 'username', 'secret_type', 'secret', 'version'
|
|
|
|
]
|
|
|
|
|
|
|
|
|
2022-07-11 10:09:06 +00:00
|
|
|
class ConnectionTokenGatewaySerializer(serializers.ModelSerializer):
|
2022-10-28 07:58:05 +00:00
|
|
|
""" Gateway """
|
2022-07-11 10:09:06 +00:00
|
|
|
class Meta:
|
|
|
|
model = Gateway
|
|
|
|
fields = ['id', 'ip', 'port', 'username', 'password', 'private_key']
|
|
|
|
|
|
|
|
|
|
|
|
class ConnectionTokenDomainSerializer(serializers.ModelSerializer):
|
2022-10-28 07:58:05 +00:00
|
|
|
""" Domain """
|
2022-07-11 10:09:06 +00:00
|
|
|
gateways = ConnectionTokenGatewaySerializer(many=True, read_only=True)
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
model = Domain
|
|
|
|
fields = ['id', 'name', 'gateways']
|
|
|
|
|
|
|
|
|
|
|
|
class ConnectionTokenCmdFilterRuleSerializer(serializers.ModelSerializer):
|
2022-10-28 07:58:05 +00:00
|
|
|
""" Command filter rule """
|
2022-07-11 10:09:06 +00:00
|
|
|
class Meta:
|
|
|
|
model = CommandFilterRule
|
|
|
|
fields = [
|
|
|
|
'id', 'type', 'content', 'ignore_case', 'pattern',
|
|
|
|
'priority', 'action', 'date_created',
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
class ConnectionTokenSecretSerializer(OrgResourceModelSerializerMixin):
|
|
|
|
user = ConnectionTokenUserSerializer(read_only=True)
|
|
|
|
asset = ConnectionTokenAssetSerializer(read_only=True)
|
2022-10-28 07:58:05 +00:00
|
|
|
account = ConnectionTokenAccountSerializer(read_only=True)
|
2022-07-11 10:09:06 +00:00
|
|
|
gateway = ConnectionTokenGatewaySerializer(read_only=True)
|
|
|
|
domain = ConnectionTokenDomainSerializer(read_only=True)
|
|
|
|
cmd_filter_rules = ConnectionTokenCmdFilterRuleSerializer(many=True)
|
|
|
|
actions = ActionsField()
|
2022-11-08 06:30:07 +00:00
|
|
|
expire_at = serializers.IntegerField()
|
2022-07-11 10:09:06 +00:00
|
|
|
|
|
|
|
class Meta:
|
|
|
|
model = ConnectionToken
|
|
|
|
fields = [
|
2022-10-28 07:58:05 +00:00
|
|
|
'id', 'secret',
|
|
|
|
'user', 'asset', 'account_username', 'account', 'protocol',
|
|
|
|
'domain', 'gateway', 'cmd_filter_rules',
|
2022-11-08 06:30:07 +00:00
|
|
|
'actions', 'expire_at',
|
2022-07-11 10:09:06 +00:00
|
|
|
]
|