我正在尝试在我的应用程序中实现基于角色的权限。我有一个装饰器 role_required,我可以将一组用户角色传递给其中,并且只有具有该角色的用户才能访问该视图。我已经为用户正确分配了角色,但是现在我收到 AttributeError 说明'Role' object has no attribute '__name__'
views.py
文件:
m_role_required = method_decorator(role_required)
class AddProposal(FormView):
@m_role_required(roles.space_admin)
def dispatch(self, *args, **kwargs):
return super(AddProposal, self).dispatch(*args, **kwargs)
装饰师role_required
:
from django.contrib.auth.decorators import user_passes_test
def role_required(*roles):
def check_role(user):
return getattr(user, 'role', None) in roles
return user_passes_test(check_role)
Role
班级:
class Roles(object):
_roles_dict = None
@property
def roles_dict(self):
if self._roles_dict is None:
self._roles_dict = {}
for item in self._config:
if isinstance(item, basestring):
# An item like 'manager'
self._roles_dict[item] = None
else:
# Anything else
raise ImproperlyConfigured(_INCORRECT_ARGS)
return self._roles_dict
@property
def choices(self):
return [(role, role) for role in self.roles_dict.keys()]
def __init__(self, config=None):
self._config = config or getattr(settings, 'USER_ROLES', ())
def __getattr__(self, name):
if name in self.roles_dict.keys():
return Role(name=name)
else:
raise AttributeError("No such role exists '%s'" % name)
roles = Roles()
我无法找出引发此错误的原因。任何人都可以帮忙。让我用这个添加回溯,
环境:
Request Method: GET
Request URL: http://127.0.0.1:8000/en-gb/spaces/bithin/proposal/add/
Traceback:
48. class AddProposal(FormView):
File "/home/bithin/gsoc/week3/e-cidadania/src/apps/ecidadania/proposals/views.py" in AddProposal
78. @m_role_required(roles.space_admin)
File "/usr/local/lib/python2.7/dist-packages/django/utils/decorators.py" in _dec
34. update_wrapper(_wrapper, func)
File "/usr/lib/python2.7/functools.py" in update_wrapper
33. setattr(wrapper, attr, getattr(wrapped, attr))
Exception Type: AttributeError at /en-gb/spaces/bithin/proposal/add/
Exception Value: 'Role' object has no attribute '__name__'