Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(788)

Side by Side Diff: sync/notifier/invalidation_notifier.h

Issue 10824161: [Sync] Avoid unregistering object IDs on shutdown (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Work around brittle unit test Created 8 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « sync/internal_api/test/fake_sync_manager.cc ('k') | sync/notifier/invalidation_notifier.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 // 4 //
5 // An implementation of SyncNotifier that wraps an invalidation 5 // An implementation of SyncNotifier that wraps an invalidation
6 // client. Handles the details of connecting to XMPP and hooking it 6 // client. Handles the details of connecting to XMPP and hooking it
7 // up to the invalidation client. 7 // up to the invalidation client.
8 // 8 //
9 // You probably don't want to use this directly; use 9 // You probably don't want to use this directly; use
10 // NonBlockingInvalidationNotifier. 10 // NonBlockingInvalidationNotifier.
11 11
12 #ifndef SYNC_NOTIFIER_INVALIDATION_NOTIFIER_H_ 12 #ifndef SYNC_NOTIFIER_INVALIDATION_NOTIFIER_H_
13 #define SYNC_NOTIFIER_INVALIDATION_NOTIFIER_H_ 13 #define SYNC_NOTIFIER_INVALIDATION_NOTIFIER_H_
14 14
15 #include <string> 15 #include <string>
16 16
17 #include "base/basictypes.h" 17 #include "base/basictypes.h"
18 #include "base/compiler_specific.h" 18 #include "base/compiler_specific.h"
19 #include "base/memory/scoped_ptr.h" 19 #include "base/memory/scoped_ptr.h"
20 #include "base/threading/non_thread_safe.h" 20 #include "base/threading/non_thread_safe.h"
21 #include "sync/internal_api/public/base/model_type.h" 21 #include "sync/internal_api/public/base/model_type.h"
22 #include "sync/internal_api/public/util/weak_handle.h" 22 #include "sync/internal_api/public/util/weak_handle.h"
23 #include "sync/notifier/chrome_invalidation_client.h" 23 #include "sync/notifier/chrome_invalidation_client.h"
24 #include "sync/notifier/invalidation_state_tracker.h" 24 #include "sync/notifier/invalidation_state_tracker.h"
25 #include "sync/notifier/sync_notifier.h" 25 #include "sync/notifier/sync_notifier.h"
26 #include "sync/notifier/sync_notifier_helper.h" 26 #include "sync/notifier/sync_notifier_registrar.h"
27 27
28 namespace notifier { 28 namespace notifier {
29 class PushClient; 29 class PushClient;
30 } // namespace notifier 30 } // namespace notifier
31 31
32 namespace syncer { 32 namespace syncer {
33 33
34 // This class must live on the IO thread. 34 // This class must live on the IO thread.
35 class InvalidationNotifier 35 class InvalidationNotifier
36 : public SyncNotifier, 36 : public SyncNotifier,
37 public ChromeInvalidationClient::Listener, 37 public ChromeInvalidationClient::Listener,
38 public base::NonThreadSafe { 38 public base::NonThreadSafe {
39 public: 39 public:
40 // |invalidation_state_tracker| must be initialized. 40 // |invalidation_state_tracker| must be initialized.
41 InvalidationNotifier( 41 InvalidationNotifier(
42 scoped_ptr<notifier::PushClient> push_client, 42 scoped_ptr<notifier::PushClient> push_client,
43 const InvalidationVersionMap& initial_max_invalidation_versions, 43 const InvalidationVersionMap& initial_max_invalidation_versions,
44 const std::string& initial_invalidation_state, 44 const std::string& initial_invalidation_state,
45 const WeakHandle<InvalidationStateTracker>& 45 const WeakHandle<InvalidationStateTracker>&
46 invalidation_state_tracker, 46 invalidation_state_tracker,
47 const std::string& client_info); 47 const std::string& client_info);
48 48
49 virtual ~InvalidationNotifier(); 49 virtual ~InvalidationNotifier();
50 50
51 // SyncNotifier implementation. 51 // SyncNotifier implementation.
52 virtual void RegisterHandler(SyncNotifierObserver* handler) OVERRIDE;
52 virtual void UpdateRegisteredIds(SyncNotifierObserver* handler, 53 virtual void UpdateRegisteredIds(SyncNotifierObserver* handler,
53 const ObjectIdSet& ids) OVERRIDE; 54 const ObjectIdSet& ids) OVERRIDE;
55 virtual void UnregisterHandler(SyncNotifierObserver* handler) OVERRIDE;
54 virtual void SetUniqueId(const std::string& unique_id) OVERRIDE; 56 virtual void SetUniqueId(const std::string& unique_id) OVERRIDE;
55 virtual void SetStateDeprecated(const std::string& state) OVERRIDE; 57 virtual void SetStateDeprecated(const std::string& state) OVERRIDE;
56 virtual void UpdateCredentials( 58 virtual void UpdateCredentials(
57 const std::string& email, const std::string& token) OVERRIDE; 59 const std::string& email, const std::string& token) OVERRIDE;
58 virtual void SendNotification(ModelTypeSet changed_types) OVERRIDE; 60 virtual void SendNotification(ModelTypeSet changed_types) OVERRIDE;
59 61
60 // ChromeInvalidationClient::Listener implementation. 62 // ChromeInvalidationClient::Listener implementation.
61 virtual void OnInvalidate(const ObjectIdPayloadMap& id_payloads) OVERRIDE; 63 virtual void OnInvalidate(const ObjectIdPayloadMap& id_payloads) OVERRIDE;
62 virtual void OnNotificationsEnabled() OVERRIDE; 64 virtual void OnNotificationsEnabled() OVERRIDE;
63 virtual void OnNotificationsDisabled( 65 virtual void OnNotificationsDisabled(
64 NotificationsDisabledReason reason) OVERRIDE; 66 NotificationsDisabledReason reason) OVERRIDE;
65 67
66 private: 68 private:
67 // We start off in the STOPPED state. When we get our initial 69 // We start off in the STOPPED state. When we get our initial
68 // credentials, we connect and move to the CONNECTING state. When 70 // credentials, we connect and move to the CONNECTING state. When
69 // we're connected we start the invalidation client and move to the 71 // we're connected we start the invalidation client and move to the
70 // STARTED state. We never go back to a previous state. 72 // STARTED state. We never go back to a previous state.
71 enum State { 73 enum State {
72 STOPPED, 74 STOPPED,
73 CONNECTING, 75 CONNECTING,
74 STARTED 76 STARTED
75 }; 77 };
76 State state_; 78 State state_;
77 79
78 SyncNotifierHelper helper_; 80 SyncNotifierRegistrar registrar_;
79 81
80 // Passed to |invalidation_client_|. 82 // Passed to |invalidation_client_|.
81 const InvalidationVersionMap initial_max_invalidation_versions_; 83 const InvalidationVersionMap initial_max_invalidation_versions_;
82 84
83 // Passed to |invalidation_client_|. 85 // Passed to |invalidation_client_|.
84 const WeakHandle<InvalidationStateTracker> 86 const WeakHandle<InvalidationStateTracker>
85 invalidation_state_tracker_; 87 invalidation_state_tracker_;
86 88
87 // Passed to |invalidation_client_|. 89 // Passed to |invalidation_client_|.
88 const std::string client_info_; 90 const std::string client_info_;
89 91
90 // The client ID to pass to |chrome_invalidation_client_|. 92 // The client ID to pass to |chrome_invalidation_client_|.
91 std::string invalidation_client_id_; 93 std::string invalidation_client_id_;
92 94
93 // The state to pass to |chrome_invalidation_client_|. 95 // The state to pass to |chrome_invalidation_client_|.
94 // TODO(tim): This should be made const once migration is completed for bug 96 // TODO(tim): This should be made const once migration is completed for bug
95 // 124140. 97 // 124140.
96 std::string invalidation_state_; 98 std::string invalidation_state_;
97 99
98 // The invalidation client. 100 // The invalidation client.
99 ChromeInvalidationClient invalidation_client_; 101 ChromeInvalidationClient invalidation_client_;
100 102
101 DISALLOW_COPY_AND_ASSIGN(InvalidationNotifier); 103 DISALLOW_COPY_AND_ASSIGN(InvalidationNotifier);
102 }; 104 };
103 105
104 } // namespace syncer 106 } // namespace syncer
105 107
106 #endif // SYNC_NOTIFIER_INVALIDATION_NOTIFIER_H_ 108 #endif // SYNC_NOTIFIER_INVALIDATION_NOTIFIER_H_
OLDNEW
« no previous file with comments | « sync/internal_api/test/fake_sync_manager.cc ('k') | sync/notifier/invalidation_notifier.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698