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
3 // found in the LICENSE file.
5 // An implementation of Invalidator that wraps an invalidation
6 // client. Handles the details of connecting to XMPP and hooking it
7 // up to the invalidation client.
9 // You probably don't want to use this directly; use
10 // NonBlockingInvalidator.
12 #ifndef SYNC_NOTIFIER_INVALIDATION_NOTIFIER_H_
13 #define SYNC_NOTIFIER_INVALIDATION_NOTIFIER_H_
17 #include "base/basictypes.h"
18 #include "base/compiler_specific.h"
19 #include "base/memory/scoped_ptr.h"
20 #include "base/threading/non_thread_safe.h"
21 #include "base/time/default_tick_clock.h"
22 #include "sync/base/sync_export.h"
23 #include "sync/internal_api/public/base/model_type.h"
24 #include "sync/internal_api/public/util/weak_handle.h"
25 #include "sync/notifier/invalidation_state_tracker.h"
26 #include "sync/notifier/invalidator.h"
27 #include "sync/notifier/invalidator_registrar.h"
28 #include "sync/notifier/sync_invalidation_listener.h"
32 } // namespace notifier
36 // This class must live on the IO thread.
37 // TODO(dcheng): Think of a name better than InvalidationInvalidator.
38 class SYNC_EXPORT_PRIVATE InvalidationNotifier
40 public SyncInvalidationListener::Delegate
,
41 public base::NonThreadSafe
{
43 // |invalidation_state_tracker| must be initialized.
45 scoped_ptr
<notifier::PushClient
> push_client
,
46 const std::string
& invalidator_client_id
,
47 const InvalidationStateMap
& initial_invalidation_state_map
,
48 const std::string
& invalidation_bootstrap_data
,
49 const WeakHandle
<InvalidationStateTracker
>&
50 invalidation_state_tracker
,
51 const std::string
& client_info
);
53 virtual ~InvalidationNotifier();
55 // Invalidator implementation.
56 virtual void RegisterHandler(InvalidationHandler
* handler
) OVERRIDE
;
57 virtual void UpdateRegisteredIds(InvalidationHandler
* handler
,
58 const ObjectIdSet
& ids
) OVERRIDE
;
59 virtual void UnregisterHandler(InvalidationHandler
* handler
) OVERRIDE
;
60 virtual void Acknowledge(const invalidation::ObjectId
& id
,
61 const AckHandle
& ack_handle
) OVERRIDE
;
62 virtual InvalidatorState
GetInvalidatorState() const OVERRIDE
;
63 virtual void UpdateCredentials(
64 const std::string
& email
, const std::string
& token
) OVERRIDE
;
66 // SyncInvalidationListener::Delegate implementation.
67 virtual void OnInvalidate(
68 const ObjectIdInvalidationMap
& invalidation_map
) OVERRIDE
;
69 virtual void OnInvalidatorStateChange(InvalidatorState state
) OVERRIDE
;
72 // We start off in the STOPPED state. When we get our initial
73 // credentials, we connect and move to the CONNECTING state. When
74 // we're connected we start the invalidation client and move to the
75 // STARTED state. We never go back to a previous state.
83 InvalidatorRegistrar registrar_
;
85 // Passed to |invalidation_listener_|.
86 const InvalidationStateMap initial_invalidation_state_map_
;
88 // Passed to |invalidation_listener_|.
89 const WeakHandle
<InvalidationStateTracker
>
90 invalidation_state_tracker_
;
92 // Passed to |invalidation_listener_|.
93 const std::string client_info_
;
95 // The client ID to pass to |invalidation_listener_|.
96 const std::string invalidator_client_id_
;
98 // The initial bootstrap data to pass to |invalidation_listener_|.
99 const std::string invalidation_bootstrap_data_
;
101 // TODO(akalin): Clean up this reference to DefaultTickClock. Ideally, we
102 // should simply be using TaskRunner's tick clock. See http://crbug.com/179211
103 base::DefaultTickClock tick_clock_
;
105 // The invalidation listener.
106 SyncInvalidationListener invalidation_listener_
;
108 DISALLOW_COPY_AND_ASSIGN(InvalidationNotifier
);
111 } // namespace syncer
113 #endif // SYNC_NOTIFIER_INVALIDATION_NOTIFIER_H_