// Copyright (c) 2011 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/sync/notifier/sync_notifier_factory.h" #include #include "base/command_line.h" #include "base/string_number_conversions.h" #include "base/string_util.h" #include "chrome/browser/sync/notifier/non_blocking_invalidation_notifier.h" #include "chrome/browser/sync/notifier/p2p_notifier.h" #include "chrome/browser/sync/notifier/sync_notifier.h" #include "chrome/common/chrome_switches.h" #include "jingle/notifier/base/const_communicator.h" #include "jingle/notifier/base/notifier_options.h" #include "net/base/host_port_pair.h" namespace sync_notifier { namespace { // TODO(akalin): Figure out whether this should be a method of // HostPortPair. net::HostPortPair StringToHostPortPair(const std::string& host_port_str, uint16 default_port) { std::string::size_type colon_index = host_port_str.find(':'); if (colon_index == std::string::npos) { return net::HostPortPair(host_port_str, default_port); } std::string host = host_port_str.substr(0, colon_index); std::string port_str = host_port_str.substr(colon_index + 1); int port = default_port; if (!base::StringToInt(port_str, &port) || (port <= 0) || (port > kuint16max)) { LOG(WARNING) << "Could not parse valid port from " << port_str << "; using port " << default_port; return net::HostPortPair(host, default_port); } return net::HostPortPair(host, port); } SyncNotifier* CreateDefaultSyncNotifier( const CommandLine& command_line, const scoped_refptr& request_context_getter, const std::string& client_info) { // Contains options specific to how sync clients send and listen to // jingle notifications. notifier::NotifierOptions notifier_options; notifier_options.request_context_getter = request_context_getter; // Override the notification server host from the command-line, if provided. if (command_line.HasSwitch(switches::kSyncNotificationHost)) { std::string value(command_line.GetSwitchValueASCII( switches::kSyncNotificationHost)); if (!value.empty()) { notifier_options.xmpp_host_port = StringToHostPortPair(value, notifier::kDefaultXmppPort); } VLOG(1) << "Using " << notifier_options.xmpp_host_port.ToString() << " for test sync notification server."; } notifier_options.try_ssltcp_first = command_line.HasSwitch(switches::kSyncTrySsltcpFirstForXmpp); if (notifier_options.try_ssltcp_first) VLOG(1) << "Trying SSL/TCP port before XMPP port for notifications."; notifier_options.invalidate_xmpp_login = command_line.HasSwitch(switches::kSyncInvalidateXmppLogin); if (notifier_options.invalidate_xmpp_login) { VLOG(1) << "Invalidating sync XMPP login."; } notifier_options.allow_insecure_connection = command_line.HasSwitch(switches::kSyncAllowInsecureXmppConnection); if (notifier_options.allow_insecure_connection) { VLOG(1) << "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); } if (notifier_options.notification_method == notifier::NOTIFICATION_P2P) { return new P2PNotifier(notifier_options); } return new NonBlockingInvalidationNotifier(notifier_options, client_info); } } // namespace SyncNotifierFactory::SyncNotifierFactory(const std::string& client_info) : client_info_(client_info) {} SyncNotifierFactory::~SyncNotifierFactory() { } SyncNotifier* SyncNotifierFactory::CreateSyncNotifier( const CommandLine& command_line, const scoped_refptr& request_context_getter) { return CreateDefaultSyncNotifier(command_line, request_context_getter, client_info_); } } // namespace sync_notifier