我有基于源和目标规则的转换装饰器在django-fsm(有限状态机)中运行良好。现在我正在尝试添加权限处理。这看起来很简单,但似乎无论我做什么,都会执行转换,而不管用户的权限或缺乏权限。lambda
根据文档,我尝试过使用 Django 权限字符串,并且尝试过使用。我已经尝试了所有这些:
@transition(field=state, source='prog', target='appr', permission='claims.change_claim')
和
@transition(field=state, source='prog', target='appr', permission=lambda instance, user: not user.has_perm('claims.change_claim'),)
并且,作为一个双重检查,因为permission
应该响应任何返回 True/False 的可调用,简单地说:
@transition(field=state, source='prog', target='appr', permission=False)
def approve(self):
在访问转换时,应该TransitionNotAllowed
为所有用户提出一个。但是不——即使是没有权限的基本用户仍然可以执行转换(claim.approve()
)。
为了证明我有正确的权限字符串:
print(has_transition_perm(claim.approve, request.user))
打印错误。我正在进行如下验证(适用于源/目标):
class ClaimEditForm(forms.ModelForm):
'''
Some users can transition claims through allowable states
'''
def clean_state(self):
state = self.cleaned_data['state']
if state == 'appr':
try:
self.instance.approve()
except TransitionNotAllowed:
raise forms.ValidationError("Claim could not be approved")
return state
class Meta:
model = Claim
fields = (
'state',
)
视图处理程序是标准:
if request.method == "POST":
claim_edit_form = ClaimEditForm(request.POST, instance=claim)
if claim_edit_form.is_valid(): # Validate transition rules
我错过了什么?谢谢。