jumpserver/apps/common/serializers/common.py

113 lines
3.4 KiB
Python
Raw Normal View History

import logging
from django.utils.functional import cached_property
from django.utils.translation import gettext_lazy as _
from drf_writable_nested.serializers import WritableNestedModelSerializer as NestedModelSerializer
from rest_framework import serializers
from rest_framework.serializers import ModelSerializer
from rest_framework.serializers import Serializer
from rest_framework_bulk.serializers import BulkListSerializer
2022-04-28 14:54:18 +00:00
from .mixin import BulkListSerializerMixin, BulkSerializerMixin
__all__ = [
2022-08-08 06:34:57 +00:00
'MethodSerializer', 'EmptySerializer', 'BulkModelSerializer',
2022-10-24 12:14:18 +00:00
'AdaptedBulkListSerializer', 'CeleryTaskExecutionSerializer',
2022-11-03 08:55:38 +00:00
'WritableNestedModelSerializer', 'GroupedChoiceSerializer',
'FileSerializer', 'DictSerializer'
]
class MethodSerializer(serializers.Serializer):
def __init__(self, method_name=None, **kwargs):
self.method_name = method_name
super().__init__(**kwargs)
class Meta:
# 生成swagger时使用
ref_name = None
def bind(self, field_name, parent):
if self.method_name is None:
method_name = 'get_{field_name}_serializer'.format(field_name=field_name)
self.method_name = method_name
super().bind(field_name, parent)
@cached_property
def serializer(self) -> serializers.Serializer:
method = getattr(self.parent, self.method_name)
try:
_serializer = method()
except Exception as e:
logging.error(e, exc_info=True)
raise e
# 设置serializer的parent值否则在serializer实例中获取parent会出现断层
setattr(_serializer, 'parent', self.parent)
return _serializer
@cached_property
def fields(self):
"""
重写此方法因为在 BindingDict 中要设置每一个 field parent `serializer`,
这样在调用 field.parent , 才会达到预期的结果
比如: serializers.SerializerMethodField
"""
return self.serializer.fields
def run_validation(self, data=serializers.empty):
return self.serializer.run_validation(data)
def to_representation(self, instance):
return self.serializer.to_representation(instance)
def get_initial(self):
return self.serializer.get_initial()
2020-07-06 03:14:20 +00:00
class EmptySerializer(Serializer):
pass
class BulkModelSerializer(BulkSerializerMixin, ModelSerializer):
pass
class AdaptedBulkListSerializer(BulkListSerializerMixin, BulkListSerializer):
pass
2022-10-24 12:14:18 +00:00
class CeleryTaskExecutionSerializer(serializers.Serializer):
task = serializers.CharField(read_only=True)
2022-04-28 14:54:18 +00:00
class ChoiceSerializer(serializers.Serializer):
2022-09-20 08:18:23 +00:00
label = serializers.CharField(label=_("Label"))
2022-04-28 14:54:18 +00:00
value = serializers.CharField(label=_("Value"))
2022-09-13 02:41:49 +00:00
class GroupedChoiceSerializer(ChoiceSerializer):
2022-04-28 14:54:18 +00:00
children = ChoiceSerializer(many=True, label=_("Children"))
2022-07-17 06:28:55 +00:00
2022-10-19 02:21:05 +00:00
class WritableNestedModelSerializer(NestedModelSerializer):
2022-08-09 08:53:43 +00:00
pass
2022-11-03 08:55:38 +00:00
class FileSerializer(serializers.Serializer):
file = serializers.FileField(label=_("File"))
2023-04-20 07:23:00 +00:00
class DictSerializer(serializers.Serializer):
def to_representation(self, instance):
# 返回一个包含所有提交字段的 Python 字典
return instance
def to_internal_value(self, data):
# 确保从请求中得到的输入是 Python 字典
if isinstance(data, dict):
return data
else:
raise serializers.ValidationError("无法转换为dict类型")