Как добавить пользовательские поля в UserManager в Django
Я пытаюсь создать профиль пользователя, я следовал через учебник, который имеет регистрацию только для имени пользователя, электронной почты и пароля, но я хочу иметь возможность добавить другие пользовательские поля.
Что я сделал:
Models.py:
class UserManager(BaseUserManager):
def create_user(self, username, email, password=None,):
if username is None:
raise TypeError('User should have a userame')
if email is None:
raise TypeError('Users should have a Email')
user = self.model(username=username , email = self.normalize_email(email))
user.set_password(password)
user.save()
return user
def create_superuser(self, username, email, password=None):
if password is None:
raise TypeError('User should have a password')
user=self.create_user(username,email,password)
user.is_superuser = True
user.is_staff = True
user.save()
return user
class User(models.Model):
dso = models.ForeignKey(Dso,related_name='dso',default=NULL,blank=False,on_delete=models.CASCADE)
name = models.CharField(max_length=70, blank=False, default='')
email = models.EmailField(max_length=70, blank=False, default='')
password = models.CharField(max_length=70, blank=False, default='')
address = models.CharField(max_length=70, blank=False, default='')
roleId = models.IntegerField(blank=False, default='1')
isActive = models.BooleanField(blank=False, default=True)
customerId = models.CharField(max_length=70, blank=False, default='')
dateJoined = models.DateTimeField(auto_now_add=False, blank=False, default=NULL)
@property
def energy_data(self):
energydata = EnergyData.objects.filter(customerId=self.customerId).first()
return energydata
Serializers.py:
class RegisterSerializer(serializers.ModelSerializer):
password = serializers.CharField(max_length = 68, min_length=6, write_only = True)
class Meta:
model=User
fields=['email','username','password','name','address','customerId',
'dso', 'roleId']
def validate(self, attrs):
email = attrs.get('email', '')
username = attrs.get('username', '')
if not len(username) >= 4:
raise serializers.ValidationError('Username must be morethan 4 letters or characters')
return attrs
def create(self, validated_data):
return User.objects.create_user(**validated_data)
Views.py:
class RegisterView(generics.GenericAPIView):
serializer_class= RegisterSerializer
def post(self, request):
user = request.data
serializer = self.serializer_class(data=user)
serializer.is_valid(raise_exception=True)
serializer.save()
user_data = serializer.data
user= User.objects.get(email=user_data['email'])
token = RefreshToken.for_user(user).access_token
current_site = get_current_site(request).domain
relativeLink = reverse('email-verify')
absolute_url = 'http://'+current_site+relativeLink+"?token="+str(token)
email_body= 'Hi '+ user.username + ' Use this link below to verify your email \n'+ absolute_url
data = {'email_subject': 'Verify Your Email', 'email_body': email_body , 'to_email': user.email}
Util.send_email(data)
return Response(user_data, status = status.HTTP_201_CREATED)
URL Path:
path('register/', RegisterView.as_view(), name="register" )
Когда я делаю это и пытаюсь протестировать, я получаю ошибку, 'UserManager.create_user() got an unexpected keyword argument 'name''
Пожалуйста, помогите, так как я новичок в django rest frameworrk.
В вашем serializers.py есть список полей, который включает переменную 'name', но она никогда не определяется в models.py
Попробуйте изменить serializers.py
fields=['email','username','password','address','customerId',
'dso', 'roleId']
И измените имя переменной в models.py на username вместо name
username = models.CharField(max_length=70, blank=False, default='')
Исходя из моего опыта работы с Django, наличие модели под названием "user" в какой-то момент создаст проблемы, поскольку Django уже имеет модель User, предустановленную в бэкенд.
Я знаю, что это не совсем тот ответ, который вы искали, но это, возможно, избавит вас от головной боли в будущем.
Для создания профиля пользователя я создал следующую модель, связав модель User с OneToOneField.
class Profile(models.Model):
user = models.OneToOneField(User, null=True, on_delete=models.CASCADE)
bio = models.TextField()
profile_pic = models.ImageField(null=True, blank=True,upload_to="images/")
def __str__(self):
return str(self.user)
и, очевидно, импортные
from django.contrib.auth.models import User
В результате,
Я бы удалил вашу модель пользователя
Импортируйте "from django.contrib.auth.models import User"
добавьте к первой строке вашей UserManager Model, я бы добавил
"user = models.OneToOneField(User, null=True, on_delete=models.CASCADE)