64 lines
2.3 KiB
Python
64 lines
2.3 KiB
Python
|
|
from rest_framework import serializers
|
|
from .models import CustomUser
|
|
from django.contrib.auth.models import Group
|
|
from api.customs.models import Importador
|
|
|
|
class CustomUserSerializer(serializers.ModelSerializer):
|
|
"""
|
|
Serializer for the CustomUser model.
|
|
"""
|
|
|
|
password = serializers.CharField(write_only=True, required=False)
|
|
groups = serializers.PrimaryKeyRelatedField(queryset=Group.objects.all(), many=True, required=False)
|
|
rfc = serializers.PrimaryKeyRelatedField(
|
|
queryset=Importador.objects.all(),
|
|
many=True,
|
|
required=False,
|
|
pk_field=serializers.CharField(),
|
|
)
|
|
|
|
class Meta:
|
|
model = CustomUser
|
|
fields = ['id', 'username', 'email', 'first_name', 'last_name', 'password', 'profile_picture', 'organizacion', 'is_importador', 'rfc', 'is_active', 'is_superuser', 'groups']
|
|
read_only_fields = ['id', 'organizacion', 'is_superuser']
|
|
|
|
def validate_password(self, value):
|
|
if not value or not value.strip():
|
|
raise serializers.ValidationError("La contraseña no puede estar vacía o contener solo espacios.")
|
|
return value
|
|
|
|
def validate(self, attrs):
|
|
# En create, la contraseña es obligatoria
|
|
if self.instance is None and not attrs.get('password'):
|
|
raise serializers.ValidationError({"password": "Este campo es requerido."})
|
|
return attrs
|
|
|
|
def create(self, validated_data):
|
|
groups = validated_data.pop('groups', [])
|
|
rfcs = validated_data.pop('rfc', [])
|
|
password = validated_data.pop('password')
|
|
user = CustomUser(**validated_data)
|
|
user.set_password(password)
|
|
user.save()
|
|
if groups:
|
|
user.groups.set(groups)
|
|
if rfcs:
|
|
user.rfc.set(rfcs)
|
|
return user
|
|
|
|
def update(self, instance, validated_data):
|
|
groups = validated_data.pop('groups', None)
|
|
rfcs = validated_data.pop('rfc', None)
|
|
password = validated_data.pop('password', None)
|
|
for attr, value in validated_data.items():
|
|
setattr(instance, attr, value)
|
|
if password:
|
|
instance.set_password(password)
|
|
instance.save()
|
|
if groups is not None:
|
|
instance.groups.set(groups)
|
|
if rfcs is not None:
|
|
instance.rfc.set(rfcs)
|
|
return instance
|