add support for rfc822Name (email) and uniformResourceIdentifier (uri) to GeneralName
This commit is contained in:
parent
9943bb6869
commit
60337266ab
|
|
@ -1090,10 +1090,10 @@ foreign_type_and_impl_send_sync! {
|
|||
}
|
||||
|
||||
impl GeneralNameRef {
|
||||
/// Returns the contents of this `GeneralName` if it is a `dNSName`.
|
||||
pub fn dnsname(&self) -> Option<&str> {
|
||||
|
||||
fn ia5_string(&self, ffi_type: c_int) -> Option<&str> {
|
||||
unsafe {
|
||||
if (*self.as_ptr()).type_ != ffi::GEN_DNS {
|
||||
if (*self.as_ptr()).type_ != ffi_type {
|
||||
return None;
|
||||
}
|
||||
|
||||
|
|
@ -1101,13 +1101,28 @@ impl GeneralNameRef {
|
|||
let len = ffi::ASN1_STRING_length((*self.as_ptr()).d as *mut _);
|
||||
|
||||
let slice = slice::from_raw_parts(ptr as *const u8, len as usize);
|
||||
// dNSNames are stated to be ASCII (specifically IA5). Hopefully
|
||||
// IA5Strings are stated to be ASCII (specifically IA5). Hopefully
|
||||
// OpenSSL checks that when loading a certificate but if not we'll
|
||||
// use this instead of from_utf8_unchecked just in case.
|
||||
str::from_utf8(slice).ok()
|
||||
}
|
||||
}
|
||||
|
||||
/// Returns the contents of this `GeneralName` if it is an `rfc822Name`.
|
||||
pub fn email(&self) -> Option<&str> {
|
||||
self.ia5_string(ffi::GEN_EMAIL)
|
||||
}
|
||||
|
||||
/// Returns the contents of this `GeneralName` if it is a `dNSName`.
|
||||
pub fn dnsname(&self) -> Option<&str> {
|
||||
self.ia5_string(ffi::GEN_DNS)
|
||||
}
|
||||
|
||||
/// Returns the contents of this `GeneralName` if it is an `uniformResourceIdentifier`.
|
||||
pub fn uri(&self) -> Option<&str> {
|
||||
self.ia5_string(ffi::GEN_URI)
|
||||
}
|
||||
|
||||
/// Returns the contents of this `GeneralName` if it is an `iPAddress`.
|
||||
pub fn ipaddress(&self) -> Option<&[u8]> {
|
||||
unsafe {
|
||||
|
|
|
|||
|
|
@ -92,13 +92,15 @@ fn test_subject_alt_name() {
|
|||
let cert = X509::from_pem(cert).unwrap();
|
||||
|
||||
let subject_alt_names = cert.subject_alt_names().unwrap();
|
||||
assert_eq!(3, subject_alt_names.len());
|
||||
assert_eq!(Some("foobar.com"), subject_alt_names[0].dnsname());
|
||||
assert_eq!(5, subject_alt_names.len());
|
||||
assert_eq!(Some("example.com"), subject_alt_names[0].dnsname());
|
||||
assert_eq!(subject_alt_names[1].ipaddress(), Some(&[127, 0, 0, 1][..]));
|
||||
assert_eq!(
|
||||
subject_alt_names[2].ipaddress(),
|
||||
Some(&b"\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\x01"[..])
|
||||
);
|
||||
assert_eq!(Some("test@example.com"), subject_alt_names[3].email());
|
||||
assert_eq!(Some("http://www.example.com"), subject_alt_names[4].uri());
|
||||
}
|
||||
|
||||
#[test]
|
||||
|
|
@ -110,7 +112,7 @@ fn test_subject_alt_name_iter() {
|
|||
let mut subject_alt_names_iter = subject_alt_names.iter();
|
||||
assert_eq!(
|
||||
subject_alt_names_iter.next().unwrap().dnsname(),
|
||||
Some("foobar.com")
|
||||
Some("example.com")
|
||||
);
|
||||
assert_eq!(
|
||||
subject_alt_names_iter.next().unwrap().ipaddress(),
|
||||
|
|
@ -120,6 +122,14 @@ fn test_subject_alt_name_iter() {
|
|||
subject_alt_names_iter.next().unwrap().ipaddress(),
|
||||
Some(&b"\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\x01"[..])
|
||||
);
|
||||
assert_eq!(
|
||||
subject_alt_names_iter.next().unwrap().email(),
|
||||
Some("test@example.com")
|
||||
);
|
||||
assert_eq!(
|
||||
subject_alt_names_iter.next().unwrap().uri(),
|
||||
Some("http://www.example.com")
|
||||
);
|
||||
assert!(subject_alt_names_iter.next().is_none());
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -1,25 +1,22 @@
|
|||
-----BEGIN CERTIFICATE-----
|
||||
MIIEOjCCAyKgAwIBAgIJAJz42fzGUJGeMA0GCSqGSIb3DQEBCwUAMH8xCzAJBgNV
|
||||
BAYTAlVTMQswCQYDVQQIDAJOWTERMA8GA1UEBwwITmV3IFlvcmsxFTATBgNVBAoM
|
||||
DEV4YW1wbGUsIExMQzEYMBYGA1UEAwwPRXhhbXBsZSBDb21wYW55MR8wHQYJKoZI
|
||||
hvcNAQkBFhB0ZXN0QGV4YW1wbGUuY29tMB4XDTE2MDQzMDA0MDg1NloXDTE3MDQz
|
||||
MDA0MDg1NlowfzELMAkGA1UEBhMCVVMxCzAJBgNVBAgMAk5ZMREwDwYDVQQHDAhO
|
||||
ZXcgWW9yazEVMBMGA1UECgwMRXhhbXBsZSwgTExDMRgwFgYDVQQDDA9FeGFtcGxl
|
||||
IENvbXBhbnkxHzAdBgkqhkiG9w0BCQEWEHRlc3RAZXhhbXBsZS5jb20wggEiMA0G
|
||||
CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDggl2TbtO5Ewi/q8kV56xK6HBpwsj9
|
||||
wBoqGi6hkKm/8lhLTkuUG6WbEUepi7n9d7tjI9hwYN7MKtppAnS+d+Zh6sKMgLJn
|
||||
hONkbQBJkYWwuIxRVXORCdyZDNzXP1rlb6ynmj6mItuPTRVNNMaZP+24fgXtwGk8
|
||||
P2nqA1ONbmyaP27txV+Rd8fmQvW3vSmq7iDob661TOtLZRqqVRpnLDGpLXTCptYz
|
||||
dLN1nDWKjBUFpPGDxvfcSE3Yf9LaQM2uDHRygSgTFusbwarAGrAk8krsm/Tiaumx
|
||||
Ls74MY6OEoLnPbEi5epWLqPmoE1nxrvYLtaWh3TTET3H72yL0+1PZTkpAgMBAAGj
|
||||
gbgwgbUwHQYDVR0OBBYEFAIcHhTPUqVdK85u47vo8z0viJGPMB8GA1UdIwQYMBaA
|
||||
FAIcHhTPUqVdK85u47vo8z0viJGPMAkGA1UdEwQCMAAwCwYDVR0PBAQDAgWgMC0G
|
||||
A1UdEQQmMCSCCmZvb2Jhci5jb22HBH8AAAGHEAAAAAAAAAAAAAAAAAAAAAEwLAYJ
|
||||
YIZIAYb4QgENBB8WHU9wZW5TU0wgR2VuZXJhdGVkIENlcnRpZmljYXRlMA0GCSqG
|
||||
SIb3DQEBCwUAA4IBAQDeYsuJaxbnxR2wDRSbxMpPp2b6fHPxC1vArKTSrQ/X+5s7
|
||||
YcQ29jkzD8FbET8iPsCOn/IECBiDKOpckkO6dBWM05ma9HHzWjQOJ7Lo6gEsvk4d
|
||||
+M/jJz5IaJ7hOxp1hGqwNQ+PJQOZMmlruNcOzPU36qaWJ03+NYOKar5VpIrRxCNc
|
||||
uehTArmJqDLQPfgETEhMYfpkqf3s/cGb1uyeCpzgIRPpf4Ki1Oys5cV/BqIn7n5g
|
||||
7sUrhXboYL4+eYt5V4rcc4rLI5J5IP/a1Z+Z6UVH+Mbiyl0iD8aRr/bo9WvKih3C
|
||||
2LBO0Apl0tkXUOMWp7G0UYHVEndwPjZnVoM42f11
|
||||
MIIDsDCCApigAwIBAgIBATANBgkqhkiG9w0BAQsFADBFMQswCQYDVQQGEwJBVTET
|
||||
MBEGA1UECAwKU29tZS1TdGF0ZTEhMB8GA1UECgwYSW50ZXJuZXQgV2lkZ2l0cyBQ
|
||||
dHkgTHRkMB4XDTE4MDExNTExMDcwM1oXDTI4MDExMzExMDcwM1owfDELMAkGA1UE
|
||||
BhMCVVMxCzAJBgNVBAgMAk5ZMREwDwYDVQQHDAhOZXcgWW9yazEVMBMGA1UECgwM
|
||||
RXhhbXBsZSwgTExDMTYwNAYDVQQDDC1FeGFtcGxlIENvbXBhbnkvZW1haWxBZGRy
|
||||
ZXNzPXRlc3RAZXhhbXBsZS5jb20wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEK
|
||||
AoIBAQCo9CWMRLMXo1CF/iORh9B4NhtJF/8tR9PlG95sNvyWuQQ/8jfev+8zErpl
|
||||
xfLkt0pJqcoiZG8g9NU0kU6o5T+/1QgZclCAoZaS0Jqxmoo2Yk/1Qsj16pnMBc10
|
||||
uSDk6V9aJSX1vKwONVNSwiHA1MhX+i7Wf7/K0niq+k7hOkhleFkWgZtUq41gXh1V
|
||||
fOugka7UktYnk9mrBbAMjmaloZNn2pMMAQxVg4ThiLm3zvuWqvXASWzUZc7IAd1G
|
||||
bN4AtDuhs252eqE9E4iTHk7F14wAS1JWqv666hReGHrmZJGx0xQTM9vPD1HN5t2U
|
||||
3KTfhO/mTlAUWVyg9tCtOzboKgs1AgMBAAGjdDByMAkGA1UdEwQCMAAwCwYDVR0P
|
||||
BAQDAgWgMFgGA1UdEQRRME+CC2V4YW1wbGUuY29thwR/AAABhxAAAAAAAAAAAAAA
|
||||
AAAAAAABgRB0ZXN0QGV4YW1wbGUuY29thhZodHRwOi8vd3d3LmV4YW1wbGUuY29t
|
||||
MA0GCSqGSIb3DQEBCwUAA4IBAQAx14G99z/MnSbs8h5jSos+dgLvhc2IQB/3CChE
|
||||
hPyELc7iyw1iteRs7bS1m2NZx6gv6TZ6VydDrK1dnWSatQ7sskXTO+zfC6qjMwXl
|
||||
IV+u7T8EREwciniIA82d8GWs60BGyBL3zp2iUOr5ULG4+c/S6OLdlyJv+fDKv+Xo
|
||||
fKv1UGDi5rcvUBikeNkpEPTN9UsE9/A8XJfDyq+4RKuDW19EtzOOeVx4xpHOMnAy
|
||||
VVAQVMKJzhoXtLF4k2j409na+f6FIcZSBet+plmzfB+WZNIgUUi/7MQIXOFQRkj4
|
||||
zH3SnsPm/IYpJzlH2vHhlqIBdaSoTWpGVWPq7D+H8OS3mmXF
|
||||
-----END CERTIFICATE-----
|
||||
|
|
|
|||
Loading…
Reference in New Issue