tss-esapi

Crates.iotss-esapi
lib.rstss-esapi
version8.0.0-alpha.1
created_at2020-01-15 11:42:15.671831+00
updated_at2025-10-25 07:51:41.294382+00
descriptionRust-native wrapper around TSS 2.0 Enhanced System API
homepage
repositoryhttps://github.com/parallaxsecond/rust-tss-esapi
max_upload_size
id198607
size2,109,830
Jesper Brynolf (Superhepper)

documentation

https://docs.rs/crate/tss-esapi

README

TPM2 Software Stack Rust Wrapper

Crates.io Code documentation

This is the high-level, Rust idiomatic wrapper crate that exposes an interface to TSS.

This crate depends on the tss-esapi-sys crate for its FFI interface. By default, pre-generated bindings are used. If you'd like the bindings to be generated at build time, please enable either the generate-bindings feature - the FFI bindings will then be generated at build time using the headers identified on the system.

Our end-goal is to achieve a fully Rust-native interface that offers strong safety and security guarantees. Check out our documentation for an overview of our code safety approach.

Integration Tests

See the integration tests

Cargo Features

The crate currently offers the following features:

  • generate-bindings - forces the underlying tss-esapi-sys crate to regenerate the FFI bindings on each build, using the TSS libraries available on the build machine.
  • abstraction (enabled by default) - provides a set of abstracted primitives on top of the basic Rust-native ESAPI API provided by the crate. This feature can be turned off to reduce the number of dependencies built.
  • serde - enable serde Serialize/Deserialize traits for types.
  • rustcrypto-full (disabled by default) - provides conversion from all supported elliptic curves, rsa or hashes. Support for individual hash, rsa or curves can be pulled individually.

Cross compiling

For more information on cross-compiling the tss-esapi crate, please see the README of the tss-esapi-sys crate.

Copyright 2021 Contributors to the Parsec project.

Commit count: 888

cargo fmt