diff options
author | avi@google.com <avi@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-09-24 14:13:26 +0000 |
---|---|---|
committer | avi@google.com <avi@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-09-24 14:13:26 +0000 |
commit | d430015b83deb8ce3fecb9a36a8a21c61a19afc6 (patch) | |
tree | 519a38581055aab5c72e2dee7b1eadfe8e4a3127 /net/base/x509_certificate_mac.cc | |
parent | c9d40877fb0df5306deac35ff176a02c667d90e8 (diff) | |
download | chromium_src-d430015b83deb8ce3fecb9a36a8a21c61a19afc6.zip chromium_src-d430015b83deb8ce3fecb9a36a8a21c61a19afc6.tar.gz chromium_src-d430015b83deb8ce3fecb9a36a8a21c61a19afc6.tar.bz2 |
Some quick changes suggested by wtc in review.
Review URL: http://codereview.chromium.org/4056
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@2547 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/base/x509_certificate_mac.cc')
-rw-r--r-- | net/base/x509_certificate_mac.cc | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/net/base/x509_certificate_mac.cc b/net/base/x509_certificate_mac.cc index 81e35c8..e60e19a 100644 --- a/net/base/x509_certificate_mac.cc +++ b/net/base/x509_certificate_mac.cc @@ -146,6 +146,9 @@ void GetCertGeneralNamesForOID(X509Certificate::OSCertHandle cert_handle, // |name_struct.nameType| and doing type-appropriate conversions. See // certextensions.h and the comment immediately preceding // CE_GeneralNameType for more information. + DCHECK(name_struct.nameType == GNT_RFC822Name || + name_struct.nameType == GNT_DNSName || + name_struct.nameType == GNT_URI); if (name_struct.nameType == name_type) { const CSSM_DATA& name_data = name_struct.name; std::string value = @@ -161,6 +164,8 @@ void GetCertGeneralNamesForOID(X509Certificate::OSCertHandle cert_handle, void GetCertDateForOID(X509Certificate::OSCertHandle cert_handle, CSSM_OID oid, Time* result) { + *result = Time::Time(); + uint32 num_of_fields; CSSM_FIELD_PTR fields; OSStatus status = GetCertFieldsForOID(cert_handle, oid, &num_of_fields, @@ -177,13 +182,20 @@ void GetCertDateForOID(X509Certificate::OSCertHandle cert_handle, (x509_time->time.Data), x509_time->time.Length); + DCHECK(x509_time->timeType == BER_TAG_UTC_TIME || + x509_time->timeType == BER_TAG_GENERALIZED_TIME); + struct tm time; const char* parse_string; if (x509_time->timeType == BER_TAG_UTC_TIME) parse_string = "%y%m%d%H%M%SZ"; else if (x509_time->timeType == BER_TAG_GENERALIZED_TIME) parse_string = "%y%m%d%H%M%SZ"; - // else log? + else { + // Those are the only two BER tags for time; if neither are used then + // this is a rather broken cert. + return; + } strptime(time_string.c_str(), parse_string, &time); @@ -198,6 +210,7 @@ void GetCertDateForOID(X509Certificate::OSCertHandle cert_handle, exploded.millisecond = 0; *result = Time::FromUTCExploded(exploded); + break; } } } |