pub struct Certificate { /* private fields */ }
Expand description
OpenSSH certificate as specified in PROTOCOL.certkeys.
OpenSSH supports X.509-like certificate authorities, but using a custom encoding format.
§⚠️ Security Warning
Certificates must be validated before they can be trusted!
The Certificate
type does not automatically perform validation checks
and supports parsing certificates which may potentially be invalid.
Just because a Certificate
parses successfully does not mean that it
can be trusted.
See “Certificate Validation” documentation below for more information on how to properly validate certificates.
§Certificate Validation
For a certificate to be trusted, the following properties MUST be validated:
- Certificate is signed by a trusted certificate authority (CA)
- Signature over the certificate verifies successfully
- Current time is within the certificate’s validity window
- Certificate authorizes the expected principal
- All critical extensions to the certificate are recognized and validate successfully.
The Certificate::validate
and Certificate::validate_at
methods can
be used to validate a certificate.
§Example
The following example walks through how to implement the steps outlined above for validating a certificate:
use ssh_key::{Certificate, Fingerprint};
use std::str::FromStr;
// List of trusted certificate authority (CA) fingerprints
let ca_fingerprints = [
Fingerprint::from_str("SHA256:JQ6FV0rf7qqJHZqIj4zNH8eV0oB8KLKh9Pph3FTD98g")?
];
// Certificate to be validated
let certificate = Certificate::from_str(
"ssh-ed25519-cert-v01@openssh.com AAAAIHNzaC1lZDI1NTE5LWNlcnQtdjAxQG9wZW5zc2guY29tAAAAIE7x9ln6uZLLkfXM8iatrnAAuytVHeCznU8VlEgx7TvLAAAAILM+rvN+ot98qgEN796jTiQfZfG1KaT0PtFDJ/XFSqtiAAAAAAAAAAAAAAABAAAAFGVkMjU1MTktd2l0aC1wMjU2LWNhAAAAAAAAAABiUZm7AAAAAPTaMrsAAAAAAAAAggAAABVwZXJtaXQtWDExLWZvcndhcmRpbmcAAAAAAAAAF3Blcm1pdC1hZ2VudC1mb3J3YXJkaW5nAAAAAAAAABZwZXJtaXQtcG9ydC1mb3J3YXJkaW5nAAAAAAAAAApwZXJtaXQtcHR5AAAAAAAAAA5wZXJtaXQtdXNlci1yYwAAAAAAAAAAAAAAaAAAABNlY2RzYS1zaGEyLW5pc3RwMjU2AAAACG5pc3RwMjU2AAAAQQR8H9hzDOU0V76NkkCY7DZIgw+SqoojY6xlb91FIfpjE+UR8YkbTp5ar44ULQatFaZqQlfz8FHYTooOL5G6gHBHAAAAZAAAABNlY2RzYS1zaGEyLW5pc3RwMjU2AAAASQAAACEA/0Cwxhkac5AeNYE958j8GgvmkIESDH1TE7QYIqxsFsIAAAAgTEw8WVjlz8AnvyaKGOUELMpyFFJagtD2JFAIAJvilrc= user@example.com"
)?;
// Perform basic certificate validation, ensuring that the certificate is
// signed by a trusted certificate authority (CA) and checking that the
// current system clock time is within the certificate's validity window
certificate.validate(&ca_fingerprints)?;
// Check that the certificate includes the expected principal name
// (i.e. username or hostname)
// if !certificate.principals().contains(expected_principal) { return Err(...) }
// Check that all of the critical extensions are recognized
// if !certificate.critical_options.iter().all(|critical| ...) { return Err(...) }
// If we've made it this far, the certificate can be trusted
Ok(())
§Certificate Builder (SSH CA support)
This crate implements all of the functionality needed for a pure Rust SSH certificate authority which can build and sign OpenSSH certificates.
See the Builder
type’s documentation for more information.
§serde
support
When the serde
feature of this crate is enabled, this type receives impls
of [Deserialize
][serde::Deserialize
] and [Serialize
][serde::Serialize
].
The serialization uses a binary encoding with binary formats like bincode and CBOR, and the OpenSSH string serialization when used with human-readable formats like JSON and TOML.
Implementations§
Source§impl Certificate
impl Certificate
Sourcepub fn from_openssh(certificate_str: &str) -> Result<Self>
pub fn from_openssh(certificate_str: &str) -> Result<Self>
Parse an OpenSSH-formatted certificate.
OpenSSH-formatted certificates look like the following
(i.e. similar to OpenSSH public keys with -cert-v01@openssh.com
):
ssh-ed25519-cert-v01@openssh.com AAAAIHNzaC1lZDI1NTE5LWNlc...8REbCaAw== user@example.com
Sourcepub fn from_bytes(bytes: &[u8]) -> Result<Self>
pub fn from_bytes(bytes: &[u8]) -> Result<Self>
Parse a raw binary OpenSSH certificate.
Sourcepub fn to_openssh(&self) -> Result<String>
pub fn to_openssh(&self) -> Result<String>
Encode OpenSSH certificate to a String
.
Sourcepub fn write_file(&self, path: &Path) -> Result<()>
pub fn write_file(&self, path: &Path) -> Result<()>
Write OpenSSH certificate to a file.
Sourcepub fn nonce(&self) -> &[u8] ⓘ
pub fn nonce(&self) -> &[u8] ⓘ
Nonces are a CA-provided random bitstring of arbitrary length (but typically 16 or 32 bytes).
It’s included to make attacks that depend on inducing collisions in the signature hash infeasible.
Sourcepub fn public_key(&self) -> &KeyData
pub fn public_key(&self) -> &KeyData
Get this certificate’s public key data.
Sourcepub fn serial(&self) -> u64
pub fn serial(&self) -> u64
Optional certificate serial number set by the CA to provide an abbreviated way to refer to certificates from that CA.
If a CA does not wish to number its certificates, it must set this field to zero.
Sourcepub fn cert_type(&self) -> CertType
pub fn cert_type(&self) -> CertType
Specifies whether this certificate is for identification of a user or a host.
Sourcepub fn key_id(&self) -> &str
pub fn key_id(&self) -> &str
Key IDs are a free-form text field that is filled in by the CA at the time of signing.
The intention is that the contents of this field are used to identify the identity principal in log messages.
Sourcepub fn valid_principals(&self) -> &[String]
pub fn valid_principals(&self) -> &[String]
List of zero or more principals which this certificate is valid for.
Principals are hostnames for host certificates and usernames for user certificates.
As a special case, a zero-length “valid principals” field means the certificate is valid for any principal of the specified type.
Sourcepub fn valid_after(&self) -> u64
pub fn valid_after(&self) -> u64
Valid after (Unix time).
Sourcepub fn valid_before(&self) -> u64
pub fn valid_before(&self) -> u64
Valid before (Unix time).
Sourcepub fn valid_after_time(&self) -> SystemTime
pub fn valid_after_time(&self) -> SystemTime
Valid after (system time).
Sourcepub fn valid_before_time(&self) -> SystemTime
pub fn valid_before_time(&self) -> SystemTime
Valid before (system time).
Sourcepub fn critical_options(&self) -> &OptionsMap
pub fn critical_options(&self) -> &OptionsMap
The critical options section of the certificate specifies zero or more options on the certificate’s validity.
Each named option may only appear once in a certificate.
All options are “critical”; if an implementation does not recognize an option, then the validating party should refuse to accept the certificate.
Sourcepub fn extensions(&self) -> &OptionsMap
pub fn extensions(&self) -> &OptionsMap
The extensions section of the certificate specifies zero or more non-critical certificate extensions.
If an implementation does not recognise an extension, then it should ignore it.
Sourcepub fn signature_key(&self) -> &KeyData
pub fn signature_key(&self) -> &KeyData
Signature key of signing CA.
Sourcepub fn signature(&self) -> &Signature
pub fn signature(&self) -> &Signature
Signature computed over all preceding fields from the initial string up to, and including the signature key.
Sourcepub fn validate<'a, I>(&self, ca_fingerprints: I) -> Result<()>where
I: IntoIterator<Item = &'a Fingerprint>,
pub fn validate<'a, I>(&self, ca_fingerprints: I) -> Result<()>where
I: IntoIterator<Item = &'a Fingerprint>,
Perform certificate validation using the system clock to check that the current time is within the certificate’s validity window.
§⚠️ Security Warning: Some Assembly Required
See Certificate::validate_at
documentation for important notes on
how to properly validate certificates!
Sourcepub fn validate_at<'a, I>(
&self,
unix_timestamp: u64,
ca_fingerprints: I,
) -> Result<()>where
I: IntoIterator<Item = &'a Fingerprint>,
pub fn validate_at<'a, I>(
&self,
unix_timestamp: u64,
ca_fingerprints: I,
) -> Result<()>where
I: IntoIterator<Item = &'a Fingerprint>,
Perform certificate validation.
Checks for the following:
- Specified Unix timestamp is within the certificate’s valid range
- Certificate’s signature validates against the public key included in the certificate
- Fingerprint of the public key included in the certificate matches one
of the trusted certificate authority (CA) fingerprints provided in
the
ca_fingerprints
parameter.
NOTE: only SHA-256 fingerprints are supported at this time.
§⚠️ Security Warning: Some Assembly Required
This method does not perform the full set of validation checks needed to determine if a certificate is to be trusted.
If this method succeeds, the following properties still need to be checked to ensure the certificate is valid:
valid_principals
is empty or contains the expected principalcritical_options
is empty or contains only options which are recognized, and that the recognized options are all valid
§Returns
Ok
if the certificate validated successfullyError::CertificateValidation
if the certificate failed to validate
Trait Implementations§
Source§impl Clone for Certificate
impl Clone for Certificate
Source§fn clone(&self) -> Certificate
fn clone(&self) -> Certificate
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more