uselesskey-rustls 0.8.0

rustls-pki-types and rustls config adapters for uselesskey X.509/key fixtures.
Documentation
#![forbid(unsafe_code)]

//! Integration between uselesskey test fixtures and `rustls-pki-types`.
//!
//! This crate owns the PKI extension traits that convert uselesskey
//! fixtures into `rustls-pki-types` types (`PrivateKeyDer`,
//! `CertificateDer`). The implementation lives under
//! [`crate::srp::pki`]. (The v0.7.x `uselesskey-core-rustls-pki`
//! published-internal shim was removed in v0.8.0.)
//!
//! With the `server-config` and `client-config` features, it also provides
//! convenience builders for `rustls::ServerConfig` and `rustls::ClientConfig`,
//! including mutual TLS (mTLS) support.
//!
//! # Convert a private key to rustls format
//!
//! ```
//! use uselesskey_core::Factory;
//! use uselesskey_rsa::{RsaFactoryExt, RsaSpec};
//! use uselesskey_rustls::RustlsPrivateKeyExt;
//!
//! let fx = Factory::random();
//! let rsa = fx.rsa("server", RsaSpec::rs256());
//! let key = rsa.private_key_der_rustls();
//! assert_eq!(key.secret_der(), rsa.private_key_pkcs8_der());
//! ```
//!
//! # Build TLS configs (requires `tls-config` + a crypto provider feature)
//!
//! ```no_run
//! use uselesskey_core::Factory;
//! use uselesskey_x509::{X509FactoryExt, ChainSpec};
//! use uselesskey_rustls::{RustlsServerConfigExt, RustlsClientConfigExt};
//!
//! let fx = Factory::random();
//! let chain = fx.x509_chain("svc", ChainSpec::new("test.example.com"));
//!
//! let server_cfg = chain.server_config_rustls();
//! let client_cfg = chain.client_config_rustls();
//! ```

#[cfg(any(feature = "server-config", feature = "client-config"))]
mod config;

#[doc(hidden)]
pub mod srp;

#[cfg(test)]
mod testutil;

#[cfg(feature = "x509")]
pub use srp::pki::RustlsChainExt;
pub use srp::pki::{RustlsCertExt, RustlsPrivateKeyExt};

#[cfg(feature = "server-config")]
pub use config::RustlsServerConfigExt;

#[cfg(feature = "client-config")]
pub use config::RustlsClientConfigExt;

#[cfg(all(feature = "server-config", feature = "client-config"))]
pub use config::RustlsMtlsExt;