summaryrefslogtreecommitdiffstats
path: root/net/base
diff options
context:
space:
mode:
authoravi@google.com <avi@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-09-24 14:13:26 +0000
committeravi@google.com <avi@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-09-24 14:13:26 +0000
commitd430015b83deb8ce3fecb9a36a8a21c61a19afc6 (patch)
tree519a38581055aab5c72e2dee7b1eadfe8e4a3127 /net/base
parentc9d40877fb0df5306deac35ff176a02c667d90e8 (diff)
downloadchromium_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')
-rw-r--r--net/base/x509_certificate_mac.cc15
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;
}
}
}