Index: chrome/browser/p2p_invalidation_service.cc |
diff --git a/chrome/browser/p2p_invalidation_service.cc b/chrome/browser/p2p_invalidation_service.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..deff822bb661c182eaeb179d89294499c5a3416b |
--- /dev/null |
+++ b/chrome/browser/p2p_invalidation_service.cc |
@@ -0,0 +1,132 @@ |
+// Copyright (c) 2013 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "chrome/browser/p2p_invalidation_service.h" |
+ |
+#include "base/base64.h" |
+#include "base/command_line.h" |
+#include "base/rand_util.h" |
+#include "chrome/browser/profiles/profile.h" |
+#include "chrome/common/chrome_switches.h" |
+#include "sync/notifier/p2p_invalidator.h" |
+ |
+namespace net { |
+class URLRequestContextGetter; |
+} |
+ |
+// FIXME: duplicated code. |
+namespace { |
+// Parses the given command line for notifier options. |
+notifier::NotifierOptions ParseNotifierOptions( |
+ const CommandLine& command_line, |
+ const scoped_refptr<net::URLRequestContextGetter>& |
+ request_context_getter) { |
+ notifier::NotifierOptions notifier_options; |
+ notifier_options.request_context_getter = request_context_getter; |
+ |
+ if (command_line.HasSwitch(switches::kSyncNotificationHostPort)) { |
+ notifier_options.xmpp_host_port = |
+ net::HostPortPair::FromString( |
+ command_line.GetSwitchValueASCII( |
+ switches::kSyncNotificationHostPort)); |
+ DVLOG(1) << "Using " << notifier_options.xmpp_host_port.ToString() |
+ << " for test sync notification server."; |
+ } |
+ |
+ notifier_options.try_ssltcp_first = |
+ command_line.HasSwitch(switches::kSyncTrySsltcpFirstForXmpp); |
+ DVLOG_IF(1, notifier_options.try_ssltcp_first) |
+ << "Trying SSL/TCP port before XMPP port for notifications."; |
+ |
+ notifier_options.invalidate_xmpp_login = |
+ command_line.HasSwitch(switches::kSyncInvalidateXmppLogin); |
+ DVLOG_IF(1, notifier_options.invalidate_xmpp_login) |
+ << "Invalidating sync XMPP login."; |
+ |
+ notifier_options.allow_insecure_connection = |
+ command_line.HasSwitch(switches::kSyncAllowInsecureXmppConnection); |
+ DVLOG_IF(1, notifier_options.allow_insecure_connection) |
+ << "Allowing insecure XMPP connections."; |
+ |
+ if (command_line.HasSwitch(switches::kSyncNotificationMethod)) { |
+ const std::string notification_method_str( |
+ command_line.GetSwitchValueASCII(switches::kSyncNotificationMethod)); |
+ notifier_options.notification_method = |
+ notifier::StringToNotificationMethod(notification_method_str); |
+ } |
+ |
+ return notifier_options; |
+} |
+ |
+std::string GenerateInvalidatorClientId() { |
+ // Generate a GUID with 128 bits worth of base64-encoded randomness. |
+ // This format is similar to that of sync's cache_guid. |
+ const int kGuidBytes = 128 / 8; |
+ std::string guid; |
+ base::Base64Encode(base::RandBytesAsString(kGuidBytes), &guid); |
+ return guid; |
+} |
+ |
+} // namespace |
+ |
+P2PInvalidationService::P2PInvalidationService() { |
+} |
+ |
+P2PInvalidationService::~P2PInvalidationService() { |
+} |
+ |
+void P2PInvalidationService::Init(Profile* profile) { |
+ notifier::NotifierOptions notifier_options = |
+ ParseNotifierOptions(*CommandLine::ForCurrentProcess(), |
+ profile->GetRequestContext()); |
+ invalidator_id_ = GenerateInvalidatorClientId(); |
+ invalidator_.reset(new syncer::P2PInvalidator( |
+ notifier::PushClient::CreateDefault(notifier_options), |
+ invalidator_id_, |
+ syncer::NOTIFY_ALL)); |
+} |
+ |
+void P2PInvalidationService::UpdateCredentials(const std::string& username, |
+ const std::string& password) { |
+ invalidator_->UpdateCredentials(username, password); |
+} |
+ |
+void P2PInvalidationService::Shutdown() { |
+ invalidator_.reset(); |
+} |
+ |
+void P2PInvalidationService::RegisterInvalidationHandler( |
+ syncer::InvalidationHandler* handler) { |
+ invalidator_->RegisterHandler(handler); |
+} |
+ |
+void P2PInvalidationService::UpdateRegisteredInvalidationIds( |
+ syncer::InvalidationHandler* handler, |
+ const syncer::ObjectIdSet& ids) { |
+ invalidator_->UpdateRegisteredIds(handler, ids); |
+} |
+ |
+void P2PInvalidationService::UnregisterInvalidationHandler( |
+ syncer::InvalidationHandler* handler) { |
+ invalidator_->UnregisterHandler(handler); |
+} |
+ |
+void P2PInvalidationService::AcknowledgeInvalidation( |
+ const invalidation::ObjectId& id, |
+ const syncer::AckHandle& ack_handle) { |
+ invalidator_->Acknowledge(id, ack_handle); |
+} |
+ |
+void P2PInvalidationService::SendInvalidation( |
+ const syncer::ObjectIdInvalidationMap& invalidation_map) { |
+ invalidator_->SendInvalidation(invalidation_map); |
+} |
+ |
+syncer::InvalidatorState P2PInvalidationService::GetInvalidatorState() const { |
+ return invalidator_->GetInvalidatorState(); |
+} |
+ |
+std::string P2PInvalidationService::GetInvalidatorClientId() const { |
+ return invalidator_id_; |
+} |