Restricting access to certain areas of a flask view function by role?

前端 未结 1 820
予麋鹿
予麋鹿 2021-01-13 14:59

I wrote this, which seems to work just fine:

@app.route(\'/admin\', methods=[\'GET\',\'POST\'])
@login_required
def admin():
    if not current_user.role ==          


        
相关标签:
1条回答
  • 2021-01-13 15:26

    To actually answer your question. You should make the admin_only function a decorator and decorate the admin view method. The reason it does not redirect now is because you are not returning the redirect from the view.

    def admin():
        ret = admin_only()
        if( not ret ):
            return ret
    ....
    

    That should fix your current issue, but it is not ideal and the functionality you wish should be moved to a decorator.

    I also recommend the following:

    Take a look at Flask-Principal it provides the ability to assign roles to users and then restrict access based on these roles to your views.

    Along with Flask-Principal take a look at Flask-Security as it provides many useful security related Flask extensions and just makes it easier to use.

    Example use:

    @roles_required( "admin" )
    def website_control_panel():
        return "Only Admin's can see this."
    

    Will ONLY allow users with the role admin attached to their account. Another use case is to allow a user to have one of many roles which can be specified with the roles_accepted and can be used as following:

    @roles_accepted( "journalist", "editor" )
    def edit_paper():
        return render_template( "paper_editor.html", ... )
    

    Will only allow users that have at least one of the journalist or editor roles tied to their account.

    0 讨论(0)
提交回复
热议问题