| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/common/ssl_status_serialization.h" | 5 #include "content/common/ssl_status_serialization.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "base/pickle.h" | 8 #include "base/pickle.h" |
| 9 | 9 |
| 10 namespace content { | 10 namespace content { |
| 11 | 11 |
| 12 std::string SerializeSecurityInfo(int cert_id, | 12 std::string SerializeSecurityInfo(int cert_id, |
| 13 net::CertStatus cert_status, | 13 net::CertStatus cert_status, |
| 14 int security_bits, | 14 int security_bits, |
| 15 int ssl_connection_status, | 15 int ssl_connection_status, |
| 16 int signed_certificate_timestamp_id) { | 16 const SCTIdStatusList& |
| 17 signed_certificate_timestamp_ids) { |
| 17 Pickle pickle; | 18 Pickle pickle; |
| 18 pickle.WriteInt(cert_id); | 19 pickle.WriteInt(cert_id); |
| 19 pickle.WriteUInt32(cert_status); | 20 pickle.WriteUInt32(cert_status); |
| 20 pickle.WriteInt(security_bits); | 21 pickle.WriteInt(security_bits); |
| 21 pickle.WriteInt(ssl_connection_status); | 22 pickle.WriteInt(ssl_connection_status); |
| 22 pickle.WriteInt(signed_certificate_timestamp_id); | 23 pickle.WriteInt(signed_certificate_timestamp_ids.size()); |
| 24 for (SCTIdStatusList::const_iterator iter = |
| 25 signed_certificate_timestamp_ids.begin(); |
| 26 iter != signed_certificate_timestamp_ids.end(); ++iter) { |
| 27 pickle.WriteInt(iter->first); // sct_id |
| 28 pickle.WriteUInt16(iter->second); // verification status |
| 29 } |
| 23 return std::string(static_cast<const char*>(pickle.data()), pickle.size()); | 30 return std::string(static_cast<const char*>(pickle.data()), pickle.size()); |
| 24 } | 31 } |
| 25 | 32 |
| 26 bool DeserializeSecurityInfo(const std::string& state, | 33 bool DeserializeSecurityInfo(const std::string& state, |
| 27 int* cert_id, | 34 int* cert_id, |
| 28 net::CertStatus* cert_status, | 35 net::CertStatus* cert_status, |
| 29 int* security_bits, | 36 int* security_bits, |
| 30 int* ssl_connection_status, | 37 int* ssl_connection_status, |
| 31 int* signed_certificate_timestamp_id) { | 38 SCTIdStatusList* |
| 39 signed_certificate_timestamp_ids) { |
| 32 DCHECK(cert_id && cert_status && security_bits && ssl_connection_status); | 40 DCHECK(cert_id && cert_status && security_bits && ssl_connection_status); |
| 33 if (state.empty()) { | 41 if (state.empty()) { |
| 34 // No SSL used. | 42 // No SSL used. |
| 35 *cert_id = 0; | 43 *cert_id = 0; |
| 36 // The following are not applicable and are set to the default values. | 44 // The following are not applicable and are set to the default values. |
| 37 *cert_status = 0; | 45 *cert_status = 0; |
| 38 *security_bits = -1; | 46 *security_bits = -1; |
| 39 *ssl_connection_status = 0; | 47 *ssl_connection_status = 0; |
| 40 *signed_certificate_timestamp_id = 0; | 48 signed_certificate_timestamp_ids->clear(); |
| 41 return false; | 49 return false; |
| 42 } | 50 } |
| 43 | 51 |
| 44 Pickle pickle(state.data(), static_cast<int>(state.size())); | 52 Pickle pickle(state.data(), static_cast<int>(state.size())); |
| 45 PickleIterator iter(pickle); | 53 PickleIterator iter(pickle); |
| 46 return pickle.ReadInt(&iter, cert_id) && | 54 bool pickle_read_ok = pickle.ReadInt(&iter, cert_id) && |
| 47 pickle.ReadUInt32(&iter, cert_status) && | 55 pickle.ReadUInt32(&iter, cert_status) && |
| 48 pickle.ReadInt(&iter, security_bits) && | 56 pickle.ReadInt(&iter, security_bits) && |
| 49 pickle.ReadInt(&iter, ssl_connection_status) && | 57 pickle.ReadInt(&iter, ssl_connection_status); |
| 50 pickle.ReadInt(&iter, signed_certificate_timestamp_id); | 58 if (pickle_read_ok) { |
| 59 int num_scts_to_read; |
| 60 pickle_read_ok = pickle.ReadInt(&iter, &num_scts_to_read); |
| 61 int id; |
| 62 net::SignedCertificateTimestampVerificationStatus status; |
| 63 for (; num_scts_to_read > 0 && pickle_read_ok; --num_scts_to_read) { |
| 64 pickle_read_ok &= pickle.ReadInt(&iter, &id) && |
| 65 pickle.ReadUInt16(&iter, &status); |
| 66 if (pickle_read_ok) |
| 67 signed_certificate_timestamp_ids->push_back( |
| 68 std::make_pair(id, status)); |
| 69 } |
| 70 } |
| 71 |
| 72 return pickle_read_ok; |
| 51 } | 73 } |
| 52 | 74 |
| 53 } // namespace content | 75 } // namespace content |
| OLD | NEW |