JWT Middleware for the pythonic Starlette API framework
JSON Web Token Middleware for use with Starlette framework.
$ pip install starlette-jwt
Alternatively, install through pipenv.
$ pipenv install starlette-jwt
Register the Middleware with your app.
from starlette.applications import Starlette
from starlette_jwt import JWTAuthenticationBackend
from starlette.middleware.authentication import AuthenticationMiddleware
app = Starlette()
app.add_middleware(AuthenticationMiddleware, backend=JWTAuthenticationBackend(secret_key='secret', prefix='JWT'))Access the JWT payload in a request, Enforce handlers to be with authentication.
The @authentication_required decorator will enforce the user to be logged in for that route. Meanwhile the @anonymous_allowed will allow anonymous users to hit the route.
The default behavior is @anonymous_allowed so your code be explicit.
from starlette.authentication import requires
def my_handler(request):
@app.route('/noauth')
@requires('authenticated')
async def homepage(request):
return JSONResponse({'payload': request.session})Not all handlers must be with authentication
@app.route('/noauth')
async def homepage(request):
return JSONResponse({'payload': None})secret_key
Store your secret key in this setting while creating the middleware:
app.add_middleware(AuthenticationMiddleware, backend=JWTAuthenticationBackend(secret_key='MY SECRET KEY'))algorithm
Configures the jwt algorithm to use (defaults to "HS256", "RSA256" available):
public_key = b'-----BEGIN PUBLIC KEY-----\nMHYwEAYHKoZIzj0CAQYFK4EEAC...'
app.add_middleware(AuthenticationMiddleware, backend=JWTAuthenticationBackend(secret_key=public_key, algorithm='RS256'))NOTE: In order to make starlette-jwt with the RSA256 Algorithm, you must have the package cryptography>=2.7
prefix
Change the Authorization header prefix string (defaults to "JWT"):
# Example: changes the prefix to Bearer
app.add_middleware(AuthenticationMiddleware, backend=JWTAuthenticationBackend(secret_key='secret', prefix='Bearer'))username_field
The user name field in the JWT token payload:
# Example: changes the username field to "user"
app.add_middleware(AuthenticationMiddleware, backend=JWTAuthenticationBackend(secret_key='secret', username_field='user'))audience
The audience field in the JWT token is validated:
# Example: changes the username field to "user"
app.add_middleware(AuthenticationMiddleware, backend=JWTAuthenticationBackend(secret_key='secret', username_field='user', audience='test_aud'))options
The options set to ignore audience verification:
# Example: changes the username field to "user"
app.add_middleware(AuthenticationMiddleware, backend=JWTAuthenticationBackend(secret_key='secret', username_field='user', options={"verify_aud": False}))- Support JWT token standard payload
This project uses pipenv to manage its development environment, and pytest as its tests runner. To install development dependencies:
pipenv install --dev
To run tests:
pipenv shell
pytest
This project uses Codecov to enforce code coverage on all pull requests. To run tests locally and output a code coverage report, run:
pipenv shell
pytest --cov=starlette_test/
python3.7 setup.py sdist
twine upload --repository-url https://pypi.org/legacy/ dist/*
- Starlette project - https://github.com/encode/starlette
- apistar-jwt project - https://github.com/audiolion/apistar-jwt