[package]
edition = "2024"
name = "assay-auth"
version = "0.3.0"
build = false
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = "Authentication, OIDC (client + provider), passkey, Argon2, JWT, Biscuit capability tokens, session management, and Zanzibar-style authorization for assay-engine."
readme = false
keywords = [
"oidc",
"zanzibar",
"passkey",
"biscuit",
"auth",
]
categories = [
"authentication",
"cryptography",
"asynchronous",
]
license = "Apache-2.0"
repository = "https://github.com/developerinlondon/assay"
resolver = "2"
[features]
auth = [
"auth-oidc",
"auth-oidc-provider",
"auth-passkey",
"auth-password",
"auth-jwt",
"auth-session",
"auth-zanzibar",
]
auth-jwt = [
"dep:jsonwebtoken",
"dep:ed25519-dalek",
"dep:rand_core_06",
]
auth-oidc = [
"dep:openidconnect",
"auth-session",
]
auth-oidc-provider = [
"auth-oidc",
"auth-jwt",
"auth-password",
"dep:oxide-auth",
"dep:askama",
"dep:sha2",
]
auth-passkey = [
"dep:webauthn-rs",
"auth-session",
]
auth-password = [
"dep:argon2",
"dep:password-hash",
]
auth-session = []
auth-zanzibar = []
backend-postgres = [
"dep:sqlx",
"sqlx/postgres",
]
backend-sqlite = [
"dep:sqlx",
"sqlx/sqlite",
]
default = [
"auth",
"backend-postgres",
"backend-sqlite",
]
[lib]
name = "assay_auth"
path = "src/lib.rs"
[[test]]
name = "oidc_provider"
path = "tests/oidc_provider.rs"
[[test]]
name = "zanzibar"
path = "tests/zanzibar.rs"
[dependencies.anyhow]
version = "1"
[dependencies.argon2]
version = "0.5"
optional = true
[dependencies.askama]
version = "0.12"
optional = true
[dependencies.assay-domain]
version = "0.2"
[dependencies.async-trait]
version = "0.1"
[dependencies.axum]
version = "0.8"
[dependencies.biscuit-auth]
version = "6"
[dependencies.chrono]
version = "0.4"
features = [
"std",
"clock",
"serde",
]
default-features = false
[dependencies.cookie]
version = "0.18"
[dependencies.data-encoding]
version = "2"
[dependencies.ed25519-dalek]
version = "2"
features = [
"pem",
"pkcs8",
"rand_core",
]
optional = true
[dependencies.jsonwebtoken]
version = "10"
features = [
"rust_crypto",
"use_pem",
]
optional = true
[dependencies.openidconnect]
version = "4"
optional = true
[dependencies.oxide-auth]
version = "0.6"
optional = true
[dependencies.parking_lot]
version = "0.12"
[dependencies.password-hash]
version = "0.5"
optional = true
[dependencies.rand]
version = "0.9"
[dependencies.rand_core_06]
version = "0.6"
features = ["getrandom"]
optional = true
package = "rand_core"
[dependencies.reqwest]
version = "0.13"
features = [
"json",
"rustls",
"form",
]
default-features = false
[dependencies.serde]
version = "1"
features = ["derive"]
[dependencies.serde_json]
version = "1"
[dependencies.sha2]
version = "0.10"
optional = true
[dependencies.sqlx]
version = "0.8"
features = [
"runtime-tokio-rustls",
"any",
]
optional = true
[dependencies.thiserror]
version = "2"
[dependencies.tokio]
version = "1"
features = [
"sync",
"time",
"rt",
]
[dependencies.tracing]
version = "0.1"
[dependencies.url]
version = "2"
[dependencies.utoipa]
version = "5"
[dependencies.uuid]
version = "1"
features = [
"v4",
"v5",
"serde",
]
[dependencies.webauthn-rs]
version = "0.5"
features = ["danger-allow-state-serialisation"]
optional = true
[dev-dependencies.rstest]
version = "0.26"
[dev-dependencies.sha2]
version = "0.10"
[dev-dependencies.tempfile]
version = "3"
[dev-dependencies.tokio]
version = "1"
features = ["full"]
[dev-dependencies.wiremock]
version = "0.6"