Implementation of the CoverCrypt algorithm.
The crate is separated in 3 main modules:
cover_crypt_core
: contains the cryptographic code for CoverCrypt. api.rs
: exposes the public API with policy managementinterfaces
: contains interfaces useful for Cosmian matching those in crypto_base as well as a Foreign Function Interface (FFI) useful to integrate with other languages. In particular, the code in this module demonstrates the use of hybrid cryptography involving ABE and AES and exposes it as a FFI.To build the core only, run
bash
cargo build --release
To build the Cosmian interfaces without FFI, pass the interfaces
feature flag, i.e.
bash
cargo build --release --features interfaces
To build everything, including the FFI, pass the ffi
feature flag, or use --all-features
i.e.
bash
cargo build --release --all-features
The latter will build a shared library and one can verify that the FFI symbols are present using (linux)
bash
objdump -T target/release/libcover_crypt.so
The code contains numerous tests that you can run using
bash
cargo test --release --all-features
Go to the build directory for an example on hw to build for GLIBC 2.17
bash
maturin develop --cargo-extra-args="--release --features python
Benchmarking is using Criterion library.
Run all benchmarks:
bash
cargo bench --features ffi
note: unfortunately, we cannot automatically tell Criterion to run benchmarks with ffi
feature activated, we need to specify it.
Run only non-FFI benchmarks:
console
cargo bench
To generate a Flamegraph on Criterion's benchmark:
console
cargo flamegraph --bench benches --features ffi -- --bench