2019-03-18 02:15:33 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
#
|
|
|
|
|
|
|
|
from django.utils.translation import ugettext as _
|
|
|
|
from rest_framework import serializers
|
|
|
|
|
2019-06-19 03:31:38 +00:00
|
|
|
from common.serializers import AdaptedBulkListSerializer
|
2019-08-21 12:27:21 +00:00
|
|
|
from orgs.mixins.serializers import BulkOrgResourceModelSerializer
|
2019-06-24 12:16:18 +00:00
|
|
|
from ..models import AuthBook, Asset
|
|
|
|
from ..backends import AssetUserManager
|
2020-03-12 08:24:38 +00:00
|
|
|
|
2019-07-08 07:35:20 +00:00
|
|
|
from .base import ConnectivitySerializer, AuthSerializerMixin
|
2019-06-19 03:31:38 +00:00
|
|
|
|
2019-03-18 02:15:33 +00:00
|
|
|
|
|
|
|
__all__ = [
|
2020-03-12 08:24:38 +00:00
|
|
|
'AssetUserWriteSerializer', 'AssetUserReadSerializer',
|
|
|
|
'AssetUserAuthInfoSerializer', 'AssetUserPushSerializer',
|
2019-03-18 02:15:33 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
|
2020-03-12 08:24:38 +00:00
|
|
|
class AssetUserWriteSerializer(AuthSerializerMixin, BulkOrgResourceModelSerializer):
|
2019-03-18 02:15:33 +00:00
|
|
|
class Meta:
|
|
|
|
model = AuthBook
|
2019-06-19 03:31:38 +00:00
|
|
|
list_serializer_class = AdaptedBulkListSerializer
|
|
|
|
fields = [
|
2020-03-12 08:24:38 +00:00
|
|
|
'id', 'username', 'password', 'private_key', "public_key",
|
|
|
|
'asset', 'comment',
|
2019-06-19 03:31:38 +00:00
|
|
|
]
|
2019-03-18 02:15:33 +00:00
|
|
|
extra_kwargs = {
|
2019-06-19 03:31:38 +00:00
|
|
|
'username': {'required': True},
|
2019-06-25 06:32:25 +00:00
|
|
|
'password': {'write_only': True},
|
|
|
|
'private_key': {'write_only': True},
|
|
|
|
'public_key': {'write_only': True},
|
2019-03-18 02:15:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
def create(self, validated_data):
|
2019-06-25 06:32:25 +00:00
|
|
|
if not validated_data.get("name") and validated_data.get("username"):
|
|
|
|
validated_data["name"] = validated_data["username"]
|
|
|
|
instance = AssetUserManager.create(**validated_data)
|
2019-03-18 02:15:33 +00:00
|
|
|
return instance
|
|
|
|
|
|
|
|
|
2020-03-12 08:24:38 +00:00
|
|
|
class AssetUserReadSerializer(AssetUserWriteSerializer):
|
|
|
|
id = serializers.CharField(read_only=True, source='union_id', label=_("ID"))
|
|
|
|
hostname = serializers.CharField(read_only=True, label=_("Hostname"))
|
|
|
|
ip = serializers.CharField(read_only=True, label=_("IP"))
|
|
|
|
asset = serializers.CharField(source='asset_id', label=_('Asset'))
|
|
|
|
backend = serializers.CharField(read_only=True, label=_("Backend"))
|
|
|
|
|
|
|
|
class Meta(AssetUserWriteSerializer.Meta):
|
|
|
|
read_only_fields = (
|
|
|
|
'date_created', 'date_updated',
|
|
|
|
'created_by', 'version',
|
|
|
|
)
|
|
|
|
fields = [
|
|
|
|
'id', 'username', 'password', 'private_key', "public_key",
|
|
|
|
'asset', 'hostname', 'ip', 'backend', 'version',
|
|
|
|
'date_created', "date_updated", 'comment',
|
|
|
|
]
|
|
|
|
extra_kwargs = {
|
|
|
|
'username': {'required': True},
|
|
|
|
'password': {'write_only': True},
|
|
|
|
'private_key': {'write_only': True},
|
|
|
|
'public_key': {'write_only': True},
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
class AssetUserAuthInfoSerializer(AssetUserReadSerializer):
|
2019-06-19 03:31:38 +00:00
|
|
|
password = serializers.CharField(
|
|
|
|
max_length=256, allow_blank=True, allow_null=True,
|
|
|
|
required=False, label=_('Password')
|
|
|
|
)
|
|
|
|
public_key = serializers.CharField(
|
|
|
|
max_length=4096, allow_blank=True, allow_null=True,
|
|
|
|
required=False, label=_('Public key')
|
|
|
|
)
|
|
|
|
private_key = serializers.CharField(
|
|
|
|
max_length=4096, allow_blank=True, allow_null=True,
|
|
|
|
required=False, label=_('Private key')
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
class AssetUserPushSerializer(serializers.Serializer):
|
2019-10-18 07:05:45 +00:00
|
|
|
asset = serializers.PrimaryKeyRelatedField(queryset=Asset.objects, label=_("Asset"))
|
2019-06-19 03:31:38 +00:00
|
|
|
username = serializers.CharField(max_length=1024)
|
|
|
|
|
|
|
|
def create(self, validated_data):
|
|
|
|
pass
|
|
|
|
|
|
|
|
def update(self, instance, validated_data):
|
|
|
|
pass
|