Search
 
SCRIPT & CODE EXAMPLE
 

PYTHON

How to secure an endpoint for selected users with Flask-JWT-Extended

from flask import abort
from flask_jwt_extended import current_user

@app.route('/users/<userid:int>/edit')
@jwt_required
def users_edit(userid):
    if userid != current_user.id:
        abort(403)

    # ... handle view for matching user
Comment

How to secure an endpoint for selected users with Flask-JWT-Extended

# assuming that the sub claim is an integer value
    if userid != get_jwt_identity()
Comment

How to secure an endpoint for selected users with Flask-JWT-Extended

from functools import wraps
from flask_jwt_extended import current_user, jwt_protected

def userid_must_match(f):
    """Abort with a 403 Forbidden if the userid doesn't match the jwt token

    This decorator adds the @protected decorator

    Checks for a `userid` parameter to the function and aborts with 
    status code 403 if this doesn't match the user identified by the
    token.
    
    """

    @wraps(f)
    @jwt_protected
    def wrapper(*args, userid=None, **kwargs):
        if userid is not None and userid != current_user.id:
            abort(403)
        return f(*args, **kwargs)

    return wrapper
Comment

How to secure an endpoint for selected users with Flask-JWT-Extended

@app.route('/users/<userid:int>/edit')
@userid_must_match
def users_edit():
    # ... handle view for matching user
Comment

How to secure an endpoint for selected users with Flask-JWT-Extended

from flask import abort
from flask_jwt_extended import current_user

@app.route('/users/edit')
@app.route('/users/<userid:int>/edit')
@userid_must_match
def users_edit():
    # ... handle view for matching user via current_user
Comment

PREVIOUS NEXT
Code Example
Python :: How to query one to many on same page 
Python :: Flask select which form to POST by button click 
Python :: Hide div element using python in Flask 
Python :: Wtforms: How to generate blank value using select fields with dynamic choice values 
Python :: How deploy Flask application on Webfaction 
Python :: Django, limit queryset without slicing 
Python :: typing effect in python 
Python :: find middle permutation of the string in python list 
Python :: Invenco Order Dict 
Python :: best website to learn python 
Python :: replace string in dictionary python 
Python :: ring get the windows new line string 
Python :: python print replace old print 
Python :: ring Trace library usage to pass an error 
Python :: how to start spaCy code 
Python :: void setup and void loop 
Python :: 0 
Python :: instead of: firstName = "John" lastName = "Henry" city = "Manchester" 
Python :: python mayusculas 
Python :: trello class 
Python :: gspread how to put shhet number in a variable 
Python :: alterning format when reading from a text file 
Python :: mail.send_message flask not working, SSL == 465 
Python :: reading json without using relative path in django 
Python :: how to read json file from s3 bucket into aws glue job 
Python :: r Return each result with an index 
Python :: Code converter C++ to python 
Python :: 1051 texes uri solution 
Python :: pandas apply dont convert to timestamp 
Python :: use python logging to log user ips+time in a file whenever a request comes to the server, this should be done in a custom middleware. 
ADD CONTENT
Topic
Content
Source link
Name
3+8 =