Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "google_apis/gcm/engine/rmq_store.h" | 5 #include "google_apis/gcm/engine/rmq_store.h" |
| 6 | 6 |
| 7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
| 8 #include "base/bind.h" | 8 #include "base/bind.h" |
| 9 #include "base/callback.h" | 9 #include "base/callback.h" |
| 10 #include "base/file_util.h" | |
| 10 #include "base/files/file_path.h" | 11 #include "base/files/file_path.h" |
| 11 #include "base/logging.h" | 12 #include "base/logging.h" |
| 12 #include "base/message_loop/message_loop_proxy.h" | 13 #include "base/message_loop/message_loop_proxy.h" |
| 14 #include "base/metrics/histogram.h" | |
| 13 #include "base/sequenced_task_runner.h" | 15 #include "base/sequenced_task_runner.h" |
| 14 #include "base/stl_util.h" | 16 #include "base/stl_util.h" |
| 15 #include "base/strings/string_number_conversions.h" | 17 #include "base/strings/string_number_conversions.h" |
| 16 #include "base/strings/string_piece.h" | 18 #include "base/strings/string_piece.h" |
| 17 #include "base/tracked_objects.h" | 19 #include "base/tracked_objects.h" |
| 18 #include "components/webdata/encryptor/encryptor.h" | 20 #include "components/webdata/encryptor/encryptor.h" |
| 19 #include "google_apis/gcm/base/mcs_message.h" | 21 #include "google_apis/gcm/base/mcs_message.h" |
| 20 #include "google_apis/gcm/base/mcs_util.h" | 22 #include "google_apis/gcm/base/mcs_util.h" |
| 21 #include "google_apis/gcm/protocol/mcs.pb.h" | 23 #include "google_apis/gcm/protocol/mcs.pb.h" |
| 22 #include "third_party/leveldatabase/src/include/leveldb/db.h" | 24 #include "third_party/leveldatabase/src/include/leveldb/db.h" |
| (...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 137 | 139 |
| 138 void RMQStore::Backend::Load(const LoadCallback& callback) { | 140 void RMQStore::Backend::Load(const LoadCallback& callback) { |
| 139 LoadResult result; | 141 LoadResult result; |
| 140 | 142 |
| 141 leveldb::Options options; | 143 leveldb::Options options; |
| 142 options.create_if_missing = true; | 144 options.create_if_missing = true; |
| 143 leveldb::DB* db; | 145 leveldb::DB* db; |
| 144 leveldb::Status status = leveldb::DB::Open(options, | 146 leveldb::Status status = leveldb::DB::Open(options, |
| 145 path_.AsUTF8Unsafe(), | 147 path_.AsUTF8Unsafe(), |
| 146 &db); | 148 &db); |
| 149 UMA_HISTOGRAM_BOOLEAN("GCM.LoadSucceeded", status.ok()); | |
| 147 if (!status.ok()) { | 150 if (!status.ok()) { |
| 148 LOG(ERROR) << "Failed to open database " << path_.value() | 151 LOG(ERROR) << "Failed to open database " << path_.value() |
| 149 << ": " << status.ToString(); | 152 << ": " << status.ToString(); |
| 150 foreground_task_runner_->PostTask(FROM_HERE, | 153 foreground_task_runner_->PostTask(FROM_HERE, |
| 151 base::Bind(callback, result)); | 154 base::Bind(callback, result)); |
| 152 return; | 155 return; |
| 153 } | 156 } |
| 154 db_.reset(db); | 157 db_.reset(db); |
| 155 | 158 |
| 156 if (!LoadDeviceCredentials(&result.device_android_id, | 159 if (!LoadDeviceCredentials(&result.device_android_id, |
| 157 &result.device_security_token) || | 160 &result.device_security_token) || |
| 158 !LoadIncomingMessages(&result.incoming_messages) || | 161 !LoadIncomingMessages(&result.incoming_messages) || |
| 159 !LoadOutgoingMessages(&result.outgoing_messages) || | 162 !LoadOutgoingMessages(&result.outgoing_messages) || |
| 160 !LoadNextSerialNumber(&result.next_serial_number) || | 163 !LoadNextSerialNumber(&result.next_serial_number) || |
| 161 !LoadUserSerialNumberMap(&result.user_serial_numbers)) { | 164 !LoadUserSerialNumberMap(&result.user_serial_numbers)) { |
| 162 result.device_android_id = 0; | 165 result.device_android_id = 0; |
| 163 result.device_security_token = 0; | 166 result.device_security_token = 0; |
| 164 result.incoming_messages.clear(); | 167 result.incoming_messages.clear(); |
| 165 STLDeleteContainerPairSecondPointers(result.outgoing_messages.begin(), | 168 STLDeleteContainerPairSecondPointers(result.outgoing_messages.begin(), |
| 166 result.outgoing_messages.end()); | 169 result.outgoing_messages.end()); |
| 167 result.outgoing_messages.clear(); | 170 result.outgoing_messages.clear(); |
| 168 foreground_task_runner_->PostTask(FROM_HERE, | 171 foreground_task_runner_->PostTask(FROM_HERE, |
| 169 base::Bind(callback, result)); | 172 base::Bind(callback, result)); |
| 170 return; | 173 return; |
| 171 } | 174 } |
| 172 | 175 |
| 176 // Only record histograms if GCM had already been set up for this device. | |
| 177 if (result.device_android_id != 0 && result.device_security_token != 0) { | |
| 178 int64 file_size = 0; | |
| 179 if (base::GetFileSize(path_, &file_size)) { | |
| 180 UMA_HISTOGRAM_COUNTS("GCM.StoreSizeKB", | |
| 181 static_cast<int>(file_size / 1024)); | |
|
fgorski
2014/01/02 23:45:40
That does not make a distinction between a 0 size
Nicolas Zea
2014/01/02 23:48:21
A 0 store should not happen if the store has been
| |
| 182 } | |
| 183 UMA_HISTOGRAM_COUNTS("GCM.RestoredOutgoingMessages", | |
| 184 result.outgoing_messages.size()); | |
| 185 UMA_HISTOGRAM_COUNTS("GCM.RestoredIncomingMessages", | |
| 186 result.incoming_messages.size()); | |
| 187 UMA_HISTOGRAM_COUNTS("GCM.NumUsers", result.user_serial_numbers.size()); | |
| 188 } | |
| 189 | |
| 173 DVLOG(1) << "Succeeded in loading " << result.incoming_messages.size() | 190 DVLOG(1) << "Succeeded in loading " << result.incoming_messages.size() |
| 174 << " unacknowledged incoming messages and " | 191 << " unacknowledged incoming messages and " |
| 175 << result.outgoing_messages.size() | 192 << result.outgoing_messages.size() |
| 176 << " unacknowledged outgoing messages."; | 193 << " unacknowledged outgoing messages."; |
| 177 result.success = true; | 194 result.success = true; |
| 178 foreground_task_runner_->PostTask(FROM_HERE, | 195 foreground_task_runner_->PostTask(FROM_HERE, |
| 179 base::Bind(callback, result)); | 196 base::Bind(callback, result)); |
| 180 return; | 197 return; |
| 181 } | 198 } |
| 182 | 199 |
| (...skipping 466 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 649 const UpdateCallback& callback) { | 666 const UpdateCallback& callback) { |
| 650 blocking_task_runner_->PostTask( | 667 blocking_task_runner_->PostTask( |
| 651 FROM_HERE, | 668 FROM_HERE, |
| 652 base::Bind(&RMQStore::Backend::RemoveUserSerialNumber, | 669 base::Bind(&RMQStore::Backend::RemoveUserSerialNumber, |
| 653 backend_, | 670 backend_, |
| 654 username, | 671 username, |
| 655 callback)); | 672 callback)); |
| 656 } | 673 } |
| 657 | 674 |
| 658 } // namespace gcm | 675 } // namespace gcm |
| OLD | NEW |