CryptoApi

Struct CryptoApi 

Source
pub struct CryptoApi<P: CheckedPermissions> { /* private fields */ }

Implementations§

Source§

impl<P: ShaPermissions> CryptoApi<P>

Source

pub fn sha2(&self, data: &[u8], algo: ShaAlgo) -> Result<Vec<u8>, CryptoError>

Permission: none

Source

pub fn sha224(&self, data: &[u8]) -> Result<[u8; 28], CryptoError>

Permission: none

Source

pub fn sha256(&self, data: &[u8]) -> Result<[u8; 32], CryptoError>

Permission: none

Source

pub fn sha384(&self, data: &[u8]) -> Result<[u8; 48], CryptoError>

Permission: none

Source

pub fn sha512(&self, data: &[u8]) -> Result<[u8; 64], CryptoError>

Permission: none

Source

pub fn sha_init(&self, algo: ShaAlgo) -> ShaStreamingContext<P>

Permission: none

Source

pub fn sha256_init(&self) -> ShaStreamingContext<P>

Permission: none

Source§

impl<P: CheckedPermissions> CryptoApi<P>

Source

pub fn setup_aes( &self, key: &[u8], mode: AesMode, ) -> Result<AesContext<P>, CryptoError>
where P: MessageAllowed<AesSetup> + MessageAllowed<AesClear>,

  • Permission: os/crypto / AesSetup

    Groups: cryptography.primitives

    Sender policy: signed

    Grant timing: install-review

  • Permission: os/crypto / AesClear

    Groups: cryptography.primitives

    Sender policy: signed

    Grant timing: install-review

Source

pub fn hmac224( &self, key: Vec<u8>, data: Vec<u8>, ) -> Result<Vec<u8>, CryptoError>
where P: MessageAllowed<Hmac>,

Permission: os/crypto / Hmac

Groups: cryptography.primitives

Sender policy: signed

Grant timing: install-review

Source

pub fn hmac256( &self, key: Vec<u8>, data: Vec<u8>, ) -> Result<Vec<u8>, CryptoError>
where P: MessageAllowed<Hmac>,

Permission: os/crypto / Hmac

Groups: cryptography.primitives

Sender policy: signed

Grant timing: install-review

Source

pub fn hmac384( &self, key: Vec<u8>, data: Vec<u8>, ) -> Result<Vec<u8>, CryptoError>
where P: MessageAllowed<Hmac>,

Permission: os/crypto / Hmac

Groups: cryptography.primitives

Sender policy: signed

Grant timing: install-review

Source

pub fn hmac512( &self, key: Vec<u8>, data: Vec<u8>, ) -> Result<Vec<u8>, CryptoError>
where P: MessageAllowed<Hmac>,

Permission: os/crypto / Hmac

Groups: cryptography.primitives

Sender policy: signed

Grant timing: install-review

Source

pub fn split_secret( &self, secret: Vec<u8>, num_shares: usize, threshold: usize, ) -> Result<Vec<Vec<u8>>, ShamirError>
where P: MessageAllowed<ShamirSplit>,

Permission: os/crypto / ShamirSplit

Groups: cryptography.secret-sharing

Sender policy: signed

Grant timing: grant-on-each-use

Source

pub fn recover_secret( &self, indexes: Vec<usize>, shares: Vec<Vec<u8>>, ) -> Result<Vec<u8>, ShamirError>
where P: MessageAllowed<ShamirRecover>,

Permission: os/crypto / ShamirRecover

Groups: cryptography.secret-sharing

Sender policy: signed

Grant timing: grant-on-each-use

Trait Implementations§

Source§

impl<P: Default + CheckedPermissions> Default for CryptoApi<P>

Source§

fn default() -> CryptoApi<P>

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl<P> Freeze for CryptoApi<P>

§

impl<P> RefUnwindSafe for CryptoApi<P>

§

impl<P> Send for CryptoApi<P>

§

impl<P> Sync for CryptoApi<P>

§

impl<P> Unpin for CryptoApi<P>

§

impl<P> UnwindSafe for CryptoApi<P>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> ArchivePointee for T

§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> LayoutRaw for T

§

fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>

Returns the layout of the type.
§

impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
where T: SharedNiching<N1, N2>, N1: Niching<T>, N2: Niching<T>,

§

unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool

Returns whether the given value has been niched. Read more
§

fn resolve_niched(out: Place<NichedOption<T, N1>>)

Writes data to out indicating that a T is niched.
§

impl<T> Pointee for T

§

type Metadata = ()

The metadata type for pointers and references to this type.
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.