// Copyright 2014 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "sync/engine/get_updates_delegate.h" #include "sync/engine/directory_update_handler.h" #include "sync/engine/get_updates_processor.h" #include "sync/internal_api/public/events/configure_get_updates_request_event.h" #include "sync/internal_api/public/events/normal_get_updates_request_event.h" #include "sync/internal_api/public/events/poll_get_updates_request_event.h" namespace syncer { namespace { void NonPassiveApplyUpdates( ModelTypeSet gu_types, sessions::StatusController* status_controller, UpdateHandlerMap* update_handler_map) { for (UpdateHandlerMap::iterator it = update_handler_map->begin(); it != update_handler_map->end(); ++it) { if (gu_types.Has(it->first)) it->second->ApplyUpdates(status_controller); } } void PassiveApplyUpdates( ModelTypeSet gu_types, sessions::StatusController* status_controller, UpdateHandlerMap* update_handler_map) { for (UpdateHandlerMap::iterator it = update_handler_map->begin(); it != update_handler_map->end(); ++it) { if (gu_types.Has(it->first)) it->second->PassiveApplyUpdates(status_controller); } } } // namespace GetUpdatesDelegate::GetUpdatesDelegate() {} GetUpdatesDelegate::~GetUpdatesDelegate() {} NormalGetUpdatesDelegate::NormalGetUpdatesDelegate( const sessions::NudgeTracker& nudge_tracker) : nudge_tracker_(nudge_tracker) {} NormalGetUpdatesDelegate::~NormalGetUpdatesDelegate() {} // This function assumes the progress markers have already been populated. void NormalGetUpdatesDelegate::HelpPopulateGuMessage( sync_pb::GetUpdatesMessage* get_updates) const { // Set legacy GetUpdatesMessage.GetUpdatesCallerInfo information. get_updates->mutable_caller_info()->set_source( nudge_tracker_.GetLegacySource()); // Set the new and improved version of source, too. get_updates->set_get_updates_origin(sync_pb::SyncEnums::GU_TRIGGER); get_updates->set_is_retry(nudge_tracker_.IsRetryRequired()); // Special case: A GU performed for no other reason than retry will have its // origin set to RETRY. if (nudge_tracker_.GetLegacySource() == sync_pb::GetUpdatesCallerInfo::RETRY) get_updates->set_get_updates_origin(sync_pb::SyncEnums::RETRY); // Fill in the notification hints. for (int i = 0; i < get_updates->from_progress_marker_size(); ++i) { sync_pb::DataTypeProgressMarker* progress_marker = get_updates->mutable_from_progress_marker(i); ModelType type = GetModelTypeFromSpecificsFieldNumber( progress_marker->data_type_id()); DCHECK(!nudge_tracker_.IsTypeThrottled(type)) << "Throttled types should have been removed from the request_types."; nudge_tracker_.SetLegacyNotificationHint(type, progress_marker); nudge_tracker_.FillProtoMessage( type, progress_marker->mutable_get_update_triggers()); } } void NormalGetUpdatesDelegate::ApplyUpdates( ModelTypeSet gu_types, sessions::StatusController* status_controller, UpdateHandlerMap* update_handler_map) const { NonPassiveApplyUpdates(gu_types, status_controller, update_handler_map); } scoped_ptr<ProtocolEvent> NormalGetUpdatesDelegate::GetNetworkRequestEvent( base::Time timestamp, const sync_pb::ClientToServerMessage& request) const { return scoped_ptr<ProtocolEvent>( new NormalGetUpdatesRequestEvent(timestamp, nudge_tracker_, request)); } ConfigureGetUpdatesDelegate::ConfigureGetUpdatesDelegate( sync_pb::GetUpdatesCallerInfo::GetUpdatesSource source) : source_(source) {} ConfigureGetUpdatesDelegate::~ConfigureGetUpdatesDelegate() {} void ConfigureGetUpdatesDelegate::HelpPopulateGuMessage( sync_pb::GetUpdatesMessage* get_updates) const { get_updates->mutable_caller_info()->set_source(source_); get_updates->set_get_updates_origin(ConvertConfigureSourceToOrigin(source_)); } void ConfigureGetUpdatesDelegate::ApplyUpdates( ModelTypeSet gu_types, sessions::StatusController* status_controller, UpdateHandlerMap* update_handler_map) const { PassiveApplyUpdates(gu_types, status_controller, update_handler_map); } scoped_ptr<ProtocolEvent> ConfigureGetUpdatesDelegate::GetNetworkRequestEvent( base::Time timestamp, const sync_pb::ClientToServerMessage& request) const { return scoped_ptr<ProtocolEvent>( new ConfigureGetUpdatesRequestEvent( timestamp, ConvertConfigureSourceToOrigin(source_), request)); } sync_pb::SyncEnums::GetUpdatesOrigin ConfigureGetUpdatesDelegate::ConvertConfigureSourceToOrigin( sync_pb::GetUpdatesCallerInfo::GetUpdatesSource source) { switch (source) { // Configurations: case sync_pb::GetUpdatesCallerInfo::NEWLY_SUPPORTED_DATATYPE: return sync_pb::SyncEnums::NEWLY_SUPPORTED_DATATYPE; case sync_pb::GetUpdatesCallerInfo::MIGRATION: return sync_pb::SyncEnums::MIGRATION; case sync_pb::GetUpdatesCallerInfo::RECONFIGURATION: return sync_pb::SyncEnums::RECONFIGURATION; case sync_pb::GetUpdatesCallerInfo::NEW_CLIENT: return sync_pb::SyncEnums::NEW_CLIENT; case sync_pb::GetUpdatesCallerInfo::PROGRAMMATIC: return sync_pb::SyncEnums::PROGRAMMATIC; default: NOTREACHED(); return sync_pb::SyncEnums::UNKNOWN_ORIGIN; } } PollGetUpdatesDelegate::PollGetUpdatesDelegate() {} PollGetUpdatesDelegate::~PollGetUpdatesDelegate() {} void PollGetUpdatesDelegate::HelpPopulateGuMessage( sync_pb::GetUpdatesMessage* get_updates) const { // Set legacy GetUpdatesMessage.GetUpdatesCallerInfo information. get_updates->mutable_caller_info()->set_source( sync_pb::GetUpdatesCallerInfo::PERIODIC); // Set the new and improved version of source, too. get_updates->set_get_updates_origin(sync_pb::SyncEnums::PERIODIC); } void PollGetUpdatesDelegate::ApplyUpdates( ModelTypeSet gu_types, sessions::StatusController* status_controller, UpdateHandlerMap* update_handler_map) const { NonPassiveApplyUpdates(gu_types, status_controller, update_handler_map); } scoped_ptr<ProtocolEvent> PollGetUpdatesDelegate::GetNetworkRequestEvent( base::Time timestamp, const sync_pb::ClientToServerMessage& request) const { return scoped_ptr<ProtocolEvent>( new PollGetUpdatesRequestEvent(timestamp, request)); } } // namespace syncer