| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/callback.h" | 8 #include "base/callback.h" |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "base/message_loop_proxy.h" | 10 #include "base/message_loop_proxy.h" |
| 11 #include "build/build_config.h" | 11 #include "build/build_config.h" |
| 12 #include "remoting/base/constants.h" | 12 #include "remoting/base/constants.h" |
| 13 #include "remoting/host/chromoting_host_context.h" | 13 #include "remoting/host/chromoting_host_context.h" |
| 14 #include "remoting/host/desktop_environment.h" | |
| 15 #include "remoting/host/desktop_environment_factory.h" | 14 #include "remoting/host/desktop_environment_factory.h" |
| 16 #include "remoting/host/event_executor.h" | 15 #include "remoting/host/event_executor.h" |
| 17 #include "remoting/host/host_config.h" | 16 #include "remoting/host/host_config.h" |
| 18 #include "remoting/protocol/connection_to_client.h" | 17 #include "remoting/protocol/connection_to_client.h" |
| 19 #include "remoting/protocol/client_stub.h" | 18 #include "remoting/protocol/client_stub.h" |
| 20 #include "remoting/protocol/host_stub.h" | 19 #include "remoting/protocol/host_stub.h" |
| 21 #include "remoting/protocol/input_stub.h" | 20 #include "remoting/protocol/input_stub.h" |
| 22 #include "remoting/protocol/session_config.h" | 21 #include "remoting/protocol/session_config.h" |
| 23 | 22 |
| 24 using remoting::protocol::ConnectionToClient; | 23 using remoting::protocol::ConnectionToClient; |
| (...skipping 275 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 300 *response = protocol::SessionManager::INCOMPATIBLE; | 299 *response = protocol::SessionManager::INCOMPATIBLE; |
| 301 return; | 300 return; |
| 302 } | 301 } |
| 303 | 302 |
| 304 session->set_config(config); | 303 session->set_config(config); |
| 305 | 304 |
| 306 *response = protocol::SessionManager::ACCEPT; | 305 *response = protocol::SessionManager::ACCEPT; |
| 307 | 306 |
| 308 LOG(INFO) << "Client connected: " << session->jid(); | 307 LOG(INFO) << "Client connected: " << session->jid(); |
| 309 | 308 |
| 310 // Create the desktop integration implementation for the client to use. | |
| 311 scoped_ptr<DesktopEnvironment> desktop_environment = | |
| 312 desktop_environment_factory_->Create(); | |
| 313 | |
| 314 // Create a client object. | 309 // Create a client object. |
| 315 scoped_ptr<protocol::ConnectionToClient> connection( | 310 scoped_ptr<protocol::ConnectionToClient> connection( |
| 316 new protocol::ConnectionToClient(session)); | 311 new protocol::ConnectionToClient(session)); |
| 317 scoped_refptr<ClientSession> client = new ClientSession( | 312 scoped_refptr<ClientSession> client = new ClientSession( |
| 318 this, | 313 this, |
| 319 capture_task_runner_, | 314 capture_task_runner_, |
| 320 encode_task_runner_, | 315 encode_task_runner_, |
| 321 network_task_runner_, | 316 network_task_runner_, |
| 322 connection.Pass(), | 317 connection.Pass(), |
| 323 desktop_environment.Pass(), | 318 desktop_environment_factory_, |
| 324 max_session_duration_); | 319 max_session_duration_); |
| 325 clients_.push_back(client); | 320 clients_.push_back(client); |
| 326 clients_count_++; | 321 clients_count_++; |
| 327 } | 322 } |
| 328 | 323 |
| 329 void ChromotingHost::set_protocol_config( | 324 void ChromotingHost::set_protocol_config( |
| 330 scoped_ptr<protocol::CandidateSessionConfig> config) { | 325 scoped_ptr<protocol::CandidateSessionConfig> config) { |
| 331 DCHECK(network_task_runner_->BelongsToCurrentThread()); | 326 DCHECK(network_task_runner_->BelongsToCurrentThread()); |
| 332 DCHECK(config.get()); | 327 DCHECK(config.get()); |
| 333 DCHECK_EQ(state_, kInitial); | 328 DCHECK_EQ(state_, kInitial); |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 368 return; | 363 return; |
| 369 } | 364 } |
| 370 | 365 |
| 371 while (!clients_.empty()) { | 366 while (!clients_.empty()) { |
| 372 size_t size = clients_.size(); | 367 size_t size = clients_.size(); |
| 373 clients_.front()->Disconnect(); | 368 clients_.front()->Disconnect(); |
| 374 CHECK_EQ(clients_.size(), size - 1); | 369 CHECK_EQ(clients_.size(), size - 1); |
| 375 } | 370 } |
| 376 } | 371 } |
| 377 | 372 |
| 373 void ChromotingHost::DisconnectClient(DesktopEnvironment* desktop_environment) { |
| 374 DCHECK(network_task_runner_->BelongsToCurrentThread()); |
| 375 |
| 376 for (ClientList::iterator i = clients_.begin(); i != clients_.end(); ++i) { |
| 377 if ((*i)->desktop_environment() == desktop_environment) { |
| 378 (*i)->Disconnect(); |
| 379 break; |
| 380 } |
| 381 } |
| 382 } |
| 383 |
| 378 void ChromotingHost::SetUiStrings(const UiStrings& ui_strings) { | 384 void ChromotingHost::SetUiStrings(const UiStrings& ui_strings) { |
| 379 DCHECK(network_task_runner_->BelongsToCurrentThread()); | 385 DCHECK(network_task_runner_->BelongsToCurrentThread()); |
| 380 DCHECK_EQ(state_, kInitial); | 386 DCHECK_EQ(state_, kInitial); |
| 381 | 387 |
| 382 ui_strings_ = ui_strings; | 388 ui_strings_ = ui_strings; |
| 383 } | 389 } |
| 384 | 390 |
| 385 void ChromotingHost::OnClientStopped() { | 391 void ChromotingHost::OnClientStopped() { |
| 386 DCHECK(network_task_runner_->BelongsToCurrentThread()); | 392 DCHECK(network_task_runner_->BelongsToCurrentThread()); |
| 387 | 393 |
| (...skipping 25 matching lines...) Expand all Loading... |
| 413 OnShutdown()); | 419 OnShutdown()); |
| 414 | 420 |
| 415 for (std::vector<base::Closure>::iterator it = shutdown_tasks_.begin(); | 421 for (std::vector<base::Closure>::iterator it = shutdown_tasks_.begin(); |
| 416 it != shutdown_tasks_.end(); ++it) { | 422 it != shutdown_tasks_.end(); ++it) { |
| 417 it->Run(); | 423 it->Run(); |
| 418 } | 424 } |
| 419 shutdown_tasks_.clear(); | 425 shutdown_tasks_.clear(); |
| 420 } | 426 } |
| 421 | 427 |
| 422 } // namespace remoting | 428 } // namespace remoting |
| OLD | NEW |