pub struct EncryptionKey<CS: CipherSuite> { /* private fields */ }Expand description
The Device Encryption Key.
Implementations§
Source§impl<CS: CipherSuite> EncryptionKey<CS>
impl<CS: CipherSuite> EncryptionKey<CS>
Source§impl<CS: CipherSuite> EncryptionKey<CS>
impl<CS: CipherSuite> EncryptionKey<CS>
Sourcepub fn id(&self) -> Result<EncryptionKeyId, IdError>
pub fn id(&self) -> Result<EncryptionKeyId, IdError>
Uniquely identifies the EncryptionKey
Two keys with the same ID are the same key.
Sourcepub fn public(&self) -> Result<EncryptionPublicKey<CS>, PkError>
pub fn public(&self) -> Result<EncryptionPublicKey<CS>, PkError>
Returns the public half of the key.
Source§impl<CS: CipherSuite> EncryptionKey<CS>
impl<CS: CipherSuite> EncryptionKey<CS>
Sourcepub fn open_group_key(
&self,
enc: &Encap<CS>,
ciphertext: EncryptedGroupKey<CS>,
group: GroupId,
) -> Result<GroupKey<CS>, Error>
pub fn open_group_key( &self, enc: &Encap<CS>, ciphertext: EncryptedGroupKey<CS>, group: GroupId, ) -> Result<GroupKey<CS>, Error>
Decrypts and authenticates a GroupKey received from
a peer.
Source§impl<CS: CipherSuite> EncryptionKey<CS>
impl<CS: CipherSuite> EncryptionKey<CS>
Sourcepub fn seal_psk_seed<R: Csprng>(
&self,
rng: &mut R,
seed: &PskSeed<CS>,
peer_pk: &EncryptionPublicKey<CS>,
group: &GroupId,
) -> Result<(Encap<CS>, EncryptedPskSeed<CS>), Error>
Available on crate feature tls only.
pub fn seal_psk_seed<R: Csprng>( &self, rng: &mut R, seed: &PskSeed<CS>, peer_pk: &EncryptionPublicKey<CS>, group: &GroupId, ) -> Result<(Encap<CS>, EncryptedPskSeed<CS>), Error>
tls only.Uses self to encrypt and authenticate the PskSeed
such that it can only be decrypted by the holder of the
private half of peer_pk.
It is an error if pk is the public key for self.
Sourcepub fn open_psk_seed(
&self,
encap: &Encap<CS>,
ciphertext: EncryptedPskSeed<CS>,
peer_pk: &EncryptionPublicKey<CS>,
group: &GroupId,
) -> Result<PskSeed<CS>, Error>
Available on crate feature tls only.
pub fn open_psk_seed( &self, encap: &Encap<CS>, ciphertext: EncryptedPskSeed<CS>, peer_pk: &EncryptionPublicKey<CS>, group: &GroupId, ) -> Result<PskSeed<CS>, Error>
tls only.Uses self to decrypt and authenticate a PskSeed
that was encrypted by peer_pk.
Trait Implementations§
Source§impl<CS: CipherSuite> Clone for EncryptionKey<CS>
impl<CS: CipherSuite> Clone for EncryptionKey<CS>
Source§impl<CS: CipherSuite> ConstantTimeEq for EncryptionKey<CS>
impl<CS: CipherSuite> ConstantTimeEq for EncryptionKey<CS>
Source§impl<CS: CipherSuite> Debug for EncryptionKey<CS>
impl<CS: CipherSuite> Debug for EncryptionKey<CS>
Source§impl<CS: CipherSuite> Display for EncryptionKey<CS>
impl<CS: CipherSuite> Display for EncryptionKey<CS>
Source§impl<CS: CipherSuite> Identified for EncryptionKey<CS>
impl<CS: CipherSuite> Identified for EncryptionKey<CS>
Source§impl<CS: CipherSuite> UnwrappedKey<CS> for EncryptionKey<CS>
impl<CS: CipherSuite> UnwrappedKey<CS> for EncryptionKey<CS>
Source§fn into_secret(self) -> Secret<CS>
fn into_secret(self) -> Secret<CS>
Converts itself into the underlying
Secret.Source§fn try_from_secret(key: UnwrappedSecret<CS>) -> Result<Self, WrongKeyType>
fn try_from_secret(key: UnwrappedSecret<CS>) -> Result<Self, WrongKeyType>
Converts itself from a
UnwrappedSecret.impl<CS: CipherSuite> ZeroizeOnDrop for EncryptionKey<CS>
Auto Trait Implementations§
impl<CS> !Freeze for EncryptionKey<CS>
impl<CS> !RefUnwindSafe for EncryptionKey<CS>
impl<CS> Send for EncryptionKey<CS>
impl<CS> !Sync for EncryptionKey<CS>
impl<CS> Unpin for EncryptionKey<CS>
impl<CS> UnwindSafe for EncryptionKey<CS>
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out indicating that a T is niched.