Социальная аутентификация django не возвращает имя и фамилию при создании профиля - django 1.5

Я использую настраиваемую модель пользователя для хранения сведений о пользователе с помощью django 1.5, ниже приведен мой код. При использовании социальной аутентификации все работает нормально, включая имя и фамилию.

В моей структуре таблицы таблицы у меня нет first_name и last_name, вместо этого у меня есть одно полное имя поля.

но я создал метод в менеджере, чтобы принимать имя и фамилию и объединять их. но я все еще получаю пустые значения, какие-либо советы о том, почему это происходит?

class UserManager(BaseUserManager):
    """
    UserManager()
    """
    def create_user(self, username, email=None, password=None, first_name='', last_name='', **extra_fields):
        if not username:
            raise ValueError('Users must have a username')

        user = self.model(
            username=username,
            email=UserManager.normalize_email(email),
            full_name='%s %s' % (first_name, last_name),
        )

        user.set_password(password)
        user.save(using=self._db)
        return user


class User(AbstractBaseUser, PermissionsMixin):
    """
    Accounts/User
    """

    GENDERS = (
        (u'M', _('Male')),
        (u'F', _('Female')),
    )


    username = models.CharField(_('username'), max_length=30, unique=True,
        help_text=_('Required. 30 characters or fewer. Letters, numbers and '
                    '@/./+/-/_ characters'),
        validators=[
            validators.RegexValidator(re.compile('^[\w.@+-]+$'), _('Enter a valid username.'), 'invalid')
        ])


    email           = models.EmailField(_('email address'), blank=True)


    is_staff = models.BooleanField(_('staff status'), default=False,
        help_text=_('Designates whether the user can log into this admin '
                    'site.'))
    is_active = models.BooleanField(_('active'), default=True,
        help_text=_('Designates whether this user should be treated as '
                    'active. Unselect this instead of deleting accounts.'))
    date_joined = models.DateTimeField(_('date joined'), default=timezone.now)

    # user details and information
    full_name           = models.CharField(_('full name'), max_length=30, )
    date_of_birth       = models.DateField(_('birthday'), null=True, blank=True)
    bio                 = models.TextField(_('biography / about you'), null=True, blank=True, help_text=_('Biography / About you'))
    gender              = models.CharField(_('gender'), max_length=1, blank=True, null=True, choices=GENDERS)

    # follows / followers
    followings           = models.ManyToManyField('self', through='Relationship', symmetrical=False, related_name='followers')

    objects             = UserManager()

    USERNAME_FIELD = 'username'
    REQUIRED_FIELDS = ['email', 'date_of_birth', 'full_name',] 

person Mo J. Mughrabi    schedule 13.04.2013    source источник


Ответы (1)


Django-social-auth не работает так при создании пользователя, вместо этого при вызове create_user в вашем менеджере он просто передает имя пользователя и адрес электронной почты, как вы можете видеть здесь. Позже в конвейере обновляются дополнительные поля в вашей пользовательской модели, когда это вызывается, но, как сказано в коде, он выполняет getattr(user, name, None), который в вашем случае для first_name и last_name возвращает None, поскольку эти поля не определены в вашей модели.

Вы можете обмануть систему, определив некоторые свойства в вашей модели, например:

class User(...):
    @property
    def first_name(self):
        if not hasattr(self, '_first_name'):
            self._first_name = self.full_name.split(' ', 1)[0]
        return self._first_name

    @first_name.setter
    def first_name(self, value):
        self._first_name = value
        self.build_full_name()

    @property
    def last_name(self):
        if not hasattr(self, '_last_name'):
            self._last_name = self.full_name.split(' ', 1)[-1]
        return self._last_name

    @first_name.setter
    def last_name(self, value):
        self._last_name = value
        self.build_full_name()

    def build_full_name(self):
        self.full_name = ' '.join([self._first_name, self._last_name])
person omab    schedule 14.04.2013