OLD | NEW |
1 // Copyright (c) 2006-2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2006-2010 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "net/base/x509_cert_types.h" | 5 #include "net/base/x509_cert_types.h" |
6 | 6 |
7 #include "net/base/x509_certificate.h" | 7 #include "net/base/x509_certificate.h" |
8 #include "base/logging.h" | 8 #include "base/logging.h" |
| 9 #include "base/string_number_conversions.h" |
| 10 #include "base/string_piece.h" |
| 11 #include "base/time.h" |
9 | 12 |
10 namespace net { | 13 namespace net { |
11 | 14 |
| 15 namespace { |
| 16 |
| 17 // Helper for ParseCertificateDate. |*field| must contain at least |
| 18 // |field_len| characters. |*field| will be advanced by |field_len| on exit. |
| 19 // |*ok| is set to false if there is an error in parsing the number, but left |
| 20 // untouched otherwise. Returns the parsed integer. |
| 21 int ParseIntAndAdvance(const char** field, size_t field_len, bool* ok) { |
| 22 int result = 0; |
| 23 *ok &= base::StringToInt(*field, *field + field_len, &result); |
| 24 *field += field_len; |
| 25 return result; |
| 26 } |
| 27 |
| 28 } // namespace |
| 29 |
12 CertPrincipal::CertPrincipal() { | 30 CertPrincipal::CertPrincipal() { |
13 } | 31 } |
14 | 32 |
15 CertPrincipal::CertPrincipal(const std::string& name) : common_name(name) {} | 33 CertPrincipal::CertPrincipal(const std::string& name) : common_name(name) {} |
16 | 34 |
17 CertPrincipal::~CertPrincipal() { | 35 CertPrincipal::~CertPrincipal() { |
18 } | 36 } |
19 | 37 |
20 std::string CertPrincipal::GetDisplayName() const { | 38 std::string CertPrincipal::GetDisplayName() const { |
21 if (!common_name.empty()) | 39 if (!common_name.empty()) |
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
68 } | 86 } |
69 | 87 |
70 bool CertPolicy::HasAllowedCert() const { | 88 bool CertPolicy::HasAllowedCert() const { |
71 return !allowed_.empty(); | 89 return !allowed_.empty(); |
72 } | 90 } |
73 | 91 |
74 bool CertPolicy::HasDeniedCert() const { | 92 bool CertPolicy::HasDeniedCert() const { |
75 return !denied_.empty(); | 93 return !denied_.empty(); |
76 } | 94 } |
77 | 95 |
| 96 bool ParseCertificateDate(const base::StringPiece& raw_date, |
| 97 CertDateFormat format, |
| 98 base::Time* time) { |
| 99 size_t year_length = format == CERT_DATE_FORMAT_UTC_TIME ? 2 : 4; |
| 100 |
| 101 if (raw_date.length() < 11 + year_length) |
| 102 return false; |
| 103 |
| 104 const char* field = raw_date.data(); |
| 105 bool valid = true; |
| 106 base::Time::Exploded exploded = {0}; |
| 107 |
| 108 exploded.year = ParseIntAndAdvance(&field, year_length, &valid); |
| 109 exploded.month = ParseIntAndAdvance(&field, 2, &valid); |
| 110 exploded.day_of_month = ParseIntAndAdvance(&field, 2, &valid); |
| 111 exploded.hour = ParseIntAndAdvance(&field, 2, &valid); |
| 112 exploded.minute = ParseIntAndAdvance(&field, 2, &valid); |
| 113 exploded.second = ParseIntAndAdvance(&field, 2, &valid); |
| 114 if (valid && year_length == 2) |
| 115 exploded.year += exploded.year < 50 ? 2000 : 1900; |
| 116 |
| 117 valid &= exploded.HasValidValues(); |
| 118 |
| 119 if (!valid) |
| 120 return false; |
| 121 |
| 122 *time = base::Time::FromUTCExploded(exploded); |
| 123 return true; |
| 124 } |
| 125 |
78 } // namespace net | 126 } // namespace net |
OLD | NEW |