securitydept-core 0.2.0

Core of SecurityDept, a layered authentication and authorization toolkit built as reusable Rust crates.
Documentation
# THIS FILE IS AUTOMATICALLY GENERATED BY CARGO
#
# When uploading crates to the registry Cargo will automatically
# "normalize" Cargo.toml files for maximal compatibility
# with all versions of Cargo and also rewrite `path` dependencies
# to registry (e.g., crates.io) dependencies.
#
# If you are reading this file be aware that the original Cargo.toml
# will likely look very different (and much more reasonable).
# See Cargo.toml.orig for the original contents.

[package]
edition = "2024"
name = "securitydept-core"
version = "0.2.0"
authors = ["Zhou Yeheng <root@aitiotekt.com>"]
build = false
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = "Core of SecurityDept, a layered authentication and authorization toolkit built as reusable Rust crates."
homepage = "https://securitydept.ethaxon.com/"
documentation = "https://docs.rs/securitydept-core"
readme = "README.md"
keywords = [
    "auth",
    "oauth",
    "oidc",
    "security",
    "token",
]
categories = [
    "authentication",
    "network-programming",
    "web-programming",
]
license = "MIT"
repository = "https://github.com/ethaxon/securitydept"

[features]
basic-auth-context = [
    "dep:securitydept-basic-auth-context",
    "utils",
    "creds",
    "realip",
]
creds = [
    "dep:securitydept-creds",
    "utils",
]
creds-jwe = [
    "creds",
    "securitydept-creds/jwe",
    "creds-jwt",
    "reexport-josekit",
    "creds-jwk",
]
creds-jwk = [
    "creds",
    "securitydept-creds/jwk",
]
creds-jwt = [
    "creds",
    "securitydept-creds/jwt",
    "reexport-jsonwebtoken",
    "creds-jwk",
]
creds-manage = [
    "dep:securitydept-creds-manage",
    "utils",
    "creds",
    "reexport-openidconnect",
]
creds-manage-migration = [
    "creds-manage",
    "securitydept-creds-manage/migration",
]
creds-oidc = [
    "creds",
    "securitydept-creds/oidc",
    "reexport-openidconnect",
]
creds-rfc9068 = [
    "creds",
    "securitydept-creds/rfc9068",
    "creds-jwt",
    "creds-jwk",
]
full = [
    "reexport-oauth2",
    "reexport-openidconnect",
    "reexport-jsonwebtoken",
    "reexport-josekit",
    "basic-auth-context",
    "creds",
    "creds-jwk",
    "creds-oidc",
    "creds-jwt",
    "creds-jwe",
    "creds-rfc9068",
    "creds-manage",
    "creds-manage-migration",
    "oauth-provider",
    "oauth-resource-server",
    "oauth-resource-server-jwe",
    "oidc-client",
    "oidc-client-recommend",
    "oidc-client-claims-script",
    "oidc-client-recommend-pending-store",
    "oidc-client-moka-pending-store",
    "realip",
    "realip-docker",
    "realip-kube",
    "session-context",
    "session-context-service",
    "token-set-context",
    "token-set-context-recommend",
    "token-set-context-recommend-pending-store",
    "token-set-context-moka-pending-store",
    "token-set-context-recommend-propagation-forwarder",
    "token-set-context-axum-reverse-proxy-propagation-forwarder",
    "utils",
]
oauth-provider = [
    "dep:securitydept-oauth-provider",
    "utils",
    "reexport-openidconnect",
    "reexport-oauth2",
]
oauth-resource-server = [
    "dep:securitydept-oauth-resource-server",
    "oauth-provider",
    "creds-rfc9068",
    "creds-oidc",
    "utils",
    "reexport-openidconnect",
    "reexport-oauth2",
]
oauth-resource-server-jwe = [
    "oauth-resource-server",
    "securitydept-oauth-resource-server/jwe",
    "creds-jwe",
    "reexport-josekit",
]
oidc-client = [
    "dep:securitydept-oidc-client",
    "oauth-provider",
    "utils",
    "reexport-openidconnect",
]
oidc-client-claims-script = [
    "oidc-client",
    "securitydept-oidc-client/claims-script",
]
oidc-client-moka-pending-store = [
    "oidc-client",
    "securitydept-oidc-client/moka-pending-store",
]
oidc-client-recommend = [
    "oidc-client",
    "securitydept-oidc-client/recommend",
    "oidc-client-claims-script",
    "oidc-client-recommend-pending-store",
]
oidc-client-recommend-pending-store = [
    "oidc-client",
    "securitydept-oidc-client/recommend-pending-store",
    "oidc-client-moka-pending-store",
]
realip = ["dep:securitydept-realip"]
realip-docker = [
    "realip",
    "securitydept-realip/docker",
]
realip-kube = [
    "realip",
    "securitydept-realip/kube",
]
reexport-josekit = ["dep:josekit"]
reexport-jsonwebtoken = ["dep:jsonwebtoken"]
reexport-oauth2 = ["dep:oauth2"]
reexport-openidconnect = [
    "dep:openidconnect",
    "reexport-oauth2",
]
session-context = [
    "dep:securitydept-session-context",
    "utils",
]
session-context-service = [
    "session-context",
    "securitydept-session-context/service",
    "oidc-client",
]
token-set-context = [
    "dep:securitydept-token-set-context",
    "oauth-provider",
    "oidc-client",
    "oauth-resource-server",
    "utils",
]
token-set-context-axum-reverse-proxy-propagation-forwarder = [
    "token-set-context",
    "securitydept-token-set-context/axum-reverse-proxy-propagation-forwarder",
]
token-set-context-moka-pending-store = [
    "token-set-context",
    "securitydept-token-set-context/moka-pending-store",
]
token-set-context-recommend = [
    "token-set-context",
    "securitydept-token-set-context/recommend",
    "token-set-context-recommend-pending-store",
    "token-set-context-axum-reverse-proxy-propagation-forwarder",
]
token-set-context-recommend-pending-store = [
    "token-set-context",
    "securitydept-token-set-context/recommend-pending-store",
    "token-set-context-moka-pending-store",
]
token-set-context-recommend-propagation-forwarder = [
    "token-set-context",
    "securitydept-token-set-context/recommend-propagation-forwarder",
    "token-set-context-axum-reverse-proxy-propagation-forwarder",
]
utils = ["dep:securitydept-utils"]

[lib]
name = "securitydept_core"
path = "src/lib.rs"

[dependencies.josekit]
version = "0.10"
optional = true

[dependencies.jsonwebtoken]
version = "10"
features = ["rust_crypto"]
optional = true

[dependencies.oauth2]
version = "5"
optional = true

[dependencies.openidconnect]
version = "4"
optional = true

[dependencies.securitydept-basic-auth-context]
version = "~0.2.0"
optional = true

[dependencies.securitydept-creds]
version = "~0.2.0"
optional = true

[dependencies.securitydept-creds-manage]
version = "~0.2.0"
optional = true

[dependencies.securitydept-oauth-provider]
version = "~0.2.0"
optional = true

[dependencies.securitydept-oauth-resource-server]
version = "~0.2.0"
optional = true

[dependencies.securitydept-oidc-client]
version = "~0.2.0"
optional = true

[dependencies.securitydept-realip]
version = "~0.2.0"
optional = true
default-features = false

[dependencies.securitydept-session-context]
version = "~0.2.0"
optional = true

[dependencies.securitydept-token-set-context]
version = "~0.2.0"
optional = true

[dependencies.securitydept-utils]
version = "~0.2.0"
optional = true