pub struct SignedSecretKey {
pub primary_key: SecretKey,
pub details: SignedKeyDetails,
pub public_subkeys: Vec<SignedPublicSubKey>,
pub secret_subkeys: Vec<SignedSecretSubKey>,
}
Expand description
Represents a secret signed PGP key.
Fields§
§primary_key: SecretKey
§details: SignedKeyDetails
§public_subkeys: Vec<SignedPublicSubKey>
§secret_subkeys: Vec<SignedSecretSubKey>
Implementations§
Source§impl SignedSecretKey
impl SignedSecretKey
pub fn new( primary_key: SecretKey, details: SignedKeyDetails, public_subkeys: Vec<SignedPublicSubKey>, secret_subkeys: Vec<SignedSecretSubKey>, ) -> Self
Sourcepub fn expires_at(&self) -> Option<DateTime<Utc>>
pub fn expires_at(&self) -> Option<DateTime<Utc>>
Get the secret key expiration as a date.
pub fn verify(&self) -> Result<()>
pub fn to_armored_writer( &self, writer: &mut impl Write, opts: ArmorOptions<'_>, ) -> Result<()>
pub fn to_armored_bytes(&self, opts: ArmorOptions<'_>) -> Result<Vec<u8>>
pub fn to_armored_string(&self, opts: ArmorOptions<'_>) -> Result<String>
Trait Implementations§
Source§impl Clone for SignedSecretKey
impl Clone for SignedSecretKey
Source§fn clone(&self) -> SignedSecretKey
fn clone(&self) -> SignedSecretKey
Returns a duplicate 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 SignedSecretKey
impl Debug for SignedSecretKey
Source§impl Deserializable for SignedSecretKey
impl Deserializable for SignedSecretKey
Source§fn from_packets<'a, I: Iterator<Item = Result<Packet>> + 'a>(
packets: Peekable<I>,
) -> Box<dyn Iterator<Item = Result<Self>> + 'a>
fn from_packets<'a, I: Iterator<Item = Result<Packet>> + 'a>( packets: Peekable<I>, ) -> Box<dyn Iterator<Item = Result<Self>> + 'a>
Parse a transferable key from packets. Ref: https://www.rfc-editor.org/rfc/rfc9580.html#name-transferable-secret-keys
Source§fn matches_block_type(typ: BlockType) -> bool
fn matches_block_type(typ: BlockType) -> bool
Check if the given typ is a valid block type for this type.
Source§fn from_bytes(bytes: impl Read) -> Result<Self>
fn from_bytes(bytes: impl Read) -> Result<Self>
Parse a single byte encoded composition.
Source§fn from_string(input: &str) -> Result<(Self, Headers)>
fn from_string(input: &str) -> Result<(Self, Headers)>
Parse a single armor encoded composition.
Source§fn from_string_many<'a>(
input: &'a str,
) -> Result<(Box<dyn Iterator<Item = Result<Self>> + 'a>, Headers)>
fn from_string_many<'a>( input: &'a str, ) -> Result<(Box<dyn Iterator<Item = Result<Self>> + 'a>, Headers)>
Parse an armor encoded list of compositions.
Source§fn from_armor_many<'a, R: Read + 'a>(
input: R,
) -> Result<(Box<dyn Iterator<Item = Result<Self>> + 'a>, Headers)>
fn from_armor_many<'a, R: Read + 'a>( input: R, ) -> Result<(Box<dyn Iterator<Item = Result<Self>> + 'a>, Headers)>
Armored ascii data.
fn from_armor_many_buf<'a, R: BufRead + 'a>( input: R, ) -> Result<(Box<dyn Iterator<Item = Result<Self>> + 'a>, Headers)>
Source§fn from_bytes_many<'a>(
bytes: impl Read + 'a,
) -> Box<dyn Iterator<Item = Result<Self>> + 'a>
fn from_bytes_many<'a>( bytes: impl Read + 'a, ) -> Box<dyn Iterator<Item = Result<Self>> + 'a>
Parse a list of compositions in raw byte format.
Source§fn from_reader_single<'a, R: Read + 'a>(
input: R,
) -> Result<(Self, Option<Headers>)>
fn from_reader_single<'a, R: Read + 'a>( input: R, ) -> Result<(Self, Option<Headers>)>
Parses a single composition, from either ASCII-armored or binary OpenPGP data. Read more
fn from_reader_single_buf<'a, R: BufRead + 'a>( input: R, ) -> Result<(Self, Option<Headers>)>
Source§impl From<SignedSecretKey> for SignedPublicKey
impl From<SignedSecretKey> for SignedPublicKey
Source§fn from(value: SignedSecretKey) -> Self
fn from(value: SignedSecretKey) -> Self
Converts to this type from the input type.
Source§impl PartialEq for SignedSecretKey
impl PartialEq for SignedSecretKey
Source§impl PublicKeyTrait for SignedSecretKey
impl PublicKeyTrait for SignedSecretKey
Source§fn fingerprint(&self) -> Fingerprint
fn fingerprint(&self) -> Fingerprint
Returns the fingerprint of the associated primary key.
Source§fn verify_signature(
&self,
hash: HashAlgorithm,
data: &[u8],
sig: &SignatureBytes,
) -> Result<()>
fn verify_signature( &self, hash: HashAlgorithm, data: &[u8], sig: &SignatureBytes, ) -> Result<()>
Verify a signed message.
Data will be hashed using
hash
, before verifying.Source§fn encrypt<R: Rng + CryptoRng>(
&self,
rng: R,
plain: &[u8],
typ: EskType,
) -> Result<PkeskBytes>
fn encrypt<R: Rng + CryptoRng>( &self, rng: R, plain: &[u8], typ: EskType, ) -> Result<PkeskBytes>
Encrypt the given
plain
for this key.Source§fn serialize_for_hashing(&self, writer: &mut impl Write) -> Result<()>
fn serialize_for_hashing(&self, writer: &mut impl Write) -> Result<()>
This is the data used for hashing in a signature. Only uses the public portion of the key.
fn public_params(&self) -> &PublicParams
fn version(&self) -> KeyVersion
fn algorithm(&self) -> PublicKeyAlgorithm
fn created_at(&self) -> &DateTime<Utc>
fn expiration(&self) -> Option<u16>
fn is_signing_key(&self) -> bool
fn is_encryption_key(&self) -> bool
Source§impl SecretKeyTrait for SignedSecretKey
impl SecretKeyTrait for SignedSecretKey
type PublicKey = PublicKey
Source§type Unlocked = SecretKeyRepr
type Unlocked = SecretKeyRepr
The type representing the unlocked version of this.
Source§fn unlock<F, G, T>(&self, pw: F, work: G) -> Result<T>
fn unlock<F, G, T>(&self, pw: F, work: G) -> Result<T>
Unlock the raw data in the secret parameters.
fn create_signature<F>( &self, key_pw: F, hash: HashAlgorithm, data: &[u8], ) -> Result<SignatureBytes>
fn public_key(&self) -> Self::PublicKey
Source§fn hash_alg(&self) -> HashAlgorithm
fn hash_alg(&self) -> HashAlgorithm
The suggested hash algorithm to calculate the signature hash digest with, when using this
key as a signer
Source§impl Serialize for SignedSecretKey
impl Serialize for SignedSecretKey
impl Eq for SignedSecretKey
impl StructuralPartialEq for SignedSecretKey
Auto Trait Implementations§
impl Freeze for SignedSecretKey
impl RefUnwindSafe for SignedSecretKey
impl Send for SignedSecretKey
impl Sync for SignedSecretKey
impl Unpin for SignedSecretKey
impl UnwindSafe for SignedSecretKey
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