【发布时间】:2022-03-22 18:38:37
【问题描述】:
我已经设法让角色使用此代码,但是!
class Roled(object):
def is_accessible(self):
roles_accepted = getattr(self, 'roles_accepted', None)
if flask_login.current_user.is_authenticated:
user = CustomUser.objects.get(email=flask_login.current_user.id)
for role in user.roles:
for permission in role.permissions:
if permission == "admin":
return flask_login.current_user.is_authenticated
def inaccessible_callback(self, name, **kwargs):
# redirect to login page if user doesn't have access
return redirect(url_for('login', next=request.url))
class AdminView(Roled, ModelView):
def __init__(self, *args, **kwargs):
self.roles_accepted = kwargs.pop('roles_accepted', list())
super(AdminView, self).__init__(*args, **kwargs)
class TranslationView(Roled, ModelView):
column_filters = ['eng']
column_searchable_list = ('eng','geo', 'name')
现在我在添加flask 管理视图时向每个add_view 添加roles_accapted 时遇到问题,就像在question 中一样
【问题讨论】:
标签: flask-admin flask-mongoengine