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

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

Issue 10824161: [Sync] Avoid unregistering object IDs on shutdown (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Work around brittle unit test Created 8 years, 4 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
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 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 // A notifier that uses p2p notifications based on XMPP push 5 // A notifier that uses p2p notifications based on XMPP push
6 // notifications. Used only for sync integration tests. 6 // notifications. Used only for sync integration tests.
7 7
8 #ifndef SYNC_NOTIFIER_P2P_NOTIFIER_H_ 8 #ifndef SYNC_NOTIFIER_P2P_NOTIFIER_H_
9 #define SYNC_NOTIFIER_P2P_NOTIFIER_H_ 9 #define SYNC_NOTIFIER_P2P_NOTIFIER_H_
10 10
11 #include <string> 11 #include <string>
12 12
13 #include "base/compiler_specific.h" 13 #include "base/compiler_specific.h"
14 #include "base/memory/ref_counted.h" 14 #include "base/memory/ref_counted.h"
15 #include "base/memory/scoped_ptr.h" 15 #include "base/memory/scoped_ptr.h"
16 #include "base/memory/weak_ptr.h" 16 #include "base/memory/weak_ptr.h"
17 #include "base/observer_list.h" 17 #include "base/observer_list.h"
18 #include "base/threading/thread_checker.h" 18 #include "base/threading/thread_checker.h"
19 #include "jingle/notifier/listener/push_client_observer.h" 19 #include "jingle/notifier/listener/push_client_observer.h"
20 #include "sync/internal_api/public/base/model_type.h" 20 #include "sync/internal_api/public/base/model_type.h"
21 #include "sync/notifier/notifications_disabled_reason.h" 21 #include "sync/notifier/notifications_disabled_reason.h"
22 #include "sync/notifier/sync_notifier.h" 22 #include "sync/notifier/sync_notifier.h"
23 #include "sync/notifier/sync_notifier_helper.h" 23 #include "sync/notifier/sync_notifier_registrar.h"
24 24
25 namespace notifier { 25 namespace notifier {
26 class PushClient; 26 class PushClient;
27 } // namespace notifier 27 } // namespace notifier
28 28
29 namespace syncer { 29 namespace syncer {
30 30
31 // The channel to use for sync notifications. 31 // The channel to use for sync notifications.
32 extern const char* kSyncP2PNotificationChannel; 32 extern const char* kSyncP2PNotificationChannel;
33 33
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after
89 // self-notifications in some cases, but not others. The value should be 89 // self-notifications in some cases, but not others. The value should be
90 // either NOTIFY_ALL to send notifications to all clients, or NOTIFY_OTHERS 90 // either NOTIFY_ALL to send notifications to all clients, or NOTIFY_OTHERS
91 // to send notifications to all clients except for the one that triggered the 91 // to send notifications to all clients except for the one that triggered the
92 // notification. See crbug.com/97780. 92 // notification. See crbug.com/97780.
93 P2PNotifier(scoped_ptr<notifier::PushClient> push_client, 93 P2PNotifier(scoped_ptr<notifier::PushClient> push_client,
94 P2PNotificationTarget send_notification_target); 94 P2PNotificationTarget send_notification_target);
95 95
96 virtual ~P2PNotifier(); 96 virtual ~P2PNotifier();
97 97
98 // SyncNotifier implementation 98 // SyncNotifier implementation
99 virtual void RegisterHandler(SyncNotifierObserver* handler) OVERRIDE;
99 virtual void UpdateRegisteredIds(SyncNotifierObserver* handler, 100 virtual void UpdateRegisteredIds(SyncNotifierObserver* handler,
100 const ObjectIdSet& ids) OVERRIDE; 101 const ObjectIdSet& ids) OVERRIDE;
102 virtual void UnregisterHandler(SyncNotifierObserver* handler) OVERRIDE;
101 virtual void SetUniqueId(const std::string& unique_id) OVERRIDE; 103 virtual void SetUniqueId(const std::string& unique_id) OVERRIDE;
102 virtual void SetStateDeprecated(const std::string& state) OVERRIDE; 104 virtual void SetStateDeprecated(const std::string& state) OVERRIDE;
103 virtual void UpdateCredentials( 105 virtual void UpdateCredentials(
104 const std::string& email, const std::string& token) OVERRIDE; 106 const std::string& email, const std::string& token) OVERRIDE;
105 virtual void SendNotification(ModelTypeSet changed_types) OVERRIDE; 107 virtual void SendNotification(ModelTypeSet changed_types) OVERRIDE;
106 108
107 // PushClientObserver implementation. 109 // PushClientObserver implementation.
108 virtual void OnNotificationsEnabled() OVERRIDE; 110 virtual void OnNotificationsEnabled() OVERRIDE;
109 virtual void OnNotificationsDisabled( 111 virtual void OnNotificationsDisabled(
110 notifier::NotificationsDisabledReason reason) OVERRIDE; 112 notifier::NotificationsDisabledReason reason) OVERRIDE;
111 virtual void OnIncomingNotification( 113 virtual void OnIncomingNotification(
112 const notifier::Notification& notification) OVERRIDE; 114 const notifier::Notification& notification) OVERRIDE;
113 115
114 void SendNotificationDataForTest( 116 void SendNotificationDataForTest(
115 const P2PNotificationData& notification_data); 117 const P2PNotificationData& notification_data);
116 118
117 private: 119 private:
118 void SendNotificationData(const P2PNotificationData& notification_data); 120 void SendNotificationData(const P2PNotificationData& notification_data);
119 121
120 base::ThreadChecker thread_checker_; 122 base::ThreadChecker thread_checker_;
121 123
122 SyncNotifierHelper helper_; 124 SyncNotifierRegistrar registrar_;
123 125
124 // The push client. 126 // The push client.
125 scoped_ptr<notifier::PushClient> push_client_; 127 scoped_ptr<notifier::PushClient> push_client_;
126 // Our unique ID. 128 // Our unique ID.
127 std::string unique_id_; 129 std::string unique_id_;
128 // Whether we have called UpdateCredentials() yet. 130 // Whether we have called UpdateCredentials() yet.
129 bool logged_in_; 131 bool logged_in_;
130 bool notifications_enabled_; 132 bool notifications_enabled_;
131 // Which set of clients should be sent notifications. 133 // Which set of clients should be sent notifications.
132 P2PNotificationTarget send_notification_target_; 134 P2PNotificationTarget send_notification_target_;
133 135
134 ModelTypeSet enabled_types_; 136 ModelTypeSet enabled_types_;
135 }; 137 };
136 138
137 } // namespace syncer 139 } // namespace syncer
138 140
139 #endif // SYNC_NOTIFIER_P2P_NOTIFIER_H_ 141 #endif // SYNC_NOTIFIER_P2P_NOTIFIER_H_
OLDNEW
« no previous file with comments | « sync/notifier/non_blocking_invalidation_notifier_unittest.cc ('k') | sync/notifier/p2p_notifier.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698