Enum biscuit::jwa::ContentEncryptionAlgorithm
source · pub enum ContentEncryptionAlgorithm {
A128CBC_HS256,
A192CBC_HS384,
A256CBC_HS512,
A128GCM,
A192GCM,
A256GCM,
}
Expand description
Algorithms meant for content encryption. See RFC7518#5
Variants§
A128CBC_HS256
AES_128_CBC_HMAC_SHA_256 authenticated encryption algorithm enc
A192CBC_HS384
AES_192_CBC_HMAC_SHA_384 authenticated encryption algorithm enc
A256CBC_HS512
AES_256_CBC_HMAC_SHA_512 authenticated encryption algorithm enc
A128GCM
AES GCM using 128-bit key
A192GCM
AES GCM using 192-bit key
This is not supported by ring
.
A256GCM
AES GCM using 256-bit key
Implementations§
source§impl ContentEncryptionAlgorithm
impl ContentEncryptionAlgorithm
sourcepub fn generate_key(self) -> Result<Vec<u8>, Error>
pub fn generate_key(self) -> Result<Vec<u8>, Error>
Convenience function to generate a new random key with the required length
sourcepub fn encrypt<T: Serialize + DeserializeOwned>(
self,
payload: &[u8],
aad: &[u8],
key: &JWK<T>,
options: &EncryptionOptions
) -> Result<EncryptionResult, Error>
pub fn encrypt<T: Serialize + DeserializeOwned>( self, payload: &[u8], aad: &[u8], key: &JWK<T>, options: &EncryptionOptions ) -> Result<EncryptionResult, Error>
Encrypt some payload with the provided algorithm
sourcepub fn decrypt<T: Serialize + DeserializeOwned>(
self,
encrypted: &EncryptionResult,
key: &JWK<T>
) -> Result<Vec<u8>, Error>
pub fn decrypt<T: Serialize + DeserializeOwned>( self, encrypted: &EncryptionResult, key: &JWK<T> ) -> Result<Vec<u8>, Error>
Decrypt some payload with the provided algorithm
Trait Implementations§
source§impl Clone for ContentEncryptionAlgorithm
impl Clone for ContentEncryptionAlgorithm
source§fn clone(&self) -> ContentEncryptionAlgorithm
fn clone(&self) -> ContentEncryptionAlgorithm
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 Debug for ContentEncryptionAlgorithm
impl Debug for ContentEncryptionAlgorithm
source§impl Default for ContentEncryptionAlgorithm
impl Default for ContentEncryptionAlgorithm
source§fn default() -> ContentEncryptionAlgorithm
fn default() -> ContentEncryptionAlgorithm
Returns the “default value” for a type. Read more
source§impl<'de> Deserialize<'de> for ContentEncryptionAlgorithm
impl<'de> Deserialize<'de> for ContentEncryptionAlgorithm
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where __D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
source§impl PartialEq for ContentEncryptionAlgorithm
impl PartialEq for ContentEncryptionAlgorithm
source§fn eq(&self, other: &ContentEncryptionAlgorithm) -> bool
fn eq(&self, other: &ContentEncryptionAlgorithm) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.impl Copy for ContentEncryptionAlgorithm
impl Eq for ContentEncryptionAlgorithm
impl StructuralEq for ContentEncryptionAlgorithm
impl StructuralPartialEq for ContentEncryptionAlgorithm
Auto Trait Implementations§
impl RefUnwindSafe for ContentEncryptionAlgorithm
impl Send for ContentEncryptionAlgorithm
impl Sync for ContentEncryptionAlgorithm
impl Unpin for ContentEncryptionAlgorithm
impl UnwindSafe for ContentEncryptionAlgorithm
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
§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Checks if this value is equivalent to the given key. Read more
§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.