lambroslambrou | e0c2d024 | 2016-03-23 01:21:20 | [diff] [blame] | 1 | // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
| 5 | #include "remoting/client/chromoting_client_runtime.h" |
| 6 | |
| 7 | #include "base/bind.h" |
Peter Kasting | 383640f5 | 2018-02-13 06:22:40 | [diff] [blame] | 8 | #include "base/bind_helpers.h" |
lambroslambrou | e0c2d024 | 2016-03-23 01:21:20 | [diff] [blame] | 9 | #include "base/logging.h" |
nicholss | 825f7eb | 2017-03-17 18:48:45 | [diff] [blame] | 10 | #include "base/memory/singleton.h" |
Alexander Timin | 4f9c35c | 2018-11-01 20:15:20 | [diff] [blame] | 11 | #include "base/message_loop/message_loop.h" |
Gabriel Charette | aec08d4 | 2018-04-24 21:40:31 | [diff] [blame] | 12 | #include "base/message_loop/message_loop_current.h" |
Gabriel Charette | 52fa3ae | 2019-04-15 21:44:37 | [diff] [blame] | 13 | #include "base/task/thread_pool/thread_pool.h" |
Ran Ji | 3d6ec66 | 2018-07-09 21:18:30 | [diff] [blame] | 14 | #include "build/build_config.h" |
Yuwei Huang | 4debbed7 | 2018-08-30 20:51:25 | [diff] [blame] | 15 | #include "mojo/core/embedder/embedder.h" |
nicholss | 825f7eb | 2017-03-17 18:48:45 | [diff] [blame] | 16 | #include "remoting/base/chromium_url_request.h" |
Yuwei Huang | 786d887 | 2019-04-30 01:07:23 | [diff] [blame] | 17 | #include "remoting/base/oauth_token_getter_proxy.h" |
nicholss | 825f7eb | 2017-03-17 18:48:45 | [diff] [blame] | 18 | #include "remoting/base/telemetry_log_writer.h" |
lambroslambrou | e0c2d024 | 2016-03-23 01:21:20 | [diff] [blame] | 19 | #include "remoting/base/url_request_context_getter.h" |
Maks Orlovich | 8db7d0d6 | 2018-08-16 19:22:27 | [diff] [blame] | 20 | #include "services/network/public/cpp/shared_url_loader_factory.h" |
| 21 | #include "services/network/transitional_url_loader_factory_owner.h" |
lambroslambrou | e0c2d024 | 2016-03-23 01:21:20 | [diff] [blame] | 22 | |
nicholss | 825f7eb | 2017-03-17 18:48:45 | [diff] [blame] | 23 | namespace { |
| 24 | |
| 25 | const char kTelemetryBaseUrl[] = "https://remoting-pa.googleapis.com/v1/events"; |
| 26 | |
| 27 | } // namespace |
| 28 | |
lambroslambrou | e0c2d024 | 2016-03-23 01:21:20 | [diff] [blame] | 29 | namespace remoting { |
| 30 | |
nicholss | 825f7eb | 2017-03-17 18:48:45 | [diff] [blame] | 31 | // static |
| 32 | ChromotingClientRuntime* ChromotingClientRuntime::GetInstance() { |
| 33 | return base::Singleton<ChromotingClientRuntime>::get(); |
| 34 | } |
| 35 | |
| 36 | ChromotingClientRuntime::ChromotingClientRuntime() { |
Gabriel Charette | 43fd370 | 2019-05-29 16:36:51 | [diff] [blame^] | 37 | base::ThreadPoolInstance::CreateAndStartWithDefaultParams("Remoting"); |
nicholss | 825f7eb | 2017-03-17 18:48:45 | [diff] [blame] | 38 | |
Gabriel Charette | aec08d4 | 2018-04-24 21:40:31 | [diff] [blame] | 39 | DCHECK(!base::MessageLoopCurrent::Get()); |
Gabriel Charette | 12c0fc10 | 2018-03-30 02:03:23 | [diff] [blame] | 40 | |
| 41 | VLOG(1) << "Starting main message loop"; |
| 42 | ui_loop_.reset(new base::MessageLoopForUI()); |
Ran Ji | 3d6ec66 | 2018-07-09 21:18:30 | [diff] [blame] | 43 | #if defined(OS_IOS) |
| 44 | // TODO(ranj): Attach on BindToCurrentThread(). |
Gabriel Charette | 12c0fc10 | 2018-03-30 02:03:23 | [diff] [blame] | 45 | ui_loop_->Attach(); |
Ran Ji | 3d6ec66 | 2018-07-09 21:18:30 | [diff] [blame] | 46 | #endif |
nicholss | 825f7eb | 2017-03-17 18:48:45 | [diff] [blame] | 47 | |
| 48 | #if defined(DEBUG) |
| 49 | net::URLFetcher::SetIgnoreCertificateRequests(true); |
| 50 | #endif // DEBUG |
lambroslambrou | e0c2d024 | 2016-03-23 01:21:20 | [diff] [blame] | 51 | |
| 52 | // |ui_loop_| runs on the main thread, so |ui_task_runner_| will run on the |
| 53 | // main thread. We can not kill the main thread when the message loop becomes |
| 54 | // idle so the callback function does nothing (as opposed to the typical |
| 55 | // base::MessageLoop::QuitClosure()) |
Peter Kasting | 341e1fb | 2018-02-24 00:03:01 | [diff] [blame] | 56 | ui_task_runner_ = |
| 57 | new AutoThreadTaskRunner(ui_loop_->task_runner(), base::DoNothing()); |
Scott Nichols | 77a375a | 2017-09-19 20:49:02 | [diff] [blame] | 58 | audio_task_runner_ = AutoThread::Create("native_audio", ui_task_runner_); |
nicholss | 825f7eb | 2017-03-17 18:48:45 | [diff] [blame] | 59 | display_task_runner_ = AutoThread::Create("native_disp", ui_task_runner_); |
| 60 | network_task_runner_ = AutoThread::CreateWithType( |
| 61 | "native_net", ui_task_runner_, base::MessageLoop::TYPE_IO); |
Yuwei Huang | 4debbed7 | 2018-08-30 20:51:25 | [diff] [blame] | 62 | |
| 63 | mojo::core::Init(); |
lambroslambrou | e0c2d024 | 2016-03-23 01:21:20 | [diff] [blame] | 64 | } |
| 65 | |
nicholss | 825f7eb | 2017-03-17 18:48:45 | [diff] [blame] | 66 | ChromotingClientRuntime::~ChromotingClientRuntime() { |
| 67 | if (delegate_) { |
| 68 | delegate_->RuntimeWillShutdown(); |
| 69 | } else { |
| 70 | DLOG(ERROR) << "ClientRuntime Delegate is null."; |
| 71 | } |
lambroslambrou | e0c2d024 | 2016-03-23 01:21:20 | [diff] [blame] | 72 | |
nicholss | 825f7eb | 2017-03-17 18:48:45 | [diff] [blame] | 73 | // Block until tasks blocking shutdown have completed their execution. |
Gabriel Charette | 43fd370 | 2019-05-29 16:36:51 | [diff] [blame^] | 74 | base::ThreadPoolInstance::Get()->Shutdown(); |
nicholss | 825f7eb | 2017-03-17 18:48:45 | [diff] [blame] | 75 | |
| 76 | if (delegate_) { |
| 77 | delegate_->RuntimeDidShutdown(); |
| 78 | } |
| 79 | } |
| 80 | |
Yuwei Huang | 50afc83 | 2018-03-21 22:00:26 | [diff] [blame] | 81 | void ChromotingClientRuntime::Init( |
nicholss | 825f7eb | 2017-03-17 18:48:45 | [diff] [blame] | 82 | ChromotingClientRuntime::Delegate* delegate) { |
Yuwei Huang | 50afc83 | 2018-03-21 22:00:26 | [diff] [blame] | 83 | DCHECK(delegate); |
| 84 | DCHECK(!delegate_); |
nicholss | 825f7eb | 2017-03-17 18:48:45 | [diff] [blame] | 85 | delegate_ = delegate; |
Yuwei Huang | a1f0a5b | 2018-09-10 20:58:34 | [diff] [blame] | 86 | url_requester_ = new URLRequestContextGetter(network_task_runner_); |
| 87 | log_writer_ = std::make_unique<TelemetryLogWriter>(kTelemetryBaseUrl, |
| 88 | CreateOAuthTokenGetter()); |
Yuwei Huang | 4debbed7 | 2018-08-30 20:51:25 | [diff] [blame] | 89 | network_task_runner()->PostTask( |
| 90 | FROM_HERE, |
| 91 | base::BindOnce(&ChromotingClientRuntime::InitializeOnNetworkThread, |
| 92 | base::Unretained(this))); |
nicholss | 825f7eb | 2017-03-17 18:48:45 | [diff] [blame] | 93 | } |
| 94 | |
Yuwei Huang | 50afc83 | 2018-03-21 22:00:26 | [diff] [blame] | 95 | std::unique_ptr<OAuthTokenGetter> |
| 96 | ChromotingClientRuntime::CreateOAuthTokenGetter() { |
| 97 | return std::make_unique<OAuthTokenGetterProxy>( |
| 98 | delegate_->oauth_token_getter(), ui_task_runner()); |
Yuwei Huang | 19220930 | 2017-11-09 00:06:08 | [diff] [blame] | 99 | } |
lambroslambrou | e0c2d024 | 2016-03-23 01:21:20 | [diff] [blame] | 100 | |
Maks Orlovich | 8db7d0d6 | 2018-08-16 19:22:27 | [diff] [blame] | 101 | scoped_refptr<network::SharedURLLoaderFactory> |
| 102 | ChromotingClientRuntime::url_loader_factory() { |
Yuwei Huang | 4debbed7 | 2018-08-30 20:51:25 | [diff] [blame] | 103 | DCHECK(network_task_runner()->BelongsToCurrentThread()); |
Maks Orlovich | 8db7d0d6 | 2018-08-16 19:22:27 | [diff] [blame] | 104 | return url_loader_factory_owner_->GetURLLoaderFactory(); |
| 105 | } |
| 106 | |
Yuwei Huang | 4debbed7 | 2018-08-30 20:51:25 | [diff] [blame] | 107 | void ChromotingClientRuntime::InitializeOnNetworkThread() { |
| 108 | DCHECK(network_task_runner()->BelongsToCurrentThread()); |
Yuwei Huang | 4debbed7 | 2018-08-30 20:51:25 | [diff] [blame] | 109 | url_loader_factory_owner_ = |
| 110 | std::make_unique<network::TransitionalURLLoaderFactoryOwner>( |
| 111 | url_requester_); |
| 112 | log_writer_->Init( |
| 113 | std::make_unique<ChromiumUrlRequestFactory>(url_loader_factory())); |
| 114 | } |
| 115 | |
lambroslambrou | e0c2d024 | 2016-03-23 01:21:20 | [diff] [blame] | 116 | } // namespace remoting |