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 invalidator that uses p2p invalidations based on XMPP push
6 // notifications. Used only for sync integration tests.
8 #ifndef SYNC_NOTIFIER_P2P_INVALIDATOR_H_
9 #define SYNC_NOTIFIER_P2P_INVALIDATOR_H_
13 #include "base/compiler_specific.h"
14 #include "base/memory/ref_counted.h"
15 #include "base/memory/scoped_ptr.h"
16 #include "base/memory/weak_ptr.h"
17 #include "base/observer_list.h"
18 #include "base/threading/thread_checker.h"
19 #include "jingle/notifier/base/notifier_options.h"
20 #include "jingle/notifier/listener/push_client.h"
21 #include "jingle/notifier/listener/push_client_observer.h"
22 #include "sync/base/sync_export.h"
23 #include "sync/internal_api/public/base/model_type.h"
24 #include "sync/notifier/invalidator.h"
25 #include "sync/notifier/invalidator_registrar.h"
26 #include "sync/notifier/invalidator_state.h"
27 #include "sync/notifier/object_id_invalidation_map.h"
31 } // namespace notifier
35 // The channel to use for sync notifications.
36 SYNC_EXPORT
extern const char kSyncP2PNotificationChannel
[];
38 // The intended recipient(s) of a P2P notification.
39 enum P2PNotificationTarget
{
41 FIRST_NOTIFICATION_TARGET
= NOTIFY_SELF
,
44 LAST_NOTIFICATION_TARGET
= NOTIFY_ALL
47 SYNC_EXPORT_PRIVATE
std::string
P2PNotificationTargetToString(
48 P2PNotificationTarget target
);
50 // If |target_str| can't be parsed, assumes NOTIFY_SELF.
51 SYNC_EXPORT_PRIVATE P2PNotificationTarget
P2PNotificationTargetFromString(
52 const std::string
& target_str
);
54 // Helper notification data class that can be serialized to and
55 // deserialized from a string.
56 class SYNC_EXPORT_PRIVATE P2PNotificationData
{
58 // Initializes with an empty sender ID, target set to NOTIFY_SELF,
59 // and empty changed types.
60 P2PNotificationData();
61 P2PNotificationData(const std::string
& sender_id
,
62 P2PNotificationTarget target
,
63 const ObjectIdInvalidationMap
& invalidation_map
);
65 ~P2PNotificationData();
67 // Returns true if the given ID is targeted by this notification.
68 bool IsTargeted(const std::string
& id
) const;
70 const ObjectIdInvalidationMap
& GetIdInvalidationMap() const;
72 bool Equals(const P2PNotificationData
& other
) const;
74 std::string
ToString() const;
76 // Returns whether parsing |str| was successful. If parsing was
77 // unsuccessful, the state of the notification is undefined.
78 bool ResetFromString(const std::string
& str
);
81 // The unique ID of the client that sent the notification.
82 std::string sender_id_
;
83 // The intendent recipient(s) of the notification.
84 P2PNotificationTarget target_
;
85 // The invalidation map for the notification.
86 ObjectIdInvalidationMap invalidation_map_
;
89 class SYNC_EXPORT_PRIVATE P2PInvalidator
91 public NON_EXPORTED_BASE(notifier::PushClientObserver
) {
93 // The |send_notification_target| parameter was added to allow us to send
94 // self-notifications in some cases, but not others. The value should be
95 // either NOTIFY_ALL to send notifications to all clients, or NOTIFY_OTHERS
96 // to send notifications to all clients except for the one that triggered the
97 // notification. See crbug.com/97780.
98 P2PInvalidator(scoped_ptr
<notifier::PushClient
> push_client
,
99 const std::string
& invalidator_client_id
,
100 P2PNotificationTarget send_notification_target
);
102 virtual ~P2PInvalidator();
104 // Invalidator implementation.
105 virtual void RegisterHandler(InvalidationHandler
* handler
) OVERRIDE
;
106 virtual void UpdateRegisteredIds(InvalidationHandler
* handler
,
107 const ObjectIdSet
& ids
) OVERRIDE
;
108 virtual void UnregisterHandler(InvalidationHandler
* handler
) OVERRIDE
;
109 virtual InvalidatorState
GetInvalidatorState() const OVERRIDE
;
110 virtual void UpdateCredentials(
111 const std::string
& email
, const std::string
& token
) OVERRIDE
;
112 virtual void RequestDetailedStatus(
113 base::Callback
<void(const base::DictionaryValue
&)> callback
) const
116 // PushClientObserver implementation.
117 virtual void OnNotificationsEnabled() OVERRIDE
;
118 virtual void OnNotificationsDisabled(
119 notifier::NotificationsDisabledReason reason
) OVERRIDE
;
120 virtual void OnIncomingNotification(
121 const notifier::Notification
& notification
) OVERRIDE
;
123 void SendInvalidation(const ObjectIdSet
& ids
);
125 void SendNotificationDataForTest(
126 const P2PNotificationData
& notification_data
);
129 void SendNotificationData(const P2PNotificationData
& notification_data
);
131 base::ThreadChecker thread_checker_
;
133 InvalidatorRegistrar registrar_
;
136 scoped_ptr
<notifier::PushClient
> push_client_
;
138 std::string invalidator_client_id_
;
139 // Whether we have called UpdateCredentials() yet.
141 bool notifications_enabled_
;
142 // Which set of clients should be sent notifications.
143 P2PNotificationTarget send_notification_target_
;
145 DISALLOW_COPY_AND_ASSIGN(P2PInvalidator
);
148 } // namespace syncer
150 #endif // SYNC_NOTIFIER_P2P_INVALIDATOR_H_