2013-05-06 50 views
2

我重寫管理模型UsersAdmin。我添加了一個新屬性:gender這是數據庫中的一列。爲什麼它不起作用?這是怎麼了重寫管理模式自定義UserAdmin模型

class UserAdmin(admin.ModelAdmin): 
    list_display = ('email', 'first_name', 'last_name','gender') 
    list_filter = ('is_staff', 'is_superuser') 

    admin.site.unregister(User) 
    admin.site.register(User, UserAdmin) 

我得到一個錯誤信息:UserAdmin.list_display[3], 'gender' is not a callable or an attribute of 'UserAdmin' or found in the model 'User'

編輯:類UserAdmin來自庫:django.contrib.auth.admin進口UserAdmin,這是類認定中

class UserAdmin(admin.ModelAdmin): 
    add_form_template = 'admin/auth/user/add_form.html' 
    change_user_password_template = None 
    fieldsets = (
     (None, {'fields': ('username', 'password')}), 
     (_('Personal info'), {'fields': ('first_name', 'last_name', 'email',)}), 
     (_('Permissions'), {'fields': ('is_active', 'is_staff', 'is_superuser', 
             'groups', 'user_permissions')}), 
     (_('Important dates'), {'fields': ('last_login', 'date_joined')}), 
    ) 
    add_fieldsets = (
     (None, { 
      'classes': ('wide',), 
      'fields': ('username', 'password1', 'password2')} 
     ), 
    ) 
    form = UserChangeForm 
    add_form = UserCreationForm 
    change_password_form = AdminPasswordChangeForm 
    list_display = ('username', 'email', 'first_name', 'last_name', 'is_staff') 
    list_filter = ('is_staff', 'is_superuser', 'is_active', 'groups') 
    search_fields = ('username', 'first_name', 'last_name', 'email') 
    ordering = ('username',) 
    filter_horizontal = ('groups', 'user_permissions',) 

    def get_fieldsets(self, request, obj=None): 
     if not obj: 
      return self.add_fieldsets 
     return super(UserAdmin, self).get_fieldsets(request, obj) 

    def get_form(self, request, obj=None, **kwargs): 
     """ 
     Use special form during user creation 
     """ 
     defaults = {} 
     if obj is None: 
      defaults.update({ 
       'form': self.add_form, 
       'fields': admin.util.flatten_fieldsets(self.add_fieldsets), 
      }) 
     defaults.update(kwargs) 
     return super(UserAdmin, self).get_form(request, obj, **defaults) 

    def get_urls(self): 
     from django.conf.urls import patterns 
     return patterns('', 
      (r'^(\d+)/password/$', 
      self.admin_site.admin_view(self.user_change_password)) 
     ) + super(UserAdmin, self).get_urls() 

    def lookup_allowed(self, lookup, value): 
     # See #20078: we don't want to allow any lookups involving passwords. 
     if lookup.startswith('password'): 
      return False 
     return super(UserAdmin, self).lookup_allowed(lookup, value) 

    @sensitive_post_parameters() 
    @csrf_protect_m 
    @transaction.commit_on_success 
    def add_view(self, request, form_url='', extra_context=None): 
     # It's an error for a user to have add permission but NOT change 
     # permission for users. If we allowed such users to add users, they 
     # could create superusers, which would mean they would essentially have 
     # the permission to change users. To avoid the problem entirely, we 
     # disallow users from adding users if they don't have change 
     # permission. 
     if not self.has_change_permission(request): 
      if self.has_add_permission(request) and settings.DEBUG: 
       # Raise Http404 in debug mode so that the user gets a helpful 
       # error message. 
       raise Http404(
        'Your user does not have the "Change user" permission. In ' 
        'order to add users, Django requires that your user ' 
        'account have both the "Add user" and "Change user" ' 
        'permissions set.') 
      raise PermissionDenied 
     if extra_context is None: 
      extra_context = {} 
     username_field = self.model._meta.get_field(self.model.USERNAME_FIELD) 
     defaults = { 
      'auto_populated_fields':(), 
      'username_help_text': username_field.help_text, 
     } 
     extra_context.update(defaults) 
     return super(UserAdmin, self).add_view(request, form_url, 
               extra_context) 

    @sensitive_post_parameters() 
    def user_change_password(self, request, id, form_url=''): 
     if not self.has_change_permission(request): 
      raise PermissionDenied 
     user = get_object_or_404(self.queryset(request), pk=id) 
     if request.method == 'POST': 
      form = self.change_password_form(user, request.POST) 
      if form.is_valid(): 
       form.save() 
       msg = ugettext('Password changed successfully.') 
       messages.success(request, msg) 
       return HttpResponseRedirect('..') 
     else: 
      form = self.change_password_form(user) 

     fieldsets = [(None, {'fields': list(form.base_fields)})] 
     adminForm = admin.helpers.AdminForm(form, fieldsets, {}) 

     context = { 
      'title': _('Change password: %s') % escape(user.get_username()), 
      'adminForm': adminForm, 
      'form_url': form_url, 
      'form': form, 
      'is_popup': '_popup' in request.REQUEST, 
      'add': True, 
      'change': False, 
      'has_delete_permission': False, 
      'has_change_permission': True, 
      'has_absolute_url': False, 
      'opts': self.model._meta, 
      'original': user, 
      'save_as': False, 
      'show_save': True, 
     } 
     return TemplateResponse(request, 
      self.change_user_password_template or 
      'admin/auth/user/change_password.html', 
      context, current_app=self.admin_site.name) 

    def response_add(self, request, obj, post_url_continue=None): 
     """ 
     Determines the HttpResponse for the add_view stage. It mostly defers to 
     its superclass implementation but is customized because the User model 
     has a slightly different workflow. 
     """ 
     # We should allow further modification of the user just added i.e. the 
     # 'Save' button should behave like the 'Save and continue editing' 
     # button except in two scenarios: 
     # * The user has pressed the 'Save and add another' button 
     # * We are adding a user in a popup 
     if '_addanother' not in request.POST and '_popup' not in request.POST: 
      request.POST['_continue'] = 1 
     return super(UserAdmin, self).response_add(request, obj, 
                post_url_continue) 

    admin.site.register(Group, GroupAdmin) 
    admin.site.register(User, UserAdmin) 


