django - 如何防止 Django 管理员用户更改其他管理员用户的个人资料数据?

标签 django django-models django-admin django-forms

我有教师类扩展/子类的管理员用户。

如何防止教师看到和更改其他教师的个人资料数据,而教师只能更改自己的记录/行?提前致谢!

最佳答案

我不确定我是否完全理解您要做什么,但是如果您的想法是让内置用户管理页面对教师用户的工作方式略有不同,那么我相信您只需要扩展 UserAdmin 并覆盖queryset 方法。

class TeacherSpecificUserAdmin(UserAdmin):
  def queryset(self, request):
    if request.user.is_teacher():
      return Teacher.objects.filter(pk=request.user.pk)
    return UserAdmin.queryset(self, request)

这将照顾到不允许教师编辑或删除其他记录,因为如果您查看 ModelAdmin 代码,change_viewdelete_view 方法使用从 queryset 方法返回的查询集来获取要更改或删除的对象。

需要再进行一次调整,因为用于更改 UserAdmin 中密码的 View 与其他 View 使用不同的系统来更改对象。只需在您的新类(class)中覆盖它:
...
def user_change_password(self, request, id):
  if request.user.is_teacher() and request.user.pk != int(id):
    # PermissionDenied is in django.core.exceptions
    raise PermissionDenied
  return UserAdmin.user_change_password(self, request, id)
...

之后,您只需要阻止教师添加新用户或删除他们自己的记录即可。要么使用默认的 django's permission framework ,要么覆盖 has_add_permissionhas_delete_permission 方法。

如果您需要更多信息(在 ModelAdmin 中),请查看 contrib/admin/options.py 源代码。

关于django - 如何防止 Django 管理员用户更改其他管理员用户的个人资料数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2278981/

相关文章:

django - 在 Django 1.9.2 数据库 sqlite3 中插入​​一个列表

django错误: "Caught AlreadyRegistered"?只注册了一次模型

尝试在管理表单上显示 DateTimeField 时出现 Django 异常

django - 新版本的 sorl-thumbnail ,如何在 django admin 中显示拇指?

python - 使用默认 python 解释器而不是安装 virtualenv 解释器的网站

django - Heroku Django 应用程序返回错误 heroku/router : at=error code=H10 desc ="App crashed"

mysql - django + mysql,存储 ip 地址,包括范围

python - authentication.BaseAuthentication.authenticate 的返回签名中的第二个 'auth' 参数是什么?

python - 从 ValuesQuerySet 访问值

django - 在 Django admin 中订购模型 - 简单/正确的方法