У меня есть модель и сериализатор, в этой модели есть ArrayField (postgres).
Теперь я хотел создать поле сериализатора, которое получит список [1,2]
и сохранить его в объекте, но для списка и деталей в сериализаторе для отображения списка объектов JSON.
Модель:
class User(models.Model):
email = models.EmailField('Email', unique=True, blank=False)
full_name = models.CharField(
'Full name', max_length=150, blank=True, null=True)
roles = ArrayField(
models.PositiveSmallIntegerField(),
default=list,
blank=True
)
Serializer:
class ArraySerializerField(ListField):
def __init__(self, queryset, serializer_class):
super(ArraySerializerField, self).__init__()
self.queryset = queryset
self.serializer_class = serializer_class
def to_representation(self, value):
if value:
qs = self.queryset.filter(pk__in=value)
return self.serializer_class(qs, many=True).data
return []
def to_internal_value(self, value):
super(ArraySerializerField, self).to_internal_value(value)
print(value) # [1, 2]
return value
class UserSerializer(SerializerExtensionsMixin, serializers.ModelSerializer):
roles = ArraySerializerField(queryset=Role.objects.all(), serializer_class=RoleSerializer)
class Meta:
model = User
fields = ('id', 'email', 'full_name', 'roles')
def create(self, validated_data):
print(validated_data)
# {'email': 'test@test.com', 'full_name': 'Test', 'roles': []}
user = super(UserSerializer, self).create(validated_data)
return user
Теперь, когда я делаю список или подробный запрос, все в порядке, я получаю список ролей как JSON.
Но когда я пытаюсь отправить данные POST и отправить с этими данными:
{
"email": "test@test.com",
"full_name": "Test",
"roles": [1, 2]
}
validated_data
в методе create
показывает роли всегда как []
, а объект сохраняется без ролей, но печать из to_internal_value
показывает [1, 2]
.
Что я делаю не так? Это должно сохранить отправленные данные, потому что to_internal_value
работает нормально.
EDIT:
Ответ GET and LIST дает мне правильный формат:
{
"id": 1,
"email": "test@test.com",
"full_name": "Test",
"roles": [
{
"id": 1,
"name": "Role 1"
},
{
"id": 2,
"name": "Role 2"
}
]
}