Index: remoting/host/host_signaling_manager.cc |
diff --git a/remoting/host/host_signaling_manager.cc b/remoting/host/host_signaling_manager.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..37da304111c645578f479c69e1c9a3cfe42c7e8f |
--- /dev/null |
+++ b/remoting/host/host_signaling_manager.cc |
@@ -0,0 +1,117 @@ |
+// Copyright 2014 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 "remoting/host/host_signaling_manager.h" |
+ |
+#include "base/bind.h" |
+#include "base/time/time.h" |
+#include "net/base/network_change_notifier.h" |
+#include "net/socket/client_socket_factory.h" |
+#include "remoting/base/auto_thread_task_runner.h" |
+#include "remoting/base/logging.h" |
+#include "remoting/base/url_request_context_getter.h" |
+#include "remoting/host/chromoting_host_context.h" |
+#include "remoting/host/dns_blackhole_checker.h" |
+#include "remoting/host/heartbeat_sender.h" |
+#include "remoting/host/signaling_connector.h" |
+#include "remoting/signaling/xmpp_signal_strategy.h" |
+ |
+namespace remoting { |
+ |
+HostSignalingManager::HostSignalingManager( |
+ scoped_ptr<base::WeakPtrFactory<Listener>> weak_factory_for_listener, |
+ const scoped_refptr<AutoThreadTaskRunner>& network_task_runner, |
+ scoped_ptr<net::NetworkChangeNotifier> network_change_notifier, |
+ scoped_ptr<SignalStrategy> signal_strategy, |
+ scoped_ptr<SignalingConnector> signaling_connector, |
+ scoped_ptr<HeartbeatSender> heartbeat_sender) |
+ : weak_factory_for_listener_(weak_factory_for_listener.Pass()), |
+ network_task_runner_(network_task_runner), |
+ network_change_notifier_(network_change_notifier.Pass()), |
+ signal_strategy_(signal_strategy.Pass()), |
+ signaling_connector_(signaling_connector.Pass()), |
+ heartbeat_sender_(heartbeat_sender.Pass()) { |
+} |
+ |
+scoped_ptr<HostSignalingManager> HostSignalingManager::Create( |
+ Listener* listener, |
+ const scoped_refptr<AutoThreadTaskRunner>& network_task_runner, |
+ const scoped_refptr<net::URLRequestContextGetter>& |
+ url_request_context_getter, |
+ const XmppSignalStrategy::XmppServerConfig& xmpp_server_config, |
+ const std::string& talkgadget_prefix_policy, |
+ const std::string& host_id, |
+ const scoped_refptr<const RsaKeyPair>& host_key_pair, |
+ const std::string& directory_bot_jid, |
+ scoped_ptr<OAuthTokenGetter::OAuthCredentials> oauth_credentials) { |
+ DCHECK(network_task_runner->BelongsToCurrentThread()); |
+ |
+ scoped_ptr<base::WeakPtrFactory<Listener>> weak_factory( |
+ new base::WeakPtrFactory<Listener>(listener)); |
+ |
+ scoped_ptr<net::NetworkChangeNotifier> network_change_notifier( |
+ net::NetworkChangeNotifier::Create()); |
+ |
+ scoped_ptr<XmppSignalStrategy> signal_strategy( |
+ new XmppSignalStrategy(net::ClientSocketFactory::GetDefaultFactory(), |
+ url_request_context_getter, xmpp_server_config)); |
+ |
+ scoped_ptr<DnsBlackholeChecker> dns_blackhole_checker(new DnsBlackholeChecker( |
+ url_request_context_getter, talkgadget_prefix_policy)); |
+ |
+ scoped_ptr<SignalingConnector> signaling_connector(new SignalingConnector( |
+ signal_strategy.get(), dns_blackhole_checker.Pass(), |
+ base::Bind(&Listener::OnAuthFailed, weak_factory->GetWeakPtr()))); |
+ |
+ if (!oauth_credentials->refresh_token.empty()) { |
+ scoped_ptr<OAuthTokenGetter> oauth_token_getter(new OAuthTokenGetter( |
+ oauth_credentials.Pass(), url_request_context_getter, false)); |
+ |
+ signaling_connector->EnableOAuth(oauth_token_getter.Pass()); |
+ } |
+ |
+ scoped_ptr<HeartbeatSender> heartbeat_sender(new HeartbeatSender( |
+ base::Bind(&Listener::OnHeartbeatSuccessful, weak_factory->GetWeakPtr()), |
+ base::Bind(&Listener::OnUnknownHostIdError, weak_factory->GetWeakPtr()), |
+ host_id, signal_strategy.get(), host_key_pair, directory_bot_jid)); |
+ |
+ return scoped_ptr<HostSignalingManager>(new HostSignalingManager( |
+ weak_factory.Pass(), network_task_runner, network_change_notifier.Pass(), |
+ signal_strategy.Pass(), signaling_connector.Pass(), |
+ heartbeat_sender.Pass())); |
+} |
+ |
+HostSignalingManager::~HostSignalingManager() { |
+ DCHECK(network_task_runner_->BelongsToCurrentThread()); |
+} |
+ |
+void HostSignalingManager::SendHostOfflineReasonAndDelete( |
+ const std::string& host_offline_reason, |
+ const base::TimeDelta& timeout) { |
+ DCHECK(network_task_runner_->BelongsToCurrentThread()); |
+ |
+ HOST_LOG << "SendHostOfflineReason: sending " << host_offline_reason; |
+ |
+ // Ensure that any subsequent callbacks from the HeartbeatSender or |
+ // SignalingConnector don't touch the Listener. |
+ weak_factory_for_listener_->InvalidateWeakPtrs(); |
+ |
+ heartbeat_sender_->SetHostOfflineReason( |
+ host_offline_reason, timeout, |
+ base::Bind(&HostSignalingManager::OnHostOfflineReasonAck, |
+ base::Unretained(this))); |
+} |
+ |
+void HostSignalingManager::OnHostOfflineReasonAck(bool success) { |
+ DCHECK(network_task_runner_->BelongsToCurrentThread()); |
+ if (success) { |
+ HOST_LOG << "SendHostOfflineReason: succeeded"; |
+ } else { |
+ HOST_LOG << "SendHostOfflineReason: timed out"; |
+ } |
+ |
+ delete this; |
+} |
+ |
+} // namespace remoting |