# SymCrypt Rust/C FFI Bindings symcrypt-sys provides Rust/C FFI bindings for the [SymCrypt](https://github.com/microsoft/SymCrypt) library. This crate is supplementary to the `symcrypt` crate. The bindings are checked into this crate in order to have better control over the binding generation as well as the exposed APIs from SymCrypt. To speed up the common case build process, the binding generation has been separated to `symcrypt-bindgen` ## Changelog To view a detailed list of changes please see the [releases page](https://github.com/microsoft/rust-symcrypt/releases/). ## Usage Recommended usage is to take advantage of the `symcrypt` crate, which provides safe and rust idiomatic wrappers over the bindings. However, If you want to access the bindings directly, you can add `symcrypt-sys` as a dependency in your rust project. You must also configure your system to pick up the SymCrypt lib on your machine, please see: [INSTALL.md](https://github.com/microsoft/rust-symcrypt/blob/main/rust-symcrypt/INSTALL.md) for more info. In your `Cargo.toml` ```Rust symcrypt-sys = "0.3.0" ``` Then you can call the underlying SymCrypt code directly via the FFIs. ```Rust unsafe { // SAFETY: FFI calls symcrypt_sys::SymCryptSha384( data.as_ptr(), data.len() as symcrypt_sys::SIZE_T, result.as_mut_ptr(), ); } ```