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

Side by Side Diff: sync/notifier/invalidator_factory.cc

Issue 12092091: Separate sync and invalidation client IDs (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 10 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
« no previous file with comments | « sync/notifier/invalidator_factory.h ('k') | sync/notifier/invalidator_registrar_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 #include "sync/notifier/invalidator_factory.h" 5 #include "sync/notifier/invalidator_factory.h"
6 6
7 #include <string> 7 #include <string>
8 8
9 #include "base/base64.h"
9 #include "base/logging.h" 10 #include "base/logging.h"
11 #include "base/rand_util.h"
10 #include "jingle/notifier/listener/push_client.h" 12 #include "jingle/notifier/listener/push_client.h"
11 #include "sync/notifier/invalidator.h" 13 #include "sync/notifier/invalidator.h"
12 #include "sync/notifier/non_blocking_invalidator.h" 14 #include "sync/notifier/non_blocking_invalidator.h"
13 #include "sync/notifier/p2p_invalidator.h" 15 #include "sync/notifier/p2p_invalidator.h"
14 16
15 namespace syncer { 17 namespace syncer {
16 namespace { 18 namespace {
17 19
18 Invalidator* CreateDefaultInvalidator( 20 Invalidator* CreateDefaultInvalidator(
19 const notifier::NotifierOptions& notifier_options, 21 const notifier::NotifierOptions& notifier_options,
22 const std::string& invalidator_client_id,
20 const InvalidationStateMap& initial_invalidation_state_map, 23 const InvalidationStateMap& initial_invalidation_state_map,
21 const std::string& invalidation_bootstrap_data, 24 const std::string& invalidation_bootstrap_data,
22 const WeakHandle<InvalidationStateTracker>& invalidation_state_tracker, 25 const WeakHandle<InvalidationStateTracker>& invalidation_state_tracker,
23 const std::string& client_info) { 26 const std::string& client_info) {
24 if (notifier_options.notification_method == notifier::NOTIFICATION_P2P) { 27 if (notifier_options.notification_method == notifier::NOTIFICATION_P2P) {
25 // TODO(rlarocque): Ideally, the notification target would be 28 // TODO(rlarocque): Ideally, the notification target would be
26 // NOTIFY_OTHERS. There's no good reason to notify ourselves of our own 29 // NOTIFY_OTHERS. There's no good reason to notify ourselves of our own
27 // commits. We self-notify for now only because the integration tests rely 30 // commits. We self-notify for now only because the integration tests rely
28 // on this behaviour. See crbug.com/97780. 31 // on this behaviour. See crbug.com/97780.
29 return new P2PInvalidator( 32 return new P2PInvalidator(
30 notifier::PushClient::CreateDefault(notifier_options), 33 notifier::PushClient::CreateDefault(notifier_options),
34 invalidator_client_id,
31 NOTIFY_ALL); 35 NOTIFY_ALL);
32 } 36 }
33 37
34 return new NonBlockingInvalidator( 38 return new NonBlockingInvalidator(
35 notifier_options, initial_invalidation_state_map, 39 notifier_options, invalidator_client_id, initial_invalidation_state_map,
36 invalidation_bootstrap_data, invalidation_state_tracker, client_info); 40 invalidation_bootstrap_data, invalidation_state_tracker, client_info);
37 } 41 }
38 42
43 std::string GenerateInvalidatorClientId() {
44 // Generate a GUID with 128 bits worth of base64-encoded randomness.
45 // This format is similar to that of sync's cache_guid.
46 const int kGuidBytes = 128 / 8;
47 std::string guid;
48 base::Base64Encode(base::RandBytesAsString(kGuidBytes), &guid);
49 return guid;
50 }
51
39 } // namespace 52 } // namespace
40 53
41 // TODO(akalin): Remove the dependency on jingle if OS_ANDROID is defined. 54 // TODO(akalin): Remove the dependency on jingle if OS_ANDROID is defined.
42 InvalidatorFactory::InvalidatorFactory( 55 InvalidatorFactory::InvalidatorFactory(
43 const notifier::NotifierOptions& notifier_options, 56 const notifier::NotifierOptions& notifier_options,
44 const std::string& client_info, 57 const std::string& client_info,
45 const base::WeakPtr<InvalidationStateTracker>& 58 const base::WeakPtr<InvalidationStateTracker>&
46 invalidation_state_tracker) 59 invalidation_state_tracker)
47 : notifier_options_(notifier_options), 60 : notifier_options_(notifier_options),
48 client_info_(client_info), 61 client_info_(client_info) {
49 initial_invalidation_state_map_( 62 if (!invalidation_state_tracker.get()) {
50 invalidation_state_tracker.get() ? 63 return;
51 invalidation_state_tracker->GetAllInvalidationStates() : 64 }
52 InvalidationStateMap()), 65
53 invalidation_bootstrap_data_( 66 // TODO(rlarocque, 124137): This is not the most obvious place for client ID
54 invalidation_state_tracker.get() ? 67 // generation code. We should try to find a better place for it when we
55 invalidation_state_tracker->GetBootstrapData() : 68 // refactor the invalidator into its own service.
56 std::string()), 69 if (invalidation_state_tracker->GetInvalidatorClientId().empty()) {
57 invalidation_state_tracker_(invalidation_state_tracker) { 70 // If the client ID changes, the stored client state must be cleared.
71 invalidation_state_tracker->Clear();
72 invalidation_state_tracker->SetInvalidatorClientId(
73 GenerateInvalidatorClientId());
74 }
75
76 initial_invalidation_state_map_ =
77 invalidation_state_tracker->GetAllInvalidationStates();
78 invalidator_client_id_ =
79 invalidation_state_tracker->GetInvalidatorClientId();
80 invalidation_bootstrap_data_ = invalidation_state_tracker->GetBootstrapData();
81 invalidation_state_tracker_ = WeakHandle<InvalidationStateTracker>(
82 invalidation_state_tracker);
58 } 83 }
59 84
60 InvalidatorFactory::~InvalidatorFactory() { 85 InvalidatorFactory::~InvalidatorFactory() {
61 } 86 }
62 87
63 Invalidator* InvalidatorFactory::CreateInvalidator() { 88 Invalidator* InvalidatorFactory::CreateInvalidator() {
64 #if defined(OS_ANDROID) 89 #if defined(OS_ANDROID)
65 // Android uses AndroidInvalidatorBridge instead. See SyncManager 90 // Android uses AndroidInvalidatorBridge instead. See SyncManager
66 // initialization code in SyncBackendHost for more information. 91 // initialization code in SyncBackendHost for more information.
67 return NULL; 92 return NULL;
68 #else 93 #else
69 return CreateDefaultInvalidator(notifier_options_, 94 return CreateDefaultInvalidator(notifier_options_,
95 invalidator_client_id_,
70 initial_invalidation_state_map_, 96 initial_invalidation_state_map_,
71 invalidation_bootstrap_data_, 97 invalidation_bootstrap_data_,
72 invalidation_state_tracker_, 98 invalidation_state_tracker_,
73 client_info_); 99 client_info_);
74 #endif 100 #endif
75 } 101 }
102
103 std::string InvalidatorFactory::GetInvalidatorClientId() const {
104 return invalidator_client_id_;
105 }
106
76 } // namespace syncer 107 } // namespace syncer
OLDNEW
« no previous file with comments | « sync/notifier/invalidator_factory.h ('k') | sync/notifier/invalidator_registrar_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698