//! Ed25519 implementation of the [crate::Verifier] and [crate::Signer] traits. //! //! This implementation uses the `ed25519-consensus` crate to adhere to a strict //! set of validation rules for Ed25519 signatures (which is necessary for //! stability in a consensus context). You can read more about this //! [here](https://hdevalence.ca/blog/2020-10-04-its-25519am). //! //! # Example //! ```rust //! use commonware_cryptography::{ed25519, PrivateKey, PublicKey, Signature, Verifier as _, Signer as _}; //! use commonware_math::algebra::Random; //! use rand::rngs::OsRng; //! //! // Generate a new private key //! let mut signer = ed25519::PrivateKey::random(&mut OsRng); //! //! // Create a message to sign //! let namespace = &b"demo"[..]; //! let msg = b"hello, world!"; //! //! // Sign the message //! let signature = signer.sign(namespace, msg); //! //! // Verify the signature //! assert!(signer.public_key().verify(namespace, msg, &signature)); //! ``` pub mod certificate; mod scheme; #[cfg(feature = "std")] pub use scheme::Batch; pub use scheme::{PrivateKey, PublicKey, Signature};