Chromium Code Reviews| OLD | NEW | 
|---|---|
| 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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 "remoting/host/chromoting_host.h" | 5 #include "remoting/host/chromoting_host.h" | 
| 6 | 6 | 
| 7 #include "base/stl_util-inl.h" | 7 #include "base/stl_util-inl.h" | 
| 8 #include "base/task.h" | 8 #include "base/task.h" | 
| 9 #include "build/build_config.h" | 9 #include "build/build_config.h" | 
| 10 #include "remoting/base/constants.h" | 10 #include "remoting/base/constants.h" | 
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 63 // it should run on. | 63 // it should run on. | 
| 64 DCHECK(capturer_.get()); | 64 DCHECK(capturer_.get()); | 
| 65 DCHECK(encoder_.get()); | 65 DCHECK(encoder_.get()); | 
| 66 session_ = new SessionManager(context_->capture_message_loop(), | 66 session_ = new SessionManager(context_->capture_message_loop(), | 
| 67 context_->encode_message_loop(), | 67 context_->encode_message_loop(), | 
| 68 context_->main_message_loop(), | 68 context_->main_message_loop(), | 
| 69 capturer_.get(), | 69 capturer_.get(), | 
| 70 encoder_.get()); | 70 encoder_.get()); | 
| 71 | 71 | 
| 72 // Immediately add the client and start the session. | 72 // Immediately add the client and start the session. | 
| 73 session_->AddClient(client); | 73 session_->AddClient(client); | 
| 
 
Sergey Ulanov
2010/09/02 01:20:24
This code is duplicated below. Move this out of th
 
 | |
