debug_info_event_listener.cc revision 868fa2fe829687343ffae624259930155e16dbd8
15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Copyright (c) 2012 The Chromium Authors. All rights reserved.
25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be
35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// found in the LICENSE file.
45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "sync/internal_api/debug_info_event_listener.h"
65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "sync/util/cryptographer.h"
85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace syncer {
105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)using sessions::SyncSessionSnapshot;
125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)DebugInfoEventListener::DebugInfoEventListener()
145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    : events_dropped_(false),
155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      cryptographer_has_pending_keys_(false),
165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      cryptographer_ready_(false),
17c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)      weak_ptr_factory_(this) {
185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)DebugInfoEventListener::~DebugInfoEventListener() {
215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnSyncCycleCompleted(
245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const SyncSessionSnapshot& snapshot) {
255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_pb::DebugEventInfo event_info;
275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_pb::SyncCycleCompletedEventInfo* sync_completed_event_info =
285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      event_info.mutable_sync_cycle_completed_event_info();
295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_completed_event_info->set_num_encryption_conflicts(
315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      snapshot.num_encryption_conflicts());
325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_completed_event_info->set_num_hierarchy_conflicts(
335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      snapshot.num_hierarchy_conflicts());
345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_completed_event_info->set_num_server_conflicts(
355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      snapshot.num_server_conflicts());
365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_completed_event_info->set_num_updates_downloaded(
385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      snapshot.model_neutral_state().num_updates_downloaded_total);
395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_completed_event_info->set_num_reflected_updates_downloaded(
405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      snapshot.model_neutral_state().num_reflected_updates_downloaded_total);
415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_completed_event_info->mutable_caller_info()->set_source(
425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      snapshot.source().updates_source);
435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_completed_event_info->mutable_caller_info()->set_notifications_enabled(
445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      snapshot.notifications_enabled());
455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  AddEventToQueue(event_info);
475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnInitializationComplete(
505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const WeakHandle<JsBackend>& js_backend,
515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const WeakHandle<DataTypeDebugInfoListener>& debug_listener,
525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    bool success, ModelTypeSet restored_types) {
535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::INITIALIZATION_COMPLETE);
555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnConnectionStatusChange(
585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    ConnectionStatus status) {
595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::CONNECTION_STATUS_CHANGE);
615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnPassphraseRequired(
645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    PassphraseRequiredReason reason,
655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const sync_pb::EncryptedData& pending_keys) {
665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::PASSPHRASE_REQUIRED);
685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnPassphraseAccepted() {
715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::PASSPHRASE_ACCEPTED);
735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnBootstrapTokenUpdated(
765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const std::string& bootstrap_token, BootstrapTokenType type) {
775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  if (type == PASSPHRASE_BOOTSTRAP_TOKEN) {
795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    CreateAndAddEvent(sync_pb::DebugEventInfo::BOOTSTRAP_TOKEN_UPDATED);
805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    return;
815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  }
825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK_EQ(type, KEYSTORE_BOOTSTRAP_TOKEN);
835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::KEYSTORE_TOKEN_UPDATED);
845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnStopSyncingPermanently() {
875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::STOP_SYNCING_PERMANENTLY);
895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnUpdatedToken(const std::string& token) {
925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::UPDATED_TOKEN);
945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnEncryptedTypesChanged(
975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    ModelTypeSet encrypted_types,
985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    bool encrypt_everything) {
995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::ENCRYPTED_TYPES_CHANGED);
1015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnEncryptionComplete() {
1045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::ENCRYPTION_COMPLETE);
1065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnCryptographerStateChanged(
1095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    Cryptographer* cryptographer) {
1105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  cryptographer_has_pending_keys_ = cryptographer->has_pending_keys();
1125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  cryptographer_ready_ = cryptographer->is_ready();
1135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnPassphraseTypeChanged(
1165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    PassphraseType type,
1175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    base::Time explicit_passphrase_time) {
1185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::PASSPHRASE_TYPE_CHANGED);
1205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnActionableError(
1235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const SyncProtocolError& sync_error) {
1245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::ACTIONABLE_ERROR);
1265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnNudgeFromDatatype(ModelType datatype) {
1295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_pb::DebugEventInfo event_info;
1315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  event_info.set_nudging_datatype(
1325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      GetSpecificsFieldNumberFromModelType(datatype));
1335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  AddEventToQueue(event_info);
1345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnIncomingNotification(
1375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)     const ModelTypeInvalidationMap& invalidation_map) {
1385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_pb::DebugEventInfo event_info;
1405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ModelTypeSet types = ModelTypeInvalidationMapToSet(invalidation_map);
1415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  for (ModelTypeSet::Iterator it = types.First(); it.Good(); it.Inc()) {
1435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    event_info.add_datatypes_notified_from_server(
1445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)        GetSpecificsFieldNumberFromModelType(it.Get()));
1455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  }
1465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  AddEventToQueue(event_info);
1485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::GetAndClearDebugInfo(
1515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    sync_pb::DebugInfo* debug_info) {
1525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK_LE(events_.size(), kMaxEntries);
1545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  while (!events_.empty()) {
1555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    sync_pb::DebugEventInfo* event_info = debug_info->add_events();
1565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const sync_pb::DebugEventInfo& debug_event_info = events_.front();
1575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    event_info->CopyFrom(debug_event_info);
1585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    events_.pop();
1595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  }
1605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  debug_info->set_events_dropped(events_dropped_);
1625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  debug_info->set_cryptographer_ready(cryptographer_ready_);
1635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  debug_info->set_cryptographer_has_pending_keys(
1645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      cryptographer_has_pending_keys_);
1655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  events_dropped_ = false;
1675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)base::WeakPtr<DataTypeDebugInfoListener> DebugInfoEventListener::GetWeakPtr() {
1705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  return weak_ptr_factory_.GetWeakPtr();
1725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
174868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)void DebugInfoEventListener::OnSingleDataTypeConfigureComplete(
175868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)    const DataTypeConfigurationStats& configuration_stats) {
1765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
177868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  DCHECK(ProtocolTypes().Has(configuration_stats.model_type));
178868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)
179868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  const DataTypeAssociationStats& association_stats =
180868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      configuration_stats.association_stats;
181868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)
1825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_pb::DebugEventInfo association_event;
1835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_pb::DatatypeAssociationStats* datatype_stats =
1845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_event.mutable_datatype_association_stats();
1855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_data_type_id(
186868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      GetSpecificsFieldNumberFromModelType(configuration_stats.model_type));
1875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_local_items_before_association(
1885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_local_items_before_association);
1895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_sync_items_before_association(
1905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_sync_items_before_association);
1915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_local_items_after_association(
1925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_local_items_after_association);
1935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_sync_items_after_association(
1945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_sync_items_after_association);
1955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_local_items_added(
1965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_local_items_added);
1975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_local_items_deleted(
1985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_local_items_deleted);
1995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_local_items_modified(
2005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_local_items_modified);
2015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_sync_items_added(
2025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_sync_items_added);
2035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_sync_items_deleted(
2045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_sync_items_deleted);
2055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_sync_items_modified(
2065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_sync_items_modified);
2075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_had_error(association_stats.had_error);
208868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  datatype_stats->set_association_wait_time_for_same_priority_us(
209b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles)        association_stats.association_wait_time.InMicroseconds());
210b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles)  datatype_stats->set_association_time_us(
211b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles)      association_stats.association_time.InMicroseconds());
212868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  datatype_stats->set_download_wait_time_us(
213868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      configuration_stats.download_wait_time.InMicroseconds());
214868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  datatype_stats->set_download_time_us(
215868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      configuration_stats.download_time.InMicroseconds());
216868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  datatype_stats->set_association_wait_time_for_high_priority_us(
217868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      configuration_stats.association_wait_time_for_high_priority
218868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)          .InMicroseconds());
219868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)
220868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  for (ModelTypeSet::Iterator it =
221868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      configuration_stats.high_priority_types_configured_before.First();
222868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      it.Good(); it.Inc()) {
223868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)    datatype_stats->add_high_priority_type_configured_before(
224868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)        GetSpecificsFieldNumberFromModelType(it.Get()));
225868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  }
226868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)
227868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  for (ModelTypeSet::Iterator it =
228868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      configuration_stats.same_priority_types_configured_before.First();
229868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      it.Good(); it.Inc()) {
230868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)    datatype_stats->add_same_priority_type_configured_before(
231868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)        GetSpecificsFieldNumberFromModelType(it.Get()));
232868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  }
2335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  AddEventToQueue(association_event);
2355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
2365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnConfigureComplete() {
2385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
2395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::CONFIGURE_COMPLETE);
2405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
2415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::CreateAndAddEvent(
2435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    sync_pb::DebugEventInfo::SingletonEventType type) {
2445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
2455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_pb::DebugEventInfo event_info;
2465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  event_info.set_singleton_event(type);
2475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  AddEventToQueue(event_info);
2485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
2495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::AddEventToQueue(
2515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  const sync_pb::DebugEventInfo& event_info) {
2525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
2535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  if (events_.size() >= kMaxEntries) {
2545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    DVLOG(1) << "DebugInfoEventListener::AddEventToQueue Dropping an old event "
2555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)             << "because of full queue";
2565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    events_.pop();
2585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    events_dropped_ = true;
2595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  }
2605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  events_.push(event_info);
2615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
2625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}  // namespace syncer
264