pub struct CertificateRevocationList { /* private fields */ }展开描述
一个证书吊销列表(CRL)
§Example
extern crate rcgen;
use rcgen::*;
#[cfg(not(feature = "crypto"))]
struct MyKeyPair { public_key: Vec<u8> }
#[cfg(not(feature = "crypto"))]
impl SigningKey for MyKeyPair {
fn sign(&self, _: &[u8]) -> Result<Vec<u8>, rcgen::Error> { Ok(vec![]) }
}
#[cfg(not(feature = "crypto"))]
impl PublicKeyData for MyKeyPair {
fn der_bytes(&self) -> &[u8] { &self.public_key }
fn algorithm(&self) -> &'static SignatureAlgorithm { &PKCS_ED25519 }
}
// Generate a CRL issuer.
let mut issuer_params = CertificateParams::new(vec!["crl.issuer.example.com".to_string()]).unwrap();
issuer_params.serial_number = Some(SerialNumber::from(9999));
issuer_params.is_ca = IsCa::Ca(BasicConstraints::Unconstrained);
issuer_params.key_usages = vec![KeyUsagePurpose::KeyCertSign, KeyUsagePurpose::DigitalSignature, KeyUsagePurpose::CrlSign];
#[cfg(feature = "crypto")]
let key_pair = KeyPair::generate().unwrap();
#[cfg(not(feature = "crypto"))]
let key_pair = MyKeyPair { public_key: vec![] };
let issuer = Issuer::new(issuer_params, key_pair);
// Describe a revoked certificate.
let revoked_cert = RevokedCertParams{
serial_number: SerialNumber::from(9999),
revocation_time: date_time_ymd(2024, 06, 17),
reason_code: Some(RevocationReason::KeyCompromise),
invalidity_date: None,
};
// Create a CRL signed by the issuer, revoking revoked_cert.
let crl = CertificateRevocationListParams{
this_update: date_time_ymd(2023, 06, 17),
next_update: date_time_ymd(2024, 06, 17),
crl_number: SerialNumber::from(1234),
issuing_distribution_point: None,
revoked_certs: vec![revoked_cert],
#[cfg(feature = "crypto")]
key_identifier_method: KeyIdMethod::Sha256,
#[cfg(not(feature = "crypto"))]
key_identifier_method: KeyIdMethod::PreSpecified(vec![]),
}.signed_by(&issuer).unwrap();实现§
Source§impl CertificateRevocationList
impl CertificateRevocationList
Sourcepub fn der(&self) -> &CertificateRevocationListDer<'static>
pub fn der(&self) -> &CertificateRevocationListDer<'static>
获取该 CRL 的 DER 编码形式。
CertificateRevocationListDer 实现了 Deref<Target = [u8]> 与 AsRef<[u8]>,因此你可以轻松地从返回值中提取 DER 字节。
Trait 实现§
Source§impl Clone for CertificateRevocationList
impl Clone for CertificateRevocationList
Source§fn clone(&self) -> CertificateRevocationList
fn clone(&self) -> CertificateRevocationList
返回值的副本。 更多信息
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. 更多信息Source§impl Debug for CertificateRevocationList
impl Debug for CertificateRevocationList
Source§impl From<CertificateRevocationList> for CertificateRevocationListDer<'static>
impl From<CertificateRevocationList> for CertificateRevocationListDer<'static>
Source§fn from(crl: CertificateRevocationList) -> Self
fn from(crl: CertificateRevocationList) -> Self
从输入类型转换为此类型。
impl Eq for CertificateRevocationList
impl StructuralPartialEq for CertificateRevocationList
自动 Trait 实现§
impl Freeze for CertificateRevocationList
impl RefUnwindSafe for CertificateRevocationList
impl Send for CertificateRevocationList
impl Sync for CertificateRevocationList
impl Unpin for CertificateRevocationList
impl UnsafeUnpin for CertificateRevocationList
impl UnwindSafe for CertificateRevocationList
Blanket 实现§
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. 更多信息