| 74 session_->Start(); | 74 session_->Start(); | 
| 75 LOG(INFO) << "Session manager started"; | 75 LOG(INFO) << "Session manager started"; | 
| 76 } else { | 76 } else { | 
| 77 // If a session manager already exists we simply add the new client. | 77 // If a session manager already exists we simply add the new client. | 
| 78 session_->AddClient(client); | 78 session_->AddClient(client); | 
| 79 session_->Start(); | |
| 79 } | 80 } | 
| 80 } | 81 } | 
| 81 | 82 | 
| 82 void ChromotingHost::OnClientDisconnected(ClientConnection* client) { | 83 void ChromotingHost::OnClientDisconnected(ClientConnection* client) { | 
| 83 DCHECK_EQ(context_->main_message_loop(), MessageLoop::current()); | 84 DCHECK_EQ(context_->main_message_loop(), MessageLoop::current()); | 
| 84 | 85 | 
| 85 // Remove the client from the session manager and pause the session. | 86 // Remove the client from the session manager and pause the session. | 
| 86 // TODO(hclam): Pause only if the last client disconnected. | 87 // TODO(hclam): Pause only if the last client disconnected. | 
| 87 if (session_.get()) { | 88 if (session_.get()) { | 
| 88 session_->RemoveClient(client); | 89 session_->RemoveClient(client); | 
| 89 session_->Pause(); | 90 session_->Pause(); | 
| 90 } | 91 } | 
| 91 | 92 | 
| 93 // Close the connection to client just to be safe. | |
| 94 client->Disconnect(); | |
| 95 | |
| 92 // Also remove reference to ClientConnection from this object. | 96 // Also remove reference to ClientConnection from this object. | 
| 93 client_ = NULL; | 97 client_ = NULL; | 
| 94 } | 98 } | 
| 95 | 99 | 
| 96 //////////////////////////////////////////////////////////////////////////// | 100 //////////////////////////////////////////////////////////////////////////// | 
| 97 // ClientConnection::EventHandler implementations | 101 // ClientConnection::EventHandler implementations | 
| 98 void ChromotingHost::HandleMessages(ClientConnection* client, | 102 void ChromotingHost::HandleMessages(ClientConnection* client, | 
| 99 ClientMessageList* messages) { | 103 ClientMessageList* messages) { | 
| 100 DCHECK_EQ(context_->main_message_loop(), MessageLoop::current()); | 104 DCHECK_EQ(context_->main_message_loop(), MessageLoop::current()); | 
| 101 | 105 | 
| 102 // Delegate the messages to EventExecutor and delete the unhandled | 106 // Delegate the messages to EventExecutor and delete the unhandled | 
| 103 // messages. | 107 // messages. | 
| 104 DCHECK(executor_.get()); | 108 DCHECK(executor_.get()); | 
| 105 executor_->HandleInputEvents(messages); | 109 executor_->HandleInputEvents(messages); | 
| 106 STLDeleteElements<ClientMessageList>(messages); | 110 STLDeleteElements<ClientMessageList>(messages); | 
| 107 } | 111 } | 
| 108 | 112 | 
| 109 void ChromotingHost::OnConnectionOpened(ClientConnection* client) { | 113 void ChromotingHost::OnConnectionOpened(ClientConnection* client) { | 
| 110 DCHECK_EQ(context_->main_message_loop(), MessageLoop::current()); | 114 DCHECK_EQ(context_->main_message_loop(), MessageLoop::current()); | 
| 111 | 115 | 
| 112 // Completes the client connection. | 116 // Completes the client connection. | 
| 113 LOG(INFO) << "Connection to client established."; | 117 LOG(INFO) << "Connection to client established."; | 
| 114 OnClientConnected(client_.get()); | 118 OnClientConnected(client_.get()); | 
| 115 } | 119 } | 
| 116 | 120 | 
| 117 void ChromotingHost::OnConnectionClosed(ClientConnection* client) { | 121 void ChromotingHost::OnConnectionClosed(ClientConnection* client) { | 
| 118 DCHECK_EQ(context_->main_message_loop(), MessageLoop::current()); | 122 DCHECK_EQ(context_->main_message_loop(), MessageLoop::current()); | 
| 119 | 123 | 
| 120 // Completes the client connection. | |
| 121 LOG(INFO) << "Connection to client closed."; | 124 LOG(INFO) << "Connection to client closed."; | 
| 122 OnClientDisconnected(client_.get()); | 125 OnClientDisconnected(client_.get()); | 
| 123 } | 126 } | 
| 124 | 127 | 
| 125 void ChromotingHost::OnConnectionFailed(ClientConnection* client) { | 128 void ChromotingHost::OnConnectionFailed(ClientConnection* client) { | 
| 126 DCHECK_EQ(context_->main_message_loop(), MessageLoop::current()); | 129 DCHECK_EQ(context_->main_message_loop(), MessageLoop::current()); | 
| 127 | 130 | 
| 128 // The client has disconnected. | |
| 129 LOG(ERROR) << "Connection failed unexpectedly."; | 131 LOG(ERROR) << "Connection failed unexpectedly."; | 
| 130 OnClientDisconnected(client_.get()); | 132 OnClientDisconnected(client_.get()); | 
| 131 } | 133 } | 
| 132 | 134 | 
| 133 //////////////////////////////////////////////////////////////////////////// | 135 //////////////////////////////////////////////////////////////////////////// | 
| 134 // JingleClient::Callback implementations | 136 // JingleClient::Callback implementations | 
| 135 void ChromotingHost::OnStateChange(JingleClient* jingle_client, | 137 void ChromotingHost::OnStateChange(JingleClient* jingle_client, | 
| 136 JingleClient::State state) { | 138 JingleClient::State state) { | 
| 137 if (state == JingleClient::CONNECTED) { | 139 if (state == JingleClient::CONNECTED) { | 
| 138 DCHECK_EQ(jingle_client_.get(), jingle_client); | 140 DCHECK_EQ(jingle_client_.get(), jingle_client); | 
| (...skipping 121 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 260 heartbeat_sender_->Stop(); | 262 heartbeat_sender_->Stop(); | 
| 261 } | 263 } | 
| 262 | 264 | 
| 263 // Lastly call the shutdown task. | 265 // Lastly call the shutdown task. | 
| 264 if (shutdown_task_.get()) { | 266 if (shutdown_task_.get()) { | 
| 265 shutdown_task_->Run(); | 267 shutdown_task_->Run(); | 
| 266 } | 268 } | 
| 267 } | 269 } | 
| 268 | 270 | 
| 269 } // namespace remoting | 271 } // namespace remoting | 
| OLD | NEW |