[package]
edition = "2024"
name = "wsc"
version = "0.5.1"
authors = [
"Frank Denis <github@pureftpd.org>",
"Ralf Anton Beier <ralf_beier@me.com>",
]
build = "build.rs"
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = "WebAssembly Signature Component - WASM signing and verification toolkit"
homepage = "https://github.com/pulseengine/wsc"
readme = "README.md"
keywords = [
"webassembly",
"modules",
"signatures",
]
categories = [
"cryptography",
"wasm",
]
license = "MIT"
repository = "https://github.com/pulseengine/wsc"
resolver = "2"
[features]
async = [
"tokio",
"reqwest",
]
cbor = []
default = [
"software-keys",
"sync",
]
keyring-storage = ["keyring"]
rego = ["regorus"]
runtime = ["wasmtime"]
se050 = ["secure-element"]
secure-element = []
sgx = []
software-keys = []
sync = []
tpm2 = ["tss-esapi"]
trustzone = []
[lib]
name = "wsc"
path = "src/lib.rs"
[[test]]
name = "airgapped_e2e"
path = "tests/airgapped_e2e.rs"
[[test]]
name = "keyless_integration"
path = "tests/keyless_integration.rs"
[dependencies.anyhow]
version = "1.0.100"
[dependencies.base64]
version = "0.22"
[dependencies.chrono]
version = "0.4"
[dependencies.const-oid]
version = "0.9"
features = ["db"]
default-features = false
[dependencies.ct-codecs]
version = "1.1.6"
[dependencies.ecdsa]
version = "0.16"
features = ["signing"]
[dependencies.ed25519-compact]
version = "2.1.1"
features = ["pem"]
[dependencies.getrandom]
version = "0.3.4"
features = ["wasm_js"]
[dependencies.hex]
version = "0.4"
[dependencies.hmac-sha256]
version = "1.1.12"
[dependencies.keyring]
version = "3"
features = [
"apple-native",
"sync-secret-service",
]
optional = true
[dependencies.log]
version = "0.4.28"
[dependencies.maybe-async]
version = "0.2"
features = ["is_sync"]
[dependencies.p256]
version = "0.13"
features = [
"ecdsa",
"pem",
]
[dependencies.pem]
version = "3.0"
[dependencies.rcgen]
version = "0.13"
features = [
"pem",
"x509-parser",
]
[dependencies.regex]
version = "1.12.2"
[dependencies.regorus]
version = "0.2"
optional = true
[dependencies.reqwest]
version = "0.12"
features = [
"rustls-tls",
"json",
]
optional = true
default-features = false
[dependencies.rustls]
version = "0.23"
features = [
"std",
"ring",
]
default-features = false
[dependencies.rustls-pki-types]
version = "1.11"
default-features = false
[dependencies.rustls-webpki]
version = "0.103"
features = ["std"]
default-features = false
[dependencies.serde]
version = "1.0"
features = ["derive"]
[dependencies.serde_jcs]
version = "0.1"
[dependencies.serde_json]
version = "1.0"
[dependencies.sha2]
version = "0.10"
[dependencies.spki]
version = "0.7"
features = ["alloc"]
[dependencies.thiserror]
version = "2.0.17"
[dependencies.time]
version = "0.3"
[dependencies.tokio]
version = "1.43"
features = [
"rt-multi-thread",
"net",
"time",
"sync",
]
optional = true
[dependencies.toml]
version = "0.8"
[dependencies.tracing]
version = "0.1"
[dependencies.tracing-subscriber]
version = "0.3"
features = [
"json",
"env-filter",
]
[dependencies.ureq]
version = "3.1.2"
[dependencies.uuid]
version = "1.11"
features = ["v4"]
[dependencies.wasi]
version = "0.14.7"
[dependencies.wasmtime]
version = "29"
features = ["component-model"]
optional = true
[dependencies.webpki-roots]
version = "1.0"
[dependencies.wsc-attestation]
version = "0.5.0"
[dependencies.x509-parser]
version = "0.16"
[dependencies.zeroize]
version = "1.8"
features = ["derive"]
[dev-dependencies.wat]
version = "1.221"
[target.'cfg(target_os = "linux")'.dependencies.tss-esapi]
version = "7"
optional = true