2015-09-27 66 views
0

我正在構建一個系統,我需要超級管理員可以創建組併爲不同的組設置不同的權限集。Django Admin將權限添加到工作人員用戶不起作用

比方說,我建立一個圖書管理系統

我已經延長我的Django用戶模型,並創建了一個名爲LibraryUser自定義Django的用戶。

class LibraryUser(AbstractBaseUser): 
    groups = models.ManyToManyField(Group, verbose_name=_('groups'),blank=True, 
     related_name="tmp_user_set", related_query_name="user") 
    user_permissions = models.ManyToManyField(Permission, 
     verbose_name=_('user permissions'), blank=True, 
     related_name="tmp_user_set", related_query_name="user") 
    # username = models.CharField(_('username'), max_length=30, unique=True, 
    #  validators=[ 
    #   validators.RegexValidator(re.compile('^[\[email protected]+-]+$'), _('Enter a valid username.'), _('invalid')) 
    #  ]) 
    first_name = models.CharField(_('first name'), max_length=30, blank=True, null=True) 
    last_name = models.CharField(_('last name'), max_length=30, blank=True, null=True) 
    email = models.EmailField(_('email address'), max_length=255, unique=True) 
    is_staff = models.BooleanField(_('staff status'), default=False) 
    is_active = models.BooleanField(_('active'), default=False) 
    is_superuser = models.BooleanField(_('admin'), default=False) 
    date_joined = models.DateTimeField(_('date joined'), default=timezone.now) 
    receive_newsletter = models.BooleanField(_('receive newsletter'), default=False) 
    facebook_id = models.CharField(max_length=30, blank=True) 
    activation_key = models.CharField(max_length=40, blank="True") 
    reset_password_key = models.CharField(max_length=40, blank="True") 
    key_expires = models.DateTimeField(default=datetime.datetime.now() + datetime.timedelta(days=1)) 
    is_email_verified = models.BooleanField(default=False) 
    objects = LibraryUserManager() 

    USERNAME_FIELD = 'email' 

    class Meta: 
     verbose_name = _('user') 
     verbose_name_plural = _('users') 

    def get_full_name(self): 
     full_name = '%s %s' % (self.first_name, self.last_name) 
     return full_name.strip() 

    def get_short_name(self): 
     return self.first_name 

    def email_user(self, subject, message, from_email=None): 
     send_mail(subject, message, from_email, [self.email]) 

    def has_perm(self, perm, obj=None): 
     return self.is_superuser 

    def has_module_perms(self, app_label): 
     return self.is_superuser 

我已經LibraryUserManager從BaseUserManager擴展和創建createstaffuser功能,這有助於創造一個員工的用戶。

class LibraryUserManager(BaseUserManager): 

    def _create_user(self, email, password, is_staff, is_superuser, **extra_fields): 
     now = timezone.now() 
     email = self.normalize_email(email) 
     user = self.model(email=email, is_staff=is_staff, 
          is_active=False, is_superuser=is_superuser, last_login=now, 
          date_joined=now, **extra_fields) 
     user.set_password(password) 
     user.is_active = True 
     user.save(using=self._db) 
     return user 

    def create_user(self, email=None, password=None, **extra_fields): 
     return self._create_user(email, password, False, False, **extra_fields) 

    def create_staffuser(self, email=None, password=None, **extra_fields): 
     user = self._create_user(email, password, True, False, **extra_fields) 
     user.is_staff = True 
     user.save(using=self._db) 
     return user 

    def create_superuser(self, email, password, **extra_fields): 
     user = self._create_user(email, password, True, True, **extra_fields) 
     user.is_superuser = True 
     user.save(using=self._db) 
     return user 

    def update_user_details(self, email, first_name, last_name): 
     user = User.objects.get(email=email) 

     if user is not None: 
      user.first_name = first_name 
      user.last_name = last_name 
      user.save 
      return user 
     return None 

而且我有兩個名爲經理和編輯與相應的權限組。因此,當我從超級用戶登錄併爲其他用戶設置了一些組權限時,我可以看到該組和相應的權限在其配置文件中得到更新。

但是,當我從工作人員的帳戶登錄我看到下面的消息

站點管理

您沒有權限編輯任何東西。

請讓我知道如果我失去了一些東西。

+0

是指從其他非超級用戶帳戶登錄? – GwynBleidD

回答

2

您已覆蓋has_perm,它檢查用戶是否有權編輯某些內容,如果用戶是超級用戶,則僅返回True。所以非超級用戶永遠不會在管理界面擁有任何權限。

如果這不是你想要的,不要這樣做。