• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 //
5 // A simple wrapper around invalidation::InvalidationClient that
6 // handles all the startup/shutdown details and hookups.
7 
8 #ifndef COMPONENTS_INVALIDATION_SYNC_INVALIDATION_LISTENER_H_
9 #define COMPONENTS_INVALIDATION_SYNC_INVALIDATION_LISTENER_H_
10 
11 #include <string>
12 
13 #include "base/basictypes.h"
14 #include "base/callback_forward.h"
15 #include "base/compiler_specific.h"
16 #include "base/memory/scoped_ptr.h"
17 #include "base/memory/weak_ptr.h"
18 #include "base/threading/non_thread_safe.h"
19 #include "components/invalidation/ack_handler.h"
20 #include "components/invalidation/invalidation_export.h"
21 #include "components/invalidation/invalidation_state_tracker.h"
22 #include "components/invalidation/invalidator_state.h"
23 #include "components/invalidation/state_writer.h"
24 #include "components/invalidation/sync_system_resources.h"
25 #include "components/invalidation/unacked_invalidation_set.h"
26 #include "google/cacheinvalidation/include/invalidation-listener.h"
27 
28 namespace buzz {
29 class XmppTaskParentInterface;
30 }  // namespace buzz
31 
32 namespace notifier {
33 class PushClient;
34 }  // namespace notifier
35 
36 namespace syncer {
37 
38 class ObjectIdInvalidationMap;
39 class RegistrationManager;
40 
41 // SyncInvalidationListener is not thread-safe and lives on the sync
42 // thread.
43 class INVALIDATION_EXPORT_PRIVATE SyncInvalidationListener
NON_EXPORTED_BASE(invalidation::InvalidationListener)44     : public NON_EXPORTED_BASE(invalidation::InvalidationListener),
45       public StateWriter,
46       public SyncNetworkChannel::Observer,
47       public AckHandler,
48       public base::NonThreadSafe {
49  public:
50   typedef base::Callback<invalidation::InvalidationClient*(
51       invalidation::SystemResources*,
52       int,
53       const invalidation::string&,
54       const invalidation::string&,
55       invalidation::InvalidationListener*)> CreateInvalidationClientCallback;
56 
57   class INVALIDATION_EXPORT_PRIVATE Delegate {
58    public:
59     virtual ~Delegate();
60 
61     virtual void OnInvalidate(
62         const ObjectIdInvalidationMap& invalidations) = 0;
63 
64     virtual void OnInvalidatorStateChange(InvalidatorState state) = 0;
65   };
66 
67   explicit SyncInvalidationListener(
68       scoped_ptr<SyncNetworkChannel> network_channel);
69 
70   // Calls Stop().
71   virtual ~SyncInvalidationListener();
72 
73   // Does not take ownership of |delegate| or |state_writer|.
74   // |invalidation_state_tracker| must be initialized.
75   void Start(
76       const CreateInvalidationClientCallback&
77           create_invalidation_client_callback,
78       const std::string& client_id,
79       const std::string& client_info,
80       const std::string& invalidation_bootstrap_data,
81       const UnackedInvalidationsMap& initial_object_states,
82       const base::WeakPtr<InvalidationStateTracker>& invalidation_state_tracker,
83       const scoped_refptr<base::SequencedTaskRunner>&
84           invalidation_state_tracker_task_runner,
85       Delegate* delegate);
86 
87   void UpdateCredentials(const std::string& email, const std::string& token);
88 
89   // Update the set of object IDs that we're interested in getting
90   // notifications for.  May be called at any time.
91   void UpdateRegisteredIds(const ObjectIdSet& ids);
92 
93   // invalidation::InvalidationListener implementation.
94   virtual void Ready(
95       invalidation::InvalidationClient* client) OVERRIDE;
96   virtual void Invalidate(
97       invalidation::InvalidationClient* client,
98       const invalidation::Invalidation& invalidation,
99       const invalidation::AckHandle& ack_handle) OVERRIDE;
100   virtual void InvalidateUnknownVersion(
101       invalidation::InvalidationClient* client,
102       const invalidation::ObjectId& object_id,
103       const invalidation::AckHandle& ack_handle) OVERRIDE;
104   virtual void InvalidateAll(
105       invalidation::InvalidationClient* client,
106       const invalidation::AckHandle& ack_handle) OVERRIDE;
107   virtual void InformRegistrationStatus(
108       invalidation::InvalidationClient* client,
109       const invalidation::ObjectId& object_id,
110       invalidation::InvalidationListener::RegistrationState reg_state) OVERRIDE;
111   virtual void InformRegistrationFailure(
112       invalidation::InvalidationClient* client,
113       const invalidation::ObjectId& object_id,
114       bool is_transient,
115       const std::string& error_message) OVERRIDE;
116   virtual void ReissueRegistrations(
117       invalidation::InvalidationClient* client,
118       const std::string& prefix,
119       int prefix_length) OVERRIDE;
120   virtual void InformError(
121       invalidation::InvalidationClient* client,
122       const invalidation::ErrorInfo& error_info) OVERRIDE;
123 
124   // AckHandler implementation.
125   virtual void Acknowledge(
126       const invalidation::ObjectId& id,
127       const syncer::AckHandle& handle) OVERRIDE;
128   virtual void Drop(
129       const invalidation::ObjectId& id,
130       const syncer::AckHandle& handle) OVERRIDE;
131 
132   // StateWriter implementation.
133   virtual void WriteState(const std::string& state) OVERRIDE;
134 
135   // SyncNetworkChannel::Observer implementation.
136   virtual void OnNetworkChannelStateChanged(
137       InvalidatorState invalidator_state) OVERRIDE;
138 
139   void DoRegistrationUpdate();
140 
141   void RequestDetailedStatus(
142       base::Callback<void(const base::DictionaryValue&)> callback) const;
143 
144   void StopForTest();
145 
146  private:
147   void Stop();
148 
149   InvalidatorState GetState() const;
150 
151   void EmitStateChange();
152 
153   // Sends invalidations to their appropriate destination.
154   //
155   // If there are no observers registered for them, they will be saved for
156   // later.
157   //
158   // If there are observers registered, they will be saved (to make sure we
159   // don't drop them until they've been acted on) and emitted to the observers.
160   void DispatchInvalidations(const ObjectIdInvalidationMap& invalidations);
161 
162   // Saves invalidations.
163   //
164   // This call isn't synchronous so we can't guarantee these invalidations will
165   // be safely on disk by the end of the call, but it should ensure that the
166   // data makes it to disk eventually.
167   void SaveInvalidations(const ObjectIdInvalidationMap& to_save);
168 
169   // Emits previously saved invalidations to their registered observers.
170   void EmitSavedInvalidations(const ObjectIdInvalidationMap& to_emit);
171 
172   // Generate a Dictionary with all the debugging information.
173   scoped_ptr<base::DictionaryValue> CollectDebugData() const;
174 
175   base::WeakPtr<AckHandler> AsWeakPtr();
176 
177   scoped_ptr<SyncNetworkChannel> sync_network_channel_;
178   SyncSystemResources sync_system_resources_;
179   UnackedInvalidationsMap unacked_invalidations_map_;
180   base::WeakPtr<InvalidationStateTracker> invalidation_state_tracker_;
181   scoped_refptr<base::SequencedTaskRunner>
182       invalidation_state_tracker_task_runner_;
183   Delegate* delegate_;
184   scoped_ptr<invalidation::InvalidationClient> invalidation_client_;
185   scoped_ptr<RegistrationManager> registration_manager_;
186   // Stored to pass to |registration_manager_| on start.
187   ObjectIdSet registered_ids_;
188 
189   // The states of the ticl and the push client.
190   InvalidatorState ticl_state_;
191   InvalidatorState push_client_state_;
192 
193   base::WeakPtrFactory<SyncInvalidationListener> weak_ptr_factory_;
194 
195   DISALLOW_COPY_AND_ASSIGN(SyncInvalidationListener);
196 };
197 
198 }  // namespace syncer
199 
200 #endif  // COMPONENTS_INVALIDATION_SYNC_INVALIDATION_LISTENER_H_
201