Skip to main content

JWT library implemented in Rust for Python

This project has been archived.

The maintainers of this project have marked this project as archived. No new releases are expected.

Project description

Rustoken

Rustoken is a Python library written in Rust that can create and decode JWT tokens. This is the first version of the library and it currently supports only the HS256 algorithm.


How to make SECRET-KEY in Rustoken:

from rustoken import secret_key

secret_key = secret_key() # save it to .env file
print(secret_key)

How to make SECRET-KEY on linux:

# 32 bytes (256 bits) base64
openssl rand -base64 32   # outputs a base64 string you can store

# or 64 bytes (512 bits)
openssl rand -base64 64

Usage In Fast-Api:

from rustoken import RustToken

from fastapi import FastAPI, Depends
from sqlalchemy.orm import Session
from . import models, schemas, database

app = FastAPI()


models.Base.metadata.create_all(bind=database.engine)

def get_db():
    db = database.SessionLocal()
    try:
        yield db
    finally:
        db.close()


@app.post("/make-user/", response_model=schemas.UserResponse)
def create_user(user: schemas.UserCreate, db: Session = Depends(get_db)):
    new_user = models.User(username=user.username, email=user.email)
    db.add(new_user)
    db.commit()
    db.refresh(new_user)

    #<------------------------------------------------------->
    jwt = RustToken("MY-SECRET-KEY") # better to use .env file
    access = jwt.create_token(new_user.id, 24 * 60 * 60) # 1 day
    refresh = jwt.create_token(new_user.id, 24 * 60 * 60 * 7) # 7 day exp
    return {"refresh_token": refresh, "access_token": access}

NOTE: The expiration time is in seconds


How to decode Tokens:

    from rustoken import RustToken

    jwt = RustToken("MY-SECRET-KEY") # better to use .env file

    token = "eyJ0eXAiOiJKV1QiLCJhbGciO..."
    try:
        jwt.decode(token)
    except ValueError:
        # if token is expired it return a ValueError
        ...

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

rustoken-0.1.3-cp313-cp313-manylinux_2_34_x86_64.whl (810.5 kB view details)

Uploaded CPython 3.13manylinux: glibc 2.34+ x86-64

File details

Details for the file rustoken-0.1.3-cp313-cp313-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for rustoken-0.1.3-cp313-cp313-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 e228407ab5a0a75cbc826235de3c8b15a440ce67fee524972f0f4d3875c8466a
MD5 2f2e667ead341c009da6e6281ffa0a09
BLAKE2b-256 228f94b4615fda3d3f1b5e04181d74a899de0c773e40d5bdfa21212a0264747d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page