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

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

Issue 12847003: Separate invalidator and sync client ID (part 2/2) (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix sync_listen_notifications utility Created 7 years, 9 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/notifier/fake_invalidator_unittest.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 2012 The Chromium Authors. All rights reserved. 1 // Copyright 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 Invalidator that wraps an invalidation 5 // An implementation of Invalidator 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 // NonBlockingInvalidator. 10 // NonBlockingInvalidator.
(...skipping 25 matching lines...) Expand all
36 // This class must live on the IO thread. 36 // This class must live on the IO thread.
37 // TODO(dcheng): Think of a name better than InvalidationInvalidator. 37 // TODO(dcheng): Think of a name better than InvalidationInvalidator.
38 class SYNC_EXPORT_PRIVATE InvalidationNotifier 38 class SYNC_EXPORT_PRIVATE InvalidationNotifier
39 : public Invalidator, 39 : public Invalidator,
40 public SyncInvalidationListener::Delegate, 40 public SyncInvalidationListener::Delegate,
41 public base::NonThreadSafe { 41 public base::NonThreadSafe {
42 public: 42 public:
43 // |invalidation_state_tracker| must be initialized. 43 // |invalidation_state_tracker| must be initialized.
44 InvalidationNotifier( 44 InvalidationNotifier(
45 scoped_ptr<notifier::PushClient> push_client, 45 scoped_ptr<notifier::PushClient> push_client,
46 const std::string& invalidator_client_id,
46 const InvalidationStateMap& initial_invalidation_state_map, 47 const InvalidationStateMap& initial_invalidation_state_map,
47 const std::string& invalidation_bootstrap_data, 48 const std::string& invalidation_bootstrap_data,
48 const WeakHandle<InvalidationStateTracker>& 49 const WeakHandle<InvalidationStateTracker>&
49 invalidation_state_tracker, 50 invalidation_state_tracker,
50 const std::string& client_info); 51 const std::string& client_info);
51 52
52 virtual ~InvalidationNotifier(); 53 virtual ~InvalidationNotifier();
53 54
54 // Invalidator implementation. 55 // Invalidator implementation.
55 virtual void RegisterHandler(InvalidationHandler* handler) OVERRIDE; 56 virtual void RegisterHandler(InvalidationHandler* handler) OVERRIDE;
56 virtual void UpdateRegisteredIds(InvalidationHandler* handler, 57 virtual void UpdateRegisteredIds(InvalidationHandler* handler,
57 const ObjectIdSet& ids) OVERRIDE; 58 const ObjectIdSet& ids) OVERRIDE;
58 virtual void UnregisterHandler(InvalidationHandler* handler) OVERRIDE; 59 virtual void UnregisterHandler(InvalidationHandler* handler) OVERRIDE;
59 virtual void Acknowledge(const invalidation::ObjectId& id, 60 virtual void Acknowledge(const invalidation::ObjectId& id,
60 const AckHandle& ack_handle) OVERRIDE; 61 const AckHandle& ack_handle) OVERRIDE;
61 virtual InvalidatorState GetInvalidatorState() const OVERRIDE; 62 virtual InvalidatorState GetInvalidatorState() const OVERRIDE;
62 virtual void SetUniqueId(const std::string& unique_id) OVERRIDE;
63 virtual void UpdateCredentials( 63 virtual void UpdateCredentials(
64 const std::string& email, const std::string& token) OVERRIDE; 64 const std::string& email, const std::string& token) OVERRIDE;
65 virtual void SendInvalidation( 65 virtual void SendInvalidation(
66 const ObjectIdInvalidationMap& invalidation_map) OVERRIDE; 66 const ObjectIdInvalidationMap& invalidation_map) OVERRIDE;
67 67
68 // SyncInvalidationListener::Delegate implementation. 68 // SyncInvalidationListener::Delegate implementation.
69 virtual void OnInvalidate( 69 virtual void OnInvalidate(
70 const ObjectIdInvalidationMap& invalidation_map) OVERRIDE; 70 const ObjectIdInvalidationMap& invalidation_map) OVERRIDE;
71 virtual void OnInvalidatorStateChange(InvalidatorState state) OVERRIDE; 71 virtual void OnInvalidatorStateChange(InvalidatorState state) OVERRIDE;
72 72
(...skipping 15 matching lines...) Expand all
88 const InvalidationStateMap initial_invalidation_state_map_; 88 const InvalidationStateMap initial_invalidation_state_map_;
89 89
90 // Passed to |invalidation_listener_|. 90 // Passed to |invalidation_listener_|.
91 const WeakHandle<InvalidationStateTracker> 91 const WeakHandle<InvalidationStateTracker>
92 invalidation_state_tracker_; 92 invalidation_state_tracker_;
93 93
94 // Passed to |invalidation_listener_|. 94 // Passed to |invalidation_listener_|.
95 const std::string client_info_; 95 const std::string client_info_;
96 96
97 // The client ID to pass to |invalidation_listener_|. 97 // The client ID to pass to |invalidation_listener_|.
98 std::string client_id_; 98 const std::string invalidator_client_id_;
99 99
100 // The initial bootstrap data to pass to |invalidation_listener_|. 100 // The initial bootstrap data to pass to |invalidation_listener_|.
101 const std::string invalidation_bootstrap_data_; 101 const std::string invalidation_bootstrap_data_;
102 102
103 // TODO(akalin): Clean up this reference to DefaultTickClock. Ideally, we 103 // TODO(akalin): Clean up this reference to DefaultTickClock. Ideally, we
104 // should simply be using TaskRunner's tick clock. See http://crbug.com/179211 104 // should simply be using TaskRunner's tick clock. See http://crbug.com/179211
105 base::DefaultTickClock tick_clock_; 105 base::DefaultTickClock tick_clock_;
106 106
107 // The invalidation listener. 107 // The invalidation listener.
108 SyncInvalidationListener invalidation_listener_; 108 SyncInvalidationListener invalidation_listener_;
109 109
110 DISALLOW_COPY_AND_ASSIGN(InvalidationNotifier); 110 DISALLOW_COPY_AND_ASSIGN(InvalidationNotifier);
111 }; 111 };
112 112
113 } // namespace syncer 113 } // namespace syncer
114 114
115 #endif // SYNC_NOTIFIER_INVALIDATION_NOTIFIER_H_ 115 #endif // SYNC_NOTIFIER_INVALIDATION_NOTIFIER_H_
OLDNEW
« no previous file with comments | « sync/notifier/fake_invalidator_unittest.cc ('k') | sync/notifier/invalidation_notifier.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698