#[non_exhaustive]pub enum SymmetricAlgorithm {
}
Expand description
The symmetric-key algorithms as defined in Section 9.3 of RFC 9580.
The values can be converted into and from their corresponding values of the serialized format.
Use SymmetricAlgorithm::from
to translate a numeric value to a
symbolic one.
§Examples
Use SymmetricAlgorithm
to set the preferred symmetric algorithms on a signature:
use sequoia_openpgp as openpgp;
use openpgp::packet::signature::SignatureBuilder;
use openpgp::types::{HashAlgorithm, SymmetricAlgorithm, SignatureType};
let mut builder = SignatureBuilder::new(SignatureType::DirectKey)
.set_hash_algo(HashAlgorithm::SHA512)
.set_preferred_symmetric_algorithms(vec![
SymmetricAlgorithm::AES256,
])?;
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Unencrypted
Null encryption.
IDEA
IDEA block cipher, deprecated in RFC 9580.
TripleDES
3-DES in EDE configuration, deprecated in RFC 9580.
CAST5
CAST5/CAST128 block cipher, deprecated in RFC 9580.
Blowfish
Schneier et.al. Blowfish block cipher.
AES128
10-round AES.
AES192
12-round AES.
AES256
14-round AES.
Twofish
Twofish block cipher.
Camellia128
18 rounds of NESSIEs Camellia.
Camellia192
24 rounds of NESSIEs Camellia w/192 bit keys.
Camellia256
24 rounds of NESSIEs Camellia w/256 bit keys.
Private(u8)
Private algorithm identifier.
Unknown(u8)
Unknown algorithm identifier.
Implementations§
Source§impl SymmetricAlgorithm
impl SymmetricAlgorithm
Sourcepub fn variants() -> impl Iterator<Item = Self>
pub fn variants() -> impl Iterator<Item = Self>
Returns an iterator over all valid variants.
Returns an iterator over all known variants. This does not
include the SymmetricAlgorithm::Unencrypted
,
SymmetricAlgorithm::Private
, or
SymmetricAlgorithm::Unknown
variants.
Sourcepub fn is_supported(&self) -> bool
pub fn is_supported(&self) -> bool
Returns whether this algorithm is supported by the crypto backend.
All backends support all the AES variants.
§Examples
use sequoia_openpgp as openpgp;
use openpgp::types::SymmetricAlgorithm;
assert!(SymmetricAlgorithm::AES256.is_supported());
assert!(SymmetricAlgorithm::TripleDES.is_supported());
assert!(!SymmetricAlgorithm::Unencrypted.is_supported());
assert!(!SymmetricAlgorithm::Private(101).is_supported());
Sourcepub fn key_size(self) -> Result<usize>
pub fn key_size(self) -> Result<usize>
Length of a key for this algorithm in bytes.
Fails if the algorithm isn’t known to Sequoia.
Sourcepub fn block_size(self) -> Result<usize>
pub fn block_size(self) -> Result<usize>
Length of a block for this algorithm in bytes.
Fails if the algorithm isn’t known to Sequoia.
Trait Implementations§
Source§impl Clone for SymmetricAlgorithm
impl Clone for SymmetricAlgorithm
Source§fn clone(&self) -> SymmetricAlgorithm
fn clone(&self) -> SymmetricAlgorithm
1.0.0 · Source§const fn clone_from(&mut self, source: &Self)
const fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for SymmetricAlgorithm
impl Debug for SymmetricAlgorithm
Source§impl Default for SymmetricAlgorithm
impl Default for SymmetricAlgorithm
Source§impl Display for SymmetricAlgorithm
Formats the symmetric algorithm name.
impl Display for SymmetricAlgorithm
Formats the symmetric algorithm name.
There are two ways the symmetric algorithm name can be formatted. By default the short name is used. The alternate format uses the full algorithm name.
§Examples
use sequoia_openpgp as openpgp;
use openpgp::types::SymmetricAlgorithm;
// default, short format
assert_eq!("AES-128", format!("{}", SymmetricAlgorithm::AES128));
// alternate, long format
assert_eq!("AES with 128-bit key", format!("{:#}", SymmetricAlgorithm::AES128));