Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vimalloc/flask-jwt-extended
An open source Flask extension that provides JWT support (with batteries included)!
https://github.com/vimalloc/flask-jwt-extended
flask flask-jwt flask-jwt-extended jwt
Last synced: 4 days ago
JSON representation
An open source Flask extension that provides JWT support (with batteries included)!
- Host: GitHub
- URL: https://github.com/vimalloc/flask-jwt-extended
- Owner: vimalloc
- License: mit
- Created: 2016-09-13T20:57:28.000Z (over 8 years ago)
- Default Branch: main
- Last Pushed: 2024-12-30T16:42:14.000Z (12 days ago)
- Last Synced: 2025-01-04T10:35:36.365Z (8 days ago)
- Topics: flask, flask-jwt, flask-jwt-extended, jwt
- Language: Python
- Homepage: http://flask-jwt-extended.readthedocs.io/en/stable/
- Size: 929 KB
- Stars: 1,560
- Watchers: 29
- Forks: 240
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- best-of-web-python - GitHub - 2% open · ⏱️ 01.03.2024): (Authorization & Authentication)
- starred-awesome - flask-jwt-extended - A Flask JWT extension that supports refresh tokens, blacklisting/revoking tokens, and token freshness (for accessing critical views) (Python)
README
# Flask-JWT-Extended
### Features
Flask-JWT-Extended not only adds support for using JSON Web Tokens (JWT) to Flask for protecting routes,
but also many helpful (and **optional**) features built in to make working with JSON Web Tokens
easier. These include:- Adding custom claims to JSON Web Tokens
- Automatic user loading (`current_user`).
- Custom claims validation on received tokens
- [Refresh tokens](https://auth0.com/blog/refresh-tokens-what-are-they-and-when-to-use-them/)
- First class support for fresh tokens for making sensitive changes.
- Token revoking/blocklisting
- Storing tokens in cookies and CSRF protection### Usage
[View the documentation online](https://flask-jwt-extended.readthedocs.io/en/stable/)
### Upgrading from 3.x.x to 4.0.0
[View the changes](https://flask-jwt-extended.readthedocs.io/en/stable/v4_upgrade_guide/)
### Changelog
You can view the changelog [here](https://github.com/vimalloc/flask-jwt-extended/releases).
This project follows [semantic versioning](https://semver.org/).### Chatting
Come chat with the community or ask questions at https://discord.gg/EJBsbFd
### Contributing
Before making any changes, make sure to install the development requirements
and setup the git hooks which will automatically lint and format your changes.```bash
pip install -r requirements.txt
pre-commit install
```We require 100% code coverage in our unit tests. You can run the tests locally
with `tox` which ensures that all tests pass, tests provide complete code coverage,
documentation builds, and style guide are adhered to```bash
tox
```A subset of checks can also be ran by adding an argument to tox. The available
arguments are:- py37, py38, py39, py310, py311, py312, pypy3
- Run unit tests on the given python version
- mypy
- Run mypy type checking
- coverage
- Run a code coverage check
- docs
- Ensure documentation builds and there are no broken links
- style
- Ensure style guide is adhered to```bash
tox -e py38
```We also require features to be well documented. You can generate a local copy
of the documentation by going to the `docs` directory and running:```bash
make clean && make html && open _build/html/index.html
```