use num_derive::FromPrimitive;
mod response_status;
pub mod utils;
pub mod common;
pub mod request;
pub mod response;
#[cfg(feature = "fuzz")]
use arbitrary::Arbitrary;
pub use request::Request;
pub use response::Response;
pub use response_status::{ResponseStatus, Result};
use std::convert::TryFrom;
#[cfg_attr(feature = "fuzz", derive(Arbitrary))]
#[derive(FromPrimitive, PartialEq, Eq, Hash, Copy, Clone, Debug)]
#[repr(u8)]
pub enum ProviderID {
Core = 0,
MbedCrypto = 1,
Pkcs11 = 2,
Tpm = 3,
}
impl std::fmt::Display for ProviderID {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
write!(f, "{:?}", self)
}
}
impl TryFrom<u8> for ProviderID {
type Error = ResponseStatus;
fn try_from(provider_id: u8) -> ::std::result::Result<Self, Self::Error> {
match num::FromPrimitive::from_u8(provider_id) {
Some(provider_id) => Ok(provider_id),
None => Err(ResponseStatus::ProviderDoesNotExist),
}
}
}
#[cfg_attr(feature = "fuzz", derive(Arbitrary))]
#[derive(FromPrimitive, Copy, Clone, Debug, PartialEq)]
#[repr(u8)]
pub enum BodyType {
Protobuf = 0,
}
#[cfg_attr(feature = "fuzz", derive(Arbitrary))]
#[derive(FromPrimitive, Copy, Clone, PartialEq, Debug, Hash, Eq)]
#[repr(u32)]
pub enum Opcode {
Ping = 1,
PsaGenerateKey = 2,
PsaDestroyKey = 3,
PsaSignHash = 4,
PsaVerifyHash = 5,
PsaImportKey = 6,
PsaExportPublicKey = 7,
ListProviders = 8,
ListOpcodes = 9,
PsaAsymmetricEncrypt = 10,
PsaAsymmetricDecrypt = 11,
PsaExportKey = 12,
PsaGenerateRandom = 13,
ListAuthenticators = 14,
PsaHashCompute = 15,
PsaHashCompare = 16,
PsaAeadEncrypt = 17,
PsaAeadDecrypt = 18,
PsaRawKeyAgreement = 19,
}
#[cfg_attr(feature = "fuzz", derive(Arbitrary))]
#[derive(FromPrimitive, PartialEq, Eq, Hash, Copy, Clone, Debug)]
#[repr(u8)]
pub enum AuthType {
NoAuth = 0,
Direct = 1,
JWT = 2,
PeerCredentials = 3,
}