Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(492)

Side by Side Diff: content/common/ssl_status_serialization.cc

Issue 1225983003: Clean up the interface to DeserializeSecurityInfo, fix uninitialized memory use. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: typo Created 5 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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 {
(...skipping 13 matching lines...) Expand all
24 pickle.WriteInt(signed_certificate_timestamp_ids.size()); 24 pickle.WriteInt(signed_certificate_timestamp_ids.size());
25 for (SignedCertificateTimestampIDStatusList::const_iterator iter = 25 for (SignedCertificateTimestampIDStatusList::const_iterator iter =
26 signed_certificate_timestamp_ids.begin(); 26 signed_certificate_timestamp_ids.begin();
27 iter != signed_certificate_timestamp_ids.end(); ++iter) { 27 iter != signed_certificate_timestamp_ids.end(); ++iter) {
28 pickle.WriteInt(iter->id); 28 pickle.WriteInt(iter->id);
29 pickle.WriteUInt16(iter->status); 29 pickle.WriteUInt16(iter->status);
30 } 30 }
31 return std::string(static_cast<const char*>(pickle.data()), pickle.size()); 31 return std::string(static_cast<const char*>(pickle.data()), pickle.size());
32 } 32 }
33 33
34 bool DeserializeSecurityInfo( 34 SSLStatus DeserializeSecurityInfo(const std::string& state) {
35 const std::string& state,
36 int* cert_id,
37 net::CertStatus* cert_status,
38 int* security_bits,
39 int* ssl_connection_status,
40 SignedCertificateTimestampIDStatusList* signed_certificate_timestamp_ids) {
41 DCHECK(cert_id && cert_status && security_bits && ssl_connection_status &&
42 signed_certificate_timestamp_ids);
43 if (state.empty()) { 35 if (state.empty()) {
44 // No SSL used. 36 // No SSL used.
45 *cert_id = 0; 37 return SSLStatus();
46 // The following are not applicable and are set to the default values.
47 *cert_status = 0;
48 *security_bits = -1;
49 *ssl_connection_status = 0;
50 signed_certificate_timestamp_ids->clear();
51 return false;
52 } 38 }
53 39
40 SSLStatus ssl_status;
54 base::Pickle pickle(state.data(), static_cast<int>(state.size())); 41 base::Pickle pickle(state.data(), static_cast<int>(state.size()));
55 base::PickleIterator iter(pickle); 42 base::PickleIterator iter(pickle);
56 int num_scts_to_read; 43 int num_scts_to_read;
57 if (!iter.ReadInt(cert_id) || 44 if (!iter.ReadInt(&ssl_status.cert_id) ||
58 !iter.ReadUInt32(cert_status) || 45 !iter.ReadUInt32(&ssl_status.cert_status) ||
59 !iter.ReadInt(security_bits) || 46 !iter.ReadInt(&ssl_status.security_bits) ||
60 !iter.ReadInt(ssl_connection_status) || 47 !iter.ReadInt(&ssl_status.connection_status) ||
61 !iter.ReadInt(&num_scts_to_read)) 48 !iter.ReadInt(&num_scts_to_read))
62 return false; 49 return SSLStatus();
63 50
64 for (; num_scts_to_read > 0; --num_scts_to_read) { 51 for (; num_scts_to_read > 0; --num_scts_to_read) {
65 int id; 52 int id;
66 uint16 status; 53 uint16 status;
67 if (!iter.ReadInt(&id) || !iter.ReadUInt16(&status)) 54 if (!iter.ReadInt(&id) || !iter.ReadUInt16(&status))
68 return false; 55 return SSLStatus();
69 signed_certificate_timestamp_ids->push_back( 56 ssl_status.signed_certificate_timestamp_ids.push_back(
70 SignedCertificateTimestampIDAndStatus( 57 SignedCertificateTimestampIDAndStatus(
71 id, 58 id,
72 static_cast<net::ct::SCTVerifyStatus>(status))); 59 static_cast<net::ct::SCTVerifyStatus>(status)));
73 } 60 }
74 61
75 return true; 62 return ssl_status;
76 } 63 }
77 64
78 } // namespace content 65 } // namespace content
OLDNEW
« no previous file with comments | « content/common/ssl_status_serialization.h ('k') | content/renderer/context_menu_params_builder.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698