- add sources.
[platform/framework/web/crosswalk.git] / src / sync / notifier / p2p_invalidator.h
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.
4 //
5 // An invalidator that uses p2p invalidations based on XMPP push
6 // notifications.  Used only for sync integration tests.
7
8 #ifndef SYNC_NOTIFIER_P2P_INVALIDATOR_H_
9 #define SYNC_NOTIFIER_P2P_INVALIDATOR_H_
10
11 #include <string>
12
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"
28
29 namespace notifier {
30 class PushClient;
31 }  // namespace notifier
32
33 namespace syncer {
34
35 // The channel to use for sync notifications.
36 SYNC_EXPORT extern const char kSyncP2PNotificationChannel[];
37
38 // The intended recipient(s) of a P2P notification.
39 enum P2PNotificationTarget {
40   NOTIFY_SELF,
41   FIRST_NOTIFICATION_TARGET = NOTIFY_SELF,
42   NOTIFY_OTHERS,
43   NOTIFY_ALL,
44   LAST_NOTIFICATION_TARGET = NOTIFY_ALL
45 };
46
47 SYNC_EXPORT_PRIVATE std::string P2PNotificationTargetToString(
48     P2PNotificationTarget target);
49
50 // If |target_str| can't be parsed, assumes NOTIFY_SELF.
51 SYNC_EXPORT_PRIVATE P2PNotificationTarget P2PNotificationTargetFromString(
52     const std::string& target_str);
53
54 // Helper notification data class that can be serialized to and
55 // deserialized from a string.
56 class SYNC_EXPORT_PRIVATE P2PNotificationData {
57  public:
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);
64
65   ~P2PNotificationData();
66
67   // Returns true if the given ID is targeted by this notification.
68   bool IsTargeted(const std::string& id) const;
69
70   const ObjectIdInvalidationMap& GetIdInvalidationMap() const;
71
72   bool Equals(const P2PNotificationData& other) const;
73
74   std::string ToString() const;
75
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);
79
80  private:
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_;
87 };
88
89 class SYNC_EXPORT_PRIVATE P2PInvalidator
90     : public Invalidator,
91       public NON_EXPORTED_BASE(notifier::PushClientObserver) {
92  public:
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);
101
102   virtual ~P2PInvalidator();
103
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 void Acknowledge(const invalidation::ObjectId& id,
110                            const AckHandle& ack_handle) OVERRIDE;
111   virtual InvalidatorState GetInvalidatorState() const OVERRIDE;
112   virtual void UpdateCredentials(
113       const std::string& email, const std::string& token) OVERRIDE;
114
115   // PushClientObserver implementation.
116   virtual void OnNotificationsEnabled() OVERRIDE;
117   virtual void OnNotificationsDisabled(
118       notifier::NotificationsDisabledReason reason) OVERRIDE;
119   virtual void OnIncomingNotification(
120       const notifier::Notification& notification) OVERRIDE;
121
122   void SendInvalidation(const ObjectIdSet& ids);
123
124   void SendNotificationDataForTest(
125       const P2PNotificationData& notification_data);
126
127  private:
128   void SendNotificationData(const P2PNotificationData& notification_data);
129
130   base::ThreadChecker thread_checker_;
131
132   InvalidatorRegistrar registrar_;
133
134   // The push client.
135   scoped_ptr<notifier::PushClient> push_client_;
136   // Our unique ID.
137   std::string invalidator_client_id_;
138   // Whether we have called UpdateCredentials() yet.
139   bool logged_in_;
140   bool notifications_enabled_;
141   // Which set of clients should be sent notifications.
142   P2PNotificationTarget send_notification_target_;
143
144   DISALLOW_COPY_AND_ASSIGN(P2PInvalidator);
145 };
146
147 }  // namespace syncer
148
149 #endif  // SYNC_NOTIFIER_P2P_INVALIDATOR_H_