| 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/client_session.h" | 5 #include "remoting/host/client_session.h" | 
| 6 | 6 | 
| 7 #include <algorithm> | 7 #include <algorithm> | 
| 8 | 8 | 
| 9 #include "base/message_loop_proxy.h" | 9 #include "base/message_loop_proxy.h" | 
| 10 #include "remoting/codec/audio_encoder.h" | 10 #include "remoting/codec/audio_encoder.h" | 
| (...skipping 11 matching lines...) Expand all  Loading... | 
| 22 #include "remoting/host/video_frame_capturer.h" | 22 #include "remoting/host/video_frame_capturer.h" | 
| 23 #include "remoting/proto/control.pb.h" | 23 #include "remoting/proto/control.pb.h" | 
| 24 #include "remoting/proto/event.pb.h" | 24 #include "remoting/proto/event.pb.h" | 
| 25 #include "remoting/protocol/client_stub.h" | 25 #include "remoting/protocol/client_stub.h" | 
| 26 #include "remoting/protocol/clipboard_thread_proxy.h" | 26 #include "remoting/protocol/clipboard_thread_proxy.h" | 
| 27 | 27 | 
| 28 namespace remoting { | 28 namespace remoting { | 
| 29 | 29 | 
| 30 ClientSession::ClientSession( | 30 ClientSession::ClientSession( | 
| 31     EventHandler* event_handler, | 31     EventHandler* event_handler, | 
|  | 32     scoped_refptr<base::SingleThreadTaskRunner> audio_task_runner, | 
| 32     scoped_refptr<base::SingleThreadTaskRunner> capture_task_runner, | 33     scoped_refptr<base::SingleThreadTaskRunner> capture_task_runner, | 
| 33     scoped_refptr<base::SingleThreadTaskRunner> encode_task_runner, | 34     scoped_refptr<base::SingleThreadTaskRunner> encode_task_runner, | 
| 34     scoped_refptr<base::SingleThreadTaskRunner> network_task_runner, | 35     scoped_refptr<base::SingleThreadTaskRunner> network_task_runner, | 
| 35     scoped_ptr<protocol::ConnectionToClient> connection, | 36     scoped_ptr<protocol::ConnectionToClient> connection, | 
| 36     DesktopEnvironmentFactory* desktop_environment_factory, | 37     DesktopEnvironmentFactory* desktop_environment_factory, | 
| 37     const base::TimeDelta& max_duration) | 38     const base::TimeDelta& max_duration) | 
| 38     : event_handler_(event_handler), | 39     : event_handler_(event_handler), | 
| 39       connection_(connection.Pass()), | 40       connection_(connection.Pass()), | 
| 40       desktop_environment_(desktop_environment_factory->Create( | 41       desktop_environment_(desktop_environment_factory->Create( | 
| 41           ALLOW_THIS_IN_INITIALIZER_LIST(this))), | 42           ALLOW_THIS_IN_INITIALIZER_LIST(this))), | 
| 42       client_jid_(connection_->session()->jid()), | 43       client_jid_(connection_->session()->jid()), | 
| 43       host_clipboard_stub_(desktop_environment_->event_executor()), | 44       host_clipboard_stub_(desktop_environment_->event_executor()), | 
| 44       host_input_stub_(desktop_environment_->event_executor()), | 45       host_input_stub_(desktop_environment_->event_executor()), | 
| 45       input_tracker_(host_input_stub_), | 46       input_tracker_(host_input_stub_), | 
| 46       remote_input_filter_(&input_tracker_), | 47       remote_input_filter_(&input_tracker_), | 
| 47       mouse_clamping_filter_(desktop_environment_->video_capturer(), | 48       mouse_clamping_filter_(desktop_environment_->video_capturer(), | 
| 48                              &remote_input_filter_), | 49                              &remote_input_filter_), | 
| 49       disable_input_filter_(&mouse_clamping_filter_), | 50       disable_input_filter_(&mouse_clamping_filter_), | 
| 50       disable_clipboard_filter_(clipboard_echo_filter_.host_filter()), | 51       disable_clipboard_filter_(clipboard_echo_filter_.host_filter()), | 
| 51       auth_input_filter_(&disable_input_filter_), | 52       auth_input_filter_(&disable_input_filter_), | 
| 52       auth_clipboard_filter_(&disable_clipboard_filter_), | 53       auth_clipboard_filter_(&disable_clipboard_filter_), | 
| 53       client_clipboard_factory_(clipboard_echo_filter_.client_filter()), | 54       client_clipboard_factory_(clipboard_echo_filter_.client_filter()), | 
| 54       max_duration_(max_duration), | 55       max_duration_(max_duration), | 
|  | 56       audio_task_runner_(audio_task_runner), | 
| 55       capture_task_runner_(capture_task_runner), | 57       capture_task_runner_(capture_task_runner), | 
| 56       encode_task_runner_(encode_task_runner), | 58       encode_task_runner_(encode_task_runner), | 
| 57       network_task_runner_(network_task_runner), | 59       network_task_runner_(network_task_runner), | 
| 58       active_recorders_(0) { | 60       active_recorders_(0) { | 
| 59   connection_->SetEventHandler(this); | 61   connection_->SetEventHandler(this); | 
| 60 | 62 | 
| 61   // TODO(sergeyu): Currently ConnectionToClient expects stubs to be | 63   // TODO(sergeyu): Currently ConnectionToClient expects stubs to be | 
| 62   // set before channels are connected. Make it possible to set stubs | 64   // set before channels are connected. Make it possible to set stubs | 
| 63   // later and set them only when connection is authenticated. | 65   // later and set them only when connection is authenticated. | 
| 64   connection_->set_clipboard_stub(&auth_clipboard_filter_); | 66   connection_->set_clipboard_stub(&auth_clipboard_filter_); | 
| (...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 133                                        encode_task_runner_, | 135                                        encode_task_runner_, | 
| 134                                        network_task_runner_, | 136                                        network_task_runner_, | 
| 135                                        desktop_environment_->video_capturer(), | 137                                        desktop_environment_->video_capturer(), | 
| 136                                        video_encoder); | 138                                        video_encoder); | 
| 137   ++active_recorders_; | 139   ++active_recorders_; | 
| 138 | 140 | 
| 139   if (connection_->session()->config().is_audio_enabled()) { | 141   if (connection_->session()->config().is_audio_enabled()) { | 
| 140     scoped_ptr<AudioEncoder> audio_encoder = | 142     scoped_ptr<AudioEncoder> audio_encoder = | 
| 141         CreateAudioEncoder(connection_->session()->config()); | 143         CreateAudioEncoder(connection_->session()->config()); | 
| 142     audio_scheduler_ = new AudioScheduler( | 144     audio_scheduler_ = new AudioScheduler( | 
| 143         capture_task_runner_, | 145         audio_task_runner_, | 
| 144         network_task_runner_, | 146         network_task_runner_, | 
| 145         desktop_environment_->audio_capturer(), | 147         desktop_environment_.get(), | 
| 146         audio_encoder.Pass(), | 148         audio_encoder.Pass(), | 
| 147         connection_->audio_stub()); | 149         connection_->audio_stub()); | 
| 148     ++active_recorders_; | 150     ++active_recorders_; | 
| 149   } | 151   } | 
| 150 | 152 | 
| 151   // Start the session. | 153   // Start the session. | 
| 152   video_recorder_->AddConnection(connection_.get()); | 154   video_recorder_->AddConnection(connection_.get()); | 
| 153   video_recorder_->Start(); | 155   video_recorder_->Start(); | 
| 154   desktop_environment_->Start(CreateClipboardProxy()); | 156   desktop_environment_->Start(CreateClipboardProxy()); | 
| 155 | 157 | 
| (...skipping 154 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 310   NOTIMPLEMENTED(); | 312   NOTIMPLEMENTED(); | 
| 311   return scoped_ptr<AudioEncoder>(NULL); | 313   return scoped_ptr<AudioEncoder>(NULL); | 
| 312 } | 314 } | 
| 313 | 315 | 
| 314 // static | 316 // static | 
| 315 void ClientSessionTraits::Destruct(const ClientSession* client) { | 317 void ClientSessionTraits::Destruct(const ClientSession* client) { | 
| 316   client->network_task_runner_->DeleteSoon(FROM_HERE, client); | 318   client->network_task_runner_->DeleteSoon(FROM_HERE, client); | 
| 317 } | 319 } | 
| 318 | 320 | 
| 319 }  // namespace remoting | 321 }  // namespace remoting | 
| OLD | NEW | 
|---|