pub mod callsign;
pub mod certificate;
pub mod device_id;
pub mod encryption;
pub mod enrollment;
pub mod error;
pub mod formation_key;
#[cfg(feature = "automerge-backend")]
pub mod formation_peers;
pub mod genesis;
pub mod keypair;
pub use callsign::{
CallsignError, CallsignGenerator, MAX_CALLSIGN_LENGTH, NATO_ALPHABET, TOTAL_CALLSIGNS,
};
pub use certificate::{CertificateBundle, MeshCertificate, MeshTier};
pub use device_id::DeviceId;
pub use encryption::{
EncryptedCellMessage, EncryptedData, EncryptedDocument, EncryptionKeypair, EncryptionManager,
GroupKey, SecureChannel, SymmetricKey, NONCE_SIZE, SYMMETRIC_KEY_SIZE, X25519_PUBLIC_KEY_SIZE,
};
pub use enrollment::{
EnrollmentRequest, EnrollmentResponse, EnrollmentService, EnrollmentStatus,
StaticEnrollmentService,
};
pub use error::SecurityError;
pub use formation_key::{
FormationAuthResult, FormationChallenge, FormationChallengeResponse, FormationKey,
FORMATION_CHALLENGE_SIZE, FORMATION_RESPONSE_SIZE,
};
#[cfg(feature = "automerge-backend")]
pub use formation_peers::FormationPeerSet;
pub use genesis::{MembershipPolicy, MeshCredentials, MeshGenesis};
pub use keypair::DeviceKeypair;
pub const DEFAULT_CHALLENGE_TIMEOUT_SECS: u64 = 30;
pub const CHALLENGE_NONCE_SIZE: usize = 32;
pub const PUBLIC_KEY_SIZE: usize = 32;
pub const SIGNATURE_SIZE: usize = 64;
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_module_exports() {
let _: fn() -> DeviceKeypair = DeviceKeypair::generate;
let _: fn() -> EncryptionKeypair = EncryptionKeypair::generate;
let _: fn() -> CallsignGenerator = CallsignGenerator::new;
}
}