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( 42a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) snapshot.legacy_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); 2077d4cd473f85ac64c3747c96c277f9e506a0d2246Torne (Richard Coles) datatype_stats->set_local_version_pre_association( 2087d4cd473f85ac64c3747c96c277f9e506a0d2246Torne (Richard Coles) association_stats.local_version_pre_association); 2097d4cd473f85ac64c3747c96c277f9e506a0d2246Torne (Richard Coles) datatype_stats->set_sync_version_pre_association( 2107d4cd473f85ac64c3747c96c277f9e506a0d2246Torne (Richard Coles) association_stats.sync_version_pre_association); 2115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) datatype_stats->set_had_error(association_stats.had_error); 212868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) datatype_stats->set_association_wait_time_for_same_priority_us( 213b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) association_stats.association_wait_time.InMicroseconds()); 214b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) datatype_stats->set_association_time_us( 215b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) association_stats.association_time.InMicroseconds()); 216868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) datatype_stats->set_download_wait_time_us( 217868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) configuration_stats.download_wait_time.InMicroseconds()); 218868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) datatype_stats->set_download_time_us( 219868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) configuration_stats.download_time.InMicroseconds()); 220868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) datatype_stats->set_association_wait_time_for_high_priority_us( 221868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) configuration_stats.association_wait_time_for_high_priority 222868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) .InMicroseconds()); 223868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) 224868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) for (ModelTypeSet::Iterator it = 225868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) configuration_stats.high_priority_types_configured_before.First(); 226868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) it.Good(); it.Inc()) { 227868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) datatype_stats->add_high_priority_type_configured_before( 228868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) GetSpecificsFieldNumberFromModelType(it.Get())); 229868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) } 230868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) 231868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) for (ModelTypeSet::Iterator it = 232868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) configuration_stats.same_priority_types_configured_before.First(); 233868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) it.Good(); it.Inc()) { 234868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) datatype_stats->add_same_priority_type_configured_before( 235868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) GetSpecificsFieldNumberFromModelType(it.Get())); 236868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) } 2375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) AddEventToQueue(association_event); 2395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 2405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnConfigureComplete() { 2425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 2435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CreateAndAddEvent(sync_pb::DebugEventInfo::CONFIGURE_COMPLETE); 2445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 2455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::CreateAndAddEvent( 2475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_pb::DebugEventInfo::SingletonEventType type) { 2485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 2495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_pb::DebugEventInfo event_info; 2505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) event_info.set_singleton_event(type); 2515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) AddEventToQueue(event_info); 2525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 2535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::AddEventToQueue( 2555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const sync_pb::DebugEventInfo& event_info) { 2565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 2575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (events_.size() >= kMaxEntries) { 2585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DVLOG(1) << "DebugInfoEventListener::AddEventToQueue Dropping an old event " 2595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) << "because of full queue"; 2605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) events_.pop(); 2625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) events_dropped_ = true; 2635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 2645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) events_.push(event_info); 2655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 2665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} // namespace syncer 268