MyUser
の拡張機能であるユーザーアプリを作成しましたAbstractBaseUser
。で言及されている限り、モデルMyUser
が標準に取って代わるという印象を受けました。Auth.User
settings.py
AUTH_PROFILE_MODULE = 'プロファイル.MyUser'
問題は、MyUser モデルに登録されているユーザーの権限を設定できないことです。グループのメンバーシップとアクセス許可を設定しようとすると、エラーが発生しますUser' instance expected, got <MyUser: username>
。
ユーザー モデルのユーザーをアクセス許可と正しいグループに追加するにはどうすればよいですか?
class MyUserManager(BaseUserManager):
def create_user(self, username, email, phone, password=None, company=False):
if not email:
raise ValueError('Users must have an email address')
if not username: username = email.split('@')[0]
user = self.model(
email=MyUserManager.normalize_email(email),
username=username,phone=phone,)
user.set_password(password)
user.save(using=self._db)
# add to user group and set permissions
if company:
g = Group.objects.get(name='company')
p = Permission.objects.get(codename='add_company')
else:
g = Group.objects.get(name='user')
p = Permission.objects.get(codename='add_user')
g.user_set.add(user)
user.user_permissions.add(p)
return user
class MyUser(AbstractBaseUser):
username = models.CharField(max_length=254, unique=True, blank=True, null=True)
email = models.EmailField(max_length=254, unique=True, db_index=True)
phone = models.CharField(_('Phone Number'), max_length=25, blank=True, null=True,)
is_active = models.BooleanField(default=True)
is_admin = models.BooleanField(default=False)
USERNAME_FIELD = 'email'
REQUIRED_FIELDS = ['phone']
objects = MyUserManager()
def get_full_name(self):
return self.email
...