summaryrefslogtreecommitdiffstats
path: root/remoting/host/chromoting_host.cc
diff options
context:
space:
mode:
Diffstat (limited to 'remoting/host/chromoting_host.cc')
-rw-r--r--remoting/host/chromoting_host.cc46
1 files changed, 28 insertions, 18 deletions
diff --git a/remoting/host/chromoting_host.cc b/remoting/host/chromoting_host.cc
index f5f0fa9..3923484 100644
--- a/remoting/host/chromoting_host.cc
+++ b/remoting/host/chromoting_host.cc
@@ -159,24 +159,7 @@ void ChromotingHost::Shutdown(Task* shutdown_task) {
}
clients_.clear();
- // Stop chromotocol session manager.
- if (session_manager_.get()) {
- session_manager_->Close();
- session_manager_.reset();
- }
-
- // Stop XMPP connection.
- if (signal_strategy_.get()) {
- signal_strategy_->Close();
- signal_strategy_.reset();
-
- for (StatusObserverList::iterator it = status_observers_.begin();
- it != status_observers_.end(); ++it) {
- (*it)->OnSignallingDisconnected();
- }
- }
-
- ShutdownRecorder();
+ ShutdownNetwork();
}
void ChromotingHost::AddStatusObserver(HostStatusObserver* observer) {
@@ -639,6 +622,33 @@ void ChromotingHost::ContinueWindowTimerFunc() {
ShowContinueWindow(true);
}
+void ChromotingHost::ShutdownNetwork() {
+ if (MessageLoop::current() != context_->network_message_loop()) {
+ context_->network_message_loop()->PostTask(
+ FROM_HERE, base::Bind(&ChromotingHost::ShutdownNetwork, this));
+ return;
+ }
+
+ // Stop chromotocol session manager.
+ if (session_manager_.get()) {
+ session_manager_->Close();
+ session_manager_.reset();
+ }
+
+ // Stop XMPP connection.
+ if (signal_strategy_.get()) {
+ signal_strategy_->Close();
+ signal_strategy_.reset();
+
+ for (StatusObserverList::iterator it = status_observers_.begin();
+ it != status_observers_.end(); ++it) {
+ (*it)->OnSignallingDisconnected();
+ }
+ }
+
+ ShutdownRecorder();
+}
+
void ChromotingHost::ShutdownRecorder() {
if (MessageLoop::current() != context_->main_message_loop()) {
context_->main_message_loop()->PostTask(