mirror of
https://github.com/openpeeps/webtokens
synced 2026-01-01 23:11:22 +00:00
No description
|
|
||
|---|---|---|
| .github/workflows | ||
| src | ||
| tests | ||
| .gitignore | ||
| README.md | ||
| webtokens.nimble | ||

👑 Nim lang bindings for LibJWT
JSON Web Token Library
nimble install webtokens
About
This package provides Nim bindings for LibJWT, a C library that supports the following standards JWS, JWE, JWK, JWA and JWTs. It allows you to create, sign, verify, and decode JSON Web Tokens in your Nim applications.
Note
👌 Low-level and high-level APIs are provided to work with JWTs, JWKs, and JWS/JWE tokens.
Prerequisites
Check the official LibJWT installation guide
Examples
Here is a simple example demonstrating how to create and sign a JSON Web Token (JWT) using HMAC SHA-256 algorithm with the webtokens Nim package.
Create and Sign a Json Web Token
{.passL:"-L/opt/local/lib -ljwt", passC:"-I /opt/local/include".}
import std/[times, json]
import webtokens
# Generate a JWK Set with one random HMAC (oct) key
let jwksJson = generateJwkSet(1, 32)
let set = loadJwkSetFromJson($jwksJson)
let key = set.findByKid("hmac-key-0")
let alg = parseAlg("HS256")
# Initialize JWT Builder
var builder = newJwtBuilder()
builder.setKey(alg, key)
builder.setHeader("typ", "JWT")
builder.setHeader("kid", key.itemKid())
builder.setIss("example-app")
builder.setSub("user123")
builder.setExpIn(3600) # token expires in 1 hour
# Generate the token
let token = builder.generate()
echo "Generated JWT: ", token
# Now, you can use this token for authentication/authorization
var verifier = newJwtChecker()
verifier.setKey(alg, key)
verifier.setLeeway(JWT_CLAIM_EXP, 5) # small clock skew
if verifier.verify(token):
echo "Verified OK!"
todo more examples
❤ Contributions & Support
- 🐛 Found a bug? Create a new Issue
- 👋 Wanna help? Fork it!
- 😎 Get €20 in cloud credits from Hetzner
🎩 License
Made by Humans from OpenPeeps.
Copyright OpenPeeps & Contributors — All rights reserved.