Struct cosmian_findex::EncryptedValue
source · pub struct EncryptedValue<const VALUE_LENGTH: usize> {
pub ciphertext: [u8; VALUE_LENGTH],
pub tag: [u8; 16],
pub nonce: Nonce<NONCE_LENGTH>,
}
Expand description
Value stored inside the EDX. It is composed of:
- a AESGCM-256 ciphertext;
- a nonce;
- a MAC tag.
TODO: the nonce used to encrypt the values should be derived from the token to avoid storing yet another random value.
Fields§
§ciphertext: [u8; VALUE_LENGTH]
§tag: [u8; 16]
§nonce: Nonce<NONCE_LENGTH>
Implementations§
source§impl<const VALUE_LENGTH: usize> EncryptedValue<VALUE_LENGTH>
impl<const VALUE_LENGTH: usize> EncryptedValue<VALUE_LENGTH>
pub const LENGTH: usize = _
sourcepub fn encrypt(
rng: &mut impl CryptoRngCore,
key: &SymmetricKey<SYM_KEY_LENGTH>,
value: [u8; VALUE_LENGTH]
) -> Result<Self, CoreError>
pub fn encrypt( rng: &mut impl CryptoRngCore, key: &SymmetricKey<SYM_KEY_LENGTH>, value: [u8; VALUE_LENGTH] ) -> Result<Self, CoreError>
Encrypts the value using the given key.
sourcepub fn decrypt(
&self,
key: &SymmetricKey<SYM_KEY_LENGTH>
) -> Result<[u8; VALUE_LENGTH], CoreError>
pub fn decrypt( &self, key: &SymmetricKey<SYM_KEY_LENGTH> ) -> Result<[u8; VALUE_LENGTH], CoreError>
Decrypts the value using the given key.
Trait Implementations§
source§impl<const VALUE_LENGTH: usize> Clone for EncryptedValue<VALUE_LENGTH>
impl<const VALUE_LENGTH: usize> Clone for EncryptedValue<VALUE_LENGTH>
source§fn clone(&self) -> EncryptedValue<VALUE_LENGTH>
fn clone(&self) -> EncryptedValue<VALUE_LENGTH>
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl<const VALUE_LENGTH: usize> Debug for EncryptedValue<VALUE_LENGTH>
impl<const VALUE_LENGTH: usize> Debug for EncryptedValue<VALUE_LENGTH>
source§impl<const LENGTH: usize> Display for EncryptedValue<LENGTH>
impl<const LENGTH: usize> Display for EncryptedValue<LENGTH>
source§impl<const VALUE_LENGTH: usize> From<&EncryptedValue<VALUE_LENGTH>> for Vec<u8>
impl<const VALUE_LENGTH: usize> From<&EncryptedValue<VALUE_LENGTH>> for Vec<u8>
source§fn from(value: &EncryptedValue<VALUE_LENGTH>) -> Self
fn from(value: &EncryptedValue<VALUE_LENGTH>) -> Self
Converts to this type from the input type.
source§impl<const VALUE_LENGTH: usize> PartialEq for EncryptedValue<VALUE_LENGTH>
impl<const VALUE_LENGTH: usize> PartialEq for EncryptedValue<VALUE_LENGTH>
source§fn eq(&self, other: &EncryptedValue<VALUE_LENGTH>) -> bool
fn eq(&self, other: &EncryptedValue<VALUE_LENGTH>) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.impl<const VALUE_LENGTH: usize> Eq for EncryptedValue<VALUE_LENGTH>
impl<const VALUE_LENGTH: usize> StructuralEq for EncryptedValue<VALUE_LENGTH>
impl<const VALUE_LENGTH: usize> StructuralPartialEq for EncryptedValue<VALUE_LENGTH>
Auto Trait Implementations§
impl<const VALUE_LENGTH: usize> RefUnwindSafe for EncryptedValue<VALUE_LENGTH>
impl<const VALUE_LENGTH: usize> Send for EncryptedValue<VALUE_LENGTH>
impl<const VALUE_LENGTH: usize> Sync for EncryptedValue<VALUE_LENGTH>
impl<const VALUE_LENGTH: usize> Unpin for EncryptedValue<VALUE_LENGTH>
impl<const VALUE_LENGTH: usize> UnwindSafe for EncryptedValue<VALUE_LENGTH>
Blanket Implementations§
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