tss_esapi/abstraction/
mod.rspub mod ak;
pub mod cipher;
pub mod ek;
pub mod nv;
pub mod pcr;
pub mod public;
pub mod transient;
use std::convert::TryFrom;
use crate::{
attributes::ObjectAttributesBuilder,
interface_types::{algorithm::AsymmetricAlgorithm, ecc::EccCurve, key_bits::RsaKeyBits},
structures::PublicBuilder,
Error, WrapperErrorKind,
};
pub trait KeyCustomization {
fn attributes(&self, attributes_builder: ObjectAttributesBuilder) -> ObjectAttributesBuilder {
attributes_builder
}
fn template(&self, template_builder: PublicBuilder) -> PublicBuilder {
template_builder
}
}
pub trait IntoKeyCustomization {
type T: KeyCustomization;
fn into_key_customization(self) -> Option<Self::T>;
}
impl<T: KeyCustomization> IntoKeyCustomization for T {
type T = T;
fn into_key_customization(self) -> Option<Self::T> {
Some(self)
}
}
#[derive(Debug, Copy, Clone)]
pub struct DefaultKey;
#[derive(Debug, Copy, Clone)]
pub struct DefaultKeyImpl;
impl KeyCustomization for DefaultKeyImpl {}
impl IntoKeyCustomization for DefaultKey {
type T = DefaultKeyImpl;
fn into_key_customization(self) -> Option<Self::T> {
None
}
}
impl IntoKeyCustomization for Option<DefaultKey> {
type T = DefaultKeyImpl;
fn into_key_customization(self) -> Option<Self::T> {
None
}
}
#[derive(Copy, Clone, Debug, PartialEq, Eq)]
pub enum AsymmetricAlgorithmSelection {
Rsa(RsaKeyBits),
Ecc(EccCurve),
}
impl TryFrom<AsymmetricAlgorithm> for AsymmetricAlgorithmSelection {
type Error = Error;
fn try_from(value: AsymmetricAlgorithm) -> Result<Self, Self::Error> {
match value {
AsymmetricAlgorithm::Rsa => Ok(AsymmetricAlgorithmSelection::Rsa(RsaKeyBits::Rsa2048)),
AsymmetricAlgorithm::Ecc => Ok(AsymmetricAlgorithmSelection::Ecc(EccCurve::NistP256)),
AsymmetricAlgorithm::Null => {
Err(Error::local_error(WrapperErrorKind::UnsupportedParam))
}
}
}
}