class User(AbstractUser): 
""" 
Users within the Django authentication system are represented by this 
model. 

Username, password and email are required. Other fields are optional. 
""" 
gender = models.CharField(_('gender'),max_length=30) 


class Meta: 
    swappable = 'AUTH_USER_MODEL' 
+0

請顯示您的型號代碼。 – Yossi 2013-05-06 05:38:03

+0

Django admin找不到性別屬性。你如何在你的模型中定義它?你如何讓它對管理員可見? – dmitri 2013-05-06 05:39:51

+0

你的模特兒缺乏「性別」屬性,兒子! – 2013-05-06 05:41:50

回答

-1

首先我認爲正在發生的事情是,你威力有名稱衝突正在進行。

根據您發佈的內容,您將取消註冊Django User模型,然後重新註冊Django User模型。 沒有看到您的進口聲明,這只是一個瘋狂的猜測。

我會重新命名我的實現Django的User模型沿CustomUser線的東西,這麼說,如果你要註冊,其實是你自己用戶模型,然後你缺少的屬性。

只是磕碰一些代碼出來將導致我這個猜測,你的模型目前看起來像這樣

class User(AbstractBaseUser): 
    identifier = models.CharField(max_length=40, unique=True, db_index=True) 
    email = models.EmailField(max_length=75) 
    USERNAME_FIELD = 'identifier' 

    #and the rest of your custom attributes. 

    def is_active(self): 
     return "your custom implementation" 

    def get_full_name(self): 
     return "your custom implementation" 

    def get_short_name(self): 
     return "your custom implementation" 

    def is_staff(self): 
     return "your custom implementation" 

    def is_superuser(self): 
     return "your custom implementation" 

所以,你的模型具有其它領域,如email,下面這個是你應該添加gender = models.CharField(max_length=1, unique=True)

+0

我很抱歉,我實際上在過濾UserAdmin,請參閱上面的 – user2284926 2013-05-06 07:31:22

+0

@ user2284926是的,但是您正在嘗試訪問'用戶'模型中的'IS NOT'屬性。換句話說,你在哪裏定義了「性別」,因爲它不在'UserAdmin'和'User'模型中。 – 2013-05-06 07:32:24

+0

在UserAdmin模型中,我在fieldset下的個人信息中定義了它。我嘗試過,但我仍然得到相同的錯誤,我應該在哪裏定義它 – user2284926 2013-05-06 07:43:32