1. 程式人生 > 程式設計 >django xadmin action相容自定義model許可權教程

django xadmin action相容自定義model許可權教程

如標題。最近在研究xadmin,發現文件確實比較少,自己只能連滾帶爬~

起因

因為想做一個審批的功能,用xadmin acrtion來實現。本來想用模組現有“change”欄位控制權限,但是發現使用“change”欄位控制權限的話,會把自帶的 “delete” action 暴露出來,這不是我想要的。 所以在模組裡添加了一個“approver”欄位,用以控制權限。

程式碼

首先修改模組的 “Meta”,增加許可權欄位。

class TaskApprove(Task):
  class Meta:
    proxy = True
    verbose_name = u'審批'
    verbose_name_plural = verbose_name
    permissions = (
      ("approve","審批:使用者任務"),)

然後重新整理一下資料庫,會在使用者管理的介面中看到我們新加的許可權。

接下來在adminx.py中建立自己的action,並在你的管理類中新增。

from xadmin.plugins.actions import BaseActionView
class MyAction(BaseActionView):
  action_name = u'accept'
  model_perm = 'approve'
  description = '同意'
  def do_action(self,queryset):
    for obj in queryset:
      ##你的操作
      print(obj)
    return HttpResponse('您已同意')
class TaskApproveSettings(ViewOnlyMixin):
  actions = [MyAction,]
  list_display = ['name','targets','services','create_by']
xadmin.site.register(TaskApprove,TaskApproveSettings)

下面是重點, 因為xadmin中的許可權檢測是寫死的 只有 “view\change\delete\add”,而我們添加了一個“approve欄位”, 這會導致報錯 – “keyerro” 。 所以接下來我們覆蓋一下xadmin中的方法,新增一個方法。

* 不知道為什麼前幾次以繼承覆蓋的方式沒有成功~~*

在控制類TaskApproveSettings中新增。

首先新增一個方法,用來獲取是否有許可權

def has_approve_permission(self):
  codename = get_permission_codename('approve',self.opts)
  return ('approve' not in self.remove_permissions) and self.user.has_perm('%s.%s' % (self.app_label,codename))

接下來修改get_model_perms 方法,將我們的許可權新增進去

  def get_model_perms(self):
    """
    Returns a dict of all perms for this model. This dict has the keys
    ``add``,``change``,and ``delete`` mapping to the True/False for each
    of those actions.
    """
    return {
      'view': self.has_view_permission(),'add': self.has_add_permission(),'change': self.has_change_permission(),'delete': self.has_delete_permission(),'approve': self.has_approve_permission()
    }

最後是這樣的

from xadmin.plugins.actions import BaseActionView
from django.shortcuts import HttpResponse
from django.contrib.auth import get_permission_codename
class ActionApproveAccept(BaseActionView):
  action_name = u'accept'
  model_perm = 'approve'
  description = '同意'
  global_actions = []
  def do_action(self,queryset):
    for obj in queryset:
      print(obj)
    return HttpResponse('您已同意')

class ActionApproveReject(BaseActionView):
  action_name = u'reject'
  model_perm = 'approve'
  description = '拒絕'
  global_actions = []
  def do_action(self,queryset):
    for obj in queryset:
      print(obj)
    return HttpResponse('您已拒絕')
class TaskApproveSettings(ViewOnlyMixin):
  actions = [ActionApproveAccept,ActionApproveReject]

  list_display = ['name','create_by']
  readonly_fields = TaskFields.create+TaskFields.params+TaskFields.approve
  form_layout = (
    Main(
      Fieldset('',*TaskFields.create,css_class='unsort no_title'
           ),Fieldset(('引數'),*TaskFields.params
           ),),Side(
      Fieldset(('審批狀態'),*TaskFields.approve
           ),)
  )
  def get_model_perms(self):
    return {
      'view': self.has_view_permission(),'approve': self.has_approve_permission()
    }
  def has_approve_permission(self):
    codename = get_permission_codename('approve',self.opts)
    return ('approve' not in self.remove_permissions) and self.user.has_perm('%s.%s' % (self.app_label,codename))

重啟服務就好啦!

我僅做了目前這些,暫時沒有發現問題。如果後面發現問題我會繼續補充,另外大家如果有更好的方法,歡迎留言糾正~!

補充知識:Dajngo 通過程式碼新增xadmin使用者和許可權(組)

在開發的時候,使用者要求在認證的時候自動新增xadmin登入賬戶和分配組許可權

from django.contrib.auth.models import Group,User
from django.http import JsonResponse
def test(req):
  name=req.POST['name']
  account=req.POST['account']
  password=req.POST['password']
  an=Group.objects.filter(id=1).first() #二級管理組 是管理員在xadmin後臺新增的許可權組
  user = User(username=account)
  user.set_password(password)
  user.is_superuser = False
  user.is_active = True
  user.first_name = name
  user.is_staff = True
  user.save() #先生成使用者
  user.groups.add(an)
  return JsonResponse({'ret':0,'msg':'success'})

以上這篇django xadmin action相容自定義model許可權教程就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。