app.decorators 源代码
from functools import wraps
from flask import abort
from flask_login import current_user
from .models import Permission
[文档]def permission_required(permission):
"""
检查用户权限的自定义修饰器。
如果用户不具有指定权限, 则返回 ``403`` 错误码, 即 HTTP ``禁止`` 错误。
"""
def decorator(f):
@wraps(f)
def decorated_function(*args, **kwargs):
if not current_user.can(permission):
abort(403)
return f(*args, **kwargs)
return decorated_function
return decorator
[文档]def admin_required(f):
return permission_required(Permission.ADMINISTER)(f)