use super::*; pub trait CryptoSystem { // Accessors fn kind(&self) -> CryptoKind; fn crypto(&self) -> Crypto; // Cached Operations fn cached_dh( &self, key: &PublicKey, secret: &SecretKey, ) -> Result; // Generation fn random_nonce(&self) -> Nonce; fn random_shared_secret(&self) -> SharedSecret; fn compute_dh( &self, key: &PublicKey, secret: &SecretKey, ) -> Result; fn generate_keypair(&self) -> (PublicKey, SecretKey); fn generate_hash(&self, data: &[u8]) -> PublicKey; fn generate_hash_reader( &self, reader: &mut dyn std::io::Read, ) -> Result; // Validation fn validate_keypair(&self, dht_key: &PublicKey, dht_key_secret: &SecretKey) -> bool; fn validate_hash(&self, data: &[u8], dht_key: &PublicKey) -> bool; fn validate_hash_reader( &self, reader: &mut dyn std::io::Read, key: &PublicKey, ) -> Result; // Distance Metric fn distance(&self, key1: &PublicKey, key2: &PublicKey) -> PublicKeyDistance; // Authentication fn sign( &self, key: &PublicKey, secret: &SecretKey, data: &[u8], ) -> Result; fn verify( &self, key: &PublicKey, data: &[u8], signature: &Signature, ) -> Result<(), VeilidAPIError>; // AEAD Encrypt/Decrypt fn aead_overhead(&self) -> usize; fn decrypt_in_place_aead( &self, body: &mut Vec, nonce: &Nonce, shared_secret: &SharedSecret, associated_data: Option<&[u8]>, ) -> Result<(), VeilidAPIError>; fn decrypt_aead( &self, body: &[u8], nonce: &Nonce, shared_secret: &SharedSecret, associated_data: Option<&[u8]>, ) -> Result, VeilidAPIError>; fn encrypt_in_place_aead( &self, body: &mut Vec, nonce: &Nonce, shared_secret: &SharedSecret, associated_data: Option<&[u8]>, ) -> Result<(), VeilidAPIError>; fn encrypt_aead( &self, body: &[u8], nonce: &Nonce, shared_secret: &SharedSecret, associated_data: Option<&[u8]>, ) -> Result, VeilidAPIError>; // NoAuth Encrypt/Decrypt fn crypt_in_place_no_auth( &self, body: &mut Vec, nonce: &Nonce, shared_secret: &SharedSecret, ); fn crypt_b2b_no_auth( &self, in_buf: &[u8], out_buf: &mut [u8], nonce: &Nonce, shared_secret: &SharedSecret, ); fn crypt_no_auth_aligned_8( &self, body: &[u8], nonce: &Nonce, shared_secret: &SharedSecret, ) -> Vec; fn crypt_no_auth_unaligned( &self, body: &[u8], nonce: &Nonce, shared_secret: &SharedSecret, ) -> Vec; }