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