OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "content/public/common/ssl_status.h" | 5 #include "content/public/common/ssl_status.h" |
6 | 6 |
| 7 #include "net/cert/sct_status_flags.h" |
7 #include "net/ssl/ssl_info.h" | 8 #include "net/ssl/ssl_info.h" |
8 | 9 |
9 namespace content { | 10 namespace content { |
10 | 11 |
11 SSLStatus::SSLStatus() | 12 SSLStatus::SSLStatus() |
12 : security_style(SECURITY_STYLE_UNKNOWN), | 13 : security_style(SECURITY_STYLE_UNKNOWN), |
13 cert_id(0), | 14 cert_id(0), |
14 cert_status(0), | 15 cert_status(0), |
15 security_bits(-1), | 16 security_bits(-1), |
16 key_exchange_info(0), | 17 key_exchange_info(0), |
17 connection_status(0), | 18 connection_status(0), |
18 content_status(NORMAL_CONTENT) { | 19 content_status(NORMAL_CONTENT), |
19 } | 20 num_unknown_scts(0), |
| 21 num_invalid_scts(0), |
| 22 num_valid_scts(0) {} |
20 | 23 |
21 SSLStatus::SSLStatus(SecurityStyle security_style, | 24 SSLStatus::SSLStatus(SecurityStyle security_style, |
22 int cert_id, | 25 int cert_id, |
23 const SignedCertificateTimestampIDStatusList& | |
24 signed_certificate_timestamp_ids, | |
25 const net::SSLInfo& ssl_info) | 26 const net::SSLInfo& ssl_info) |
26 : security_style(security_style), | 27 : security_style(security_style), |
27 cert_id(cert_id), | 28 cert_id(cert_id), |
28 cert_status(ssl_info.cert_status), | 29 cert_status(ssl_info.cert_status), |
29 security_bits(ssl_info.security_bits), | 30 security_bits(ssl_info.security_bits), |
30 key_exchange_info(ssl_info.key_exchange_info), | 31 key_exchange_info(ssl_info.key_exchange_info), |
31 connection_status(ssl_info.connection_status), | 32 connection_status(ssl_info.connection_status), |
32 content_status(NORMAL_CONTENT), | 33 content_status(NORMAL_CONTENT), |
33 signed_certificate_timestamp_ids(signed_certificate_timestamp_ids) {} | 34 num_unknown_scts(0), |
| 35 num_invalid_scts(0), |
| 36 num_valid_scts(0) { |
| 37 // Count unknown, invalid and valid SCTs. |
| 38 for (const auto& sct_and_status : ssl_info.signed_certificate_timestamps) { |
| 39 switch (sct_and_status.status) { |
| 40 case net::ct::SCT_STATUS_LOG_UNKNOWN: |
| 41 num_unknown_scts++; |
| 42 break; |
| 43 case net::ct::SCT_STATUS_INVALID: |
| 44 num_invalid_scts++; |
| 45 break; |
| 46 case net::ct::SCT_STATUS_OK: |
| 47 num_valid_scts++; |
| 48 break; |
| 49 case net::ct::SCT_STATUS_NONE: |
| 50 case net::ct::SCT_STATUS_MAX: |
| 51 // These enum values do not represent SCTs that are taken into account |
| 52 // for CT compliance calculations, so we ignore them. |
| 53 NOTREACHED(); |
| 54 break; |
| 55 } |
| 56 } |
| 57 } |
34 | 58 |
35 SSLStatus::SSLStatus(const SSLStatus& other) = default; | 59 SSLStatus::SSLStatus(const SSLStatus& other) = default; |
36 | 60 |
37 SSLStatus::~SSLStatus() {} | 61 SSLStatus::~SSLStatus() {} |
38 | 62 |
39 } // namespace content | 63 } // namespace content |
OLD | NEW |