Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/NovemberOscar/Sanic-JWT-Extended
⚡️An open source Sanic extension that provides "extended" JWT support
https://github.com/NovemberOscar/Sanic-JWT-Extended
authentication authorization jwt jwt-authentication sanic
Last synced: 7 days ago
JSON representation
⚡️An open source Sanic extension that provides "extended" JWT support
- Host: GitHub
- URL: https://github.com/NovemberOscar/Sanic-JWT-Extended
- Owner: rscarrera27
- License: mit
- Created: 2018-11-06T13:32:33.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2023-07-19T23:48:39.000Z (over 1 year ago)
- Last Synced: 2025-02-08T22:35:53.810Z (12 days ago)
- Topics: authentication, authorization, jwt, jwt-authentication, sanic
- Language: Python
- Homepage: https://sanic-jwt-extended.seonghyeon.dev
- Size: 276 KB
- Stars: 35
- Watchers: 1
- Forks: 8
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-sanic - Sanic-JWT-Extended - jwt-extended, provides access/refresh token with fresh, easy custom claim insertion, and role-based access control (Extensions / Authentication)
README
🛡 Sanic-JWT-Extended 🛡
| | |
|:----------|:----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Buiild | [data:image/s3,"s3://crabby-images/2e76e/2e76e4520181f148f2f8f7c2f44a8f5182fe623a" alt="Tests"](https://github.com/NovemberOscar/Sanic-JWT-Extended/actions?query=workflow%3ATests) [data:image/s3,"s3://crabby-images/054a2/054a23a051f5e0cd52d91a96858587e89aa68eba" alt="Deploy"](https://github.com/NovemberOscar/Sanic-JWT-Extended/actions?query=workflow%3A%22Upload+to+PyPI%22) [data:image/s3,"s3://crabby-images/bba7b/bba7b90fad0ad5c490fa6fd71111352f29f8d399" alt="Netlify"](https://app.netlify.com/sites/sanic-jwt-extended/deploys) |
| Quality | [data:image/s3,"s3://crabby-images/5bc6b/5bc6b8c3af01436153b65aee32d17ee9ad947d6d" alt="codecov"](https://codecov.io/gh/NovemberOscar/Sanic-JWT-Extended) [data:image/s3,"s3://crabby-images/41a47/41a47abfffbb16a37c4844f85adfc47ba87a4c2a" alt="Codacy Badge"](https://www.codacy.com/manual/NovemberOscar/Sanic-JWT-Extended?utm_source=github.com&utm_medium=referral&utm_content=NovemberOscar/Sanic-JWT-Extended&utm_campaign=Badge_Grade) [data:image/s3,"s3://crabby-images/c34c5/c34c59b8eeb69f1e3872b6e49248ff8ba61b72a7" alt="Maintainability"](https://codeclimate.com/github/NovemberOscar/Sanic-JWT-Extended/maintainability) |
| Package | data:image/s3,"s3://crabby-images/4a0eb/4a0eb54cd432fadf0887314c654cc8b9fda07205" alt="PyPI" data:image/s3,"s3://crabby-images/c4483/c44834b07a88e188272f63d0519ee19c2b06ef28" alt="GitHub release (latest SemVer including pre-releases)" data:image/s3,"s3://crabby-images/a56ae/a56ae9725433db90f9ab8dde004a53507a2d38ad" alt="PyPI - Python Version" |
| Stats | [data:image/s3,"s3://crabby-images/35d25/35d257806d62077be1523a6c02381d0f467b03c4" alt="Downloads"](https://pepy.tech/project/sanic-jwt-extended) [data:image/s3,"s3://crabby-images/56c23/56c23e211e8a4afdea5a937f3ac073df2ff58750" alt="Downloads"](https://pepy.tech/project/sanic-jwt-extended/month) |
| Community | [data:image/s3,"s3://crabby-images/2e856/2e85676b481b4eba6d1077a656c51692b09ac64f" alt="Gitter"](https://gitter.im/Sanic-JWT-Extended/community?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge) |> **☢️ This is README of 1.0 version. [Click here](https://github.com/NovemberOscar/Sanic-JWT-Extended/tree/v0.4.4) to checkout legacy version(v0.4.4)**
## 🚀 What is Sanic-JWT-Extended?
Sanic-JWT-Extended is an open source Sanic extension that provides JWT support (comply with RFC standard)## 💡 Why Sanic-JWT-Extended?
Sanic-JWT-Extended not only adds support for using JSON Web Tokens (JWT) to Sanic for protecting views,
but also many helpful (and **optional**) features built in to make working with JSON Web Tokens
easier. These include:* Support for adding public claims with [namespacing](https://auth0.com/docs/tokens/concepts/claims-namespacing)
* Support for adding private claims
* [Refresh tokens](https://auth0.com/blog/refresh-tokens-what-are-they-and-when-to-use-them/)
* Token freshness and separate view decorators to only allow fresh tokens
* Access control
* blacklist support with some built-in blacklist
* Provides Token object for easier jwt manifulation## ⚡️ Installation
```shell script
$ pip install sanic-jwt-extended --pre
```
```shell script
$ poetry add sanic-jwt-extended --git https://github.com/NovemberOscar/Sanic-JWT-Extended.git
```
```shell script
$ pipenv install sanic-jwt-extended --pre
```## 🛠 Developing Sanic-JWT-Extended
### Prerequesties
- [poetry](https://github.com/sdispater/poetry)### Installaion
```shell script
$ make env
```
this will install dependencies with poetry. if poetry not found, will install poetry.### Development
- `make format`: this will format your code with `isort` and `black`
- `make check`: this will lint your code with `isort`, `black`, `mypy` and `pylint`
- `make clean`: this will remove temporary things.### Commit Convention
[Conventional Commits](https://www.conventionalcommits.org/en/v1.0.0/)### Testing
```shell script
$ make check # check convention and type
$ poetry run pytest
```with coverage:
```shell script
$ poetry run pytest --cov=sanic_jwt_extended tests/
```**Make sure you wrote TCs about your work!**