1ddb351dbec246cf1fab5ec20d2d5520909041de1Kristian Monsen// Copyright (c) 2011 The Chromium Authors. All rights reserved. 2c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch// Use of this source code is governed by a BSD-style license that can be 3c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch// found in the LICENSE file. 4c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 5c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch#ifndef CHROME_BROWSER_SYNC_ENGINE_SYNCER_TYPES_H_ 6c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch#define CHROME_BROWSER_SYNC_ENGINE_SYNCER_TYPES_H_ 73345a6884c488ff3a535c2c9acdd33d74b37e311Iain Merrick#pragma once 8c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 9c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch#include <map> 10c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch#include <vector> 11c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 12731df977c0511bca2206b5f333555b1205ff1f43Iain Merrick#include "base/observer_list.h" 13ddb351dbec246cf1fab5ec20d2d5520909041de1Kristian Monsen#include "chrome/browser/sync/syncable/model_type.h" 14c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 15c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdochnamespace syncable { 16c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdochclass BaseTransaction; 17c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdochclass Id; 18c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch} 19c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 20c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch// The intent of this is to keep all shared data types and enums for the syncer 21c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch// in a single place without having dependencies between other files. 22c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdochnamespace browser_sync { 23c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 24c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdochnamespace sessions { 25c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdochstruct SyncSessionSnapshot; 26c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch} 27c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdochclass Syncer; 28c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 29c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdochenum UpdateAttemptResponse { 30c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // Update was applied or safely ignored. 31c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch SUCCESS, 32c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 33c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // Conflicts with the local data representation. This can also mean that the 34c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // entry doesn't currently make sense if we applied it. 35c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch CONFLICT, 36c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch}; 37c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 38c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdochenum ServerUpdateProcessingResult { 39c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // Success. Update applied and stored in SERVER_* fields or dropped if 40c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // irrelevant. 41c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch SUCCESS_PROCESSED, 42c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 43c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // Success. Update details stored in SERVER_* fields, but wasn't applied. 44c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch SUCCESS_STORED, 45c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 46c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // Update is illegally inconsistent with earlier updates. e.g. A bookmark 47c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // becoming a folder. 48c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch FAILED_INCONSISTENT, 49c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 50c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // Update is illegal when considered alone. e.g. broken UTF-8 in the name. 51c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch FAILED_CORRUPT, 52c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 53c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // Only used by VerifyUpdate. Indicates that an update is valid. As 54c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // VerifyUpdate cannot return SUCCESS_STORED, we reuse the value. 55c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch SUCCESS_VALID = SUCCESS_STORED 56c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch}; 57c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 58c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch// Different results from the verify phase will yield different methods of 59c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch// processing in the ProcessUpdates phase. The SKIP result means the entry 60c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch// doesn't go to the ProcessUpdates phase. 61c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdochenum VerifyResult { 62c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch VERIFY_FAIL, 63c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch VERIFY_SUCCESS, 64c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch VERIFY_UNDELETE, 65c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch VERIFY_SKIP, 66c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch VERIFY_UNDECIDED 67c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch}; 68c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 69c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdochenum VerifyCommitResult { 70c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch VERIFY_UNSYNCABLE, 71c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch VERIFY_OK, 72c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch}; 73c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 74731df977c0511bca2206b5f333555b1205ff1f43Iain Merrickstruct SyncEngineEvent { 75c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch enum EventCause { 76731df977c0511bca2206b5f333555b1205ff1f43Iain Merrick //////////////////////////////////////////////////////////////// 77731df977c0511bca2206b5f333555b1205ff1f43Iain Merrick // SyncerCommand generated events. 78c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch STATUS_CHANGED, 79c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 80c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // We have reached the SYNCER_END state in the main sync loop. 81c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // Check the SyncerSession for information like whether we need to continue 82c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // syncing (SyncerSession::HasMoreToSync). 83c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch SYNC_CYCLE_ENDED, 84c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 85731df977c0511bca2206b5f333555b1205ff1f43Iain Merrick //////////////////////////////////////////////////////////////// 86731df977c0511bca2206b5f333555b1205ff1f43Iain Merrick // Generated in response to specific protocol actions or events. 87731df977c0511bca2206b5f333555b1205ff1f43Iain Merrick 88731df977c0511bca2206b5f333555b1205ff1f43Iain Merrick // New token in updated_token. 89731df977c0511bca2206b5f333555b1205ff1f43Iain Merrick UPDATED_TOKEN, 90c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 91c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // This is sent after the Syncer (and SyncerThread) have initiated self 92c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // halt due to no longer being permitted to communicate with the server. 93c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // The listener should sever the sync / browser connections and delete sync 94c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // data (i.e. as if the user clicked 'Stop Syncing' in the browser. 95c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch STOP_SYNCING_PERMANENTLY, 96c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 973345a6884c488ff3a535c2c9acdd33d74b37e311Iain Merrick // These events are sent to indicate when we know the clearing of 983345a6884c488ff3a535c2c9acdd33d74b37e311Iain Merrick // server data have failed or succeeded. 993345a6884c488ff3a535c2c9acdd33d74b37e311Iain Merrick CLEAR_SERVER_DATA_SUCCEEDED, 1003345a6884c488ff3a535c2c9acdd33d74b37e311Iain Merrick CLEAR_SERVER_DATA_FAILED, 101c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch }; 102c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 103ddb351dbec246cf1fab5ec20d2d5520909041de1Kristian Monsen explicit SyncEngineEvent(EventCause cause); 104ddb351dbec246cf1fab5ec20d2d5520909041de1Kristian Monsen ~SyncEngineEvent(); 105c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 106c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch EventCause what_happened; 107c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 108c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch // The last session used for syncing. 109c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch const sessions::SyncSessionSnapshot* snapshot; 110c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 1113345a6884c488ff3a535c2c9acdd33d74b37e311Iain Merrick // Update-Client-Auth returns a new token for sync use. 1123345a6884c488ff3a535c2c9acdd33d74b37e311Iain Merrick std::string updated_token; 113c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch}; 114c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 115731df977c0511bca2206b5f333555b1205ff1f43Iain Merrickclass SyncEngineEventListener { 116731df977c0511bca2206b5f333555b1205ff1f43Iain Merrick public: 117731df977c0511bca2206b5f333555b1205ff1f43Iain Merrick // TODO(tim): Consider splitting this up to multiple callbacks, rather than 118731df977c0511bca2206b5f333555b1205ff1f43Iain Merrick // have to do Event e(type); OnSyncEngineEvent(e); at all callsites, 119731df977c0511bca2206b5f333555b1205ff1f43Iain Merrick virtual void OnSyncEngineEvent(const SyncEngineEvent& event) = 0; 120731df977c0511bca2206b5f333555b1205ff1f43Iain Merrick protected: 121731df977c0511bca2206b5f333555b1205ff1f43Iain Merrick virtual ~SyncEngineEventListener() {} 122c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch}; 123c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 124c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch// This struct is passed between parts of the syncer during the processing of 125c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch// one sync loop. It lives on the stack. We don't expose the number of 126c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch// conflicts during SyncShare as the conflicts may be solved automatically 127c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch// by the conflict resolver. 128c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdochtypedef std::vector<syncable::Id> ConflictSet; 129c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 130c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdochtypedef std::map<syncable::Id, ConflictSet*> IdToConflictSetMap; 131c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 132c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch} // namespace browser_sync 133c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch 134c407dc5cd9bdc5668497f21b26b09d988ab439deBen Murdoch#endif // CHROME_BROWSER_SYNC_ENGINE_SYNCER_TYPES_H_ 135