blob: 170a2f56c027183023cfb1ed845c0d424ba9cb94 [file] [log] [blame]
lambroslambroue0c2d0242016-03-23 01:21:201// 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"
danakjdb9ae7942020-11-11 16:01:358#include "base/callback_helpers.h"
lambroslambroue0c2d0242016-03-23 01:21:209#include "base/logging.h"
nicholss825f7eb2017-03-17 18:48:4510#include "base/memory/singleton.h"
Carlos Caballerodd8bf7b042019-07-30 14:14:1511#include "base/message_loop/message_pump_type.h"
Carlos Caballerob25fe8472020-07-17 10:27:1712#include "base/task/current_thread.h"
Alex Clarkef7fb8a82019-06-06 15:41:5313#include "base/task/single_thread_task_executor.h"
Gabriel Charetteeadf58862019-08-29 05:20:2714#include "base/task/thread_pool/thread_pool_instance.h"
Ran Ji3d6ec662018-07-09 21:18:3015#include "build/build_config.h"
Yuwei Huang4debbed72018-08-30 20:51:2516#include "mojo/core/embedder/embedder.h"
nicholss825f7eb2017-03-17 18:48:4517#include "remoting/base/chromium_url_request.h"
Yuwei Huangfa4b0e72020-07-28 00:08:3818#include "remoting/base/directory_service_client.h"
Yuwei Huang786d8872019-04-30 01:07:2319#include "remoting/base/oauth_token_getter_proxy.h"
nicholss825f7eb2017-03-17 18:48:4520#include "remoting/base/telemetry_log_writer.h"
lambroslambroue0c2d0242016-03-23 01:21:2021#include "remoting/base/url_request_context_getter.h"
Maks Orlovich8db7d0d62018-08-16 19:22:2722#include "services/network/public/cpp/shared_url_loader_factory.h"
23#include "services/network/transitional_url_loader_factory_owner.h"
lambroslambroue0c2d0242016-03-23 01:21:2024
25namespace remoting {
26
nicholss825f7eb2017-03-17 18:48:4527// static
28ChromotingClientRuntime* ChromotingClientRuntime::GetInstance() {
29 return base::Singleton<ChromotingClientRuntime>::get();
30}
31
32ChromotingClientRuntime::ChromotingClientRuntime() {
Gabriel Charette43fd3702019-05-29 16:36:5133 base::ThreadPoolInstance::CreateAndStartWithDefaultParams("Remoting");
nicholss825f7eb2017-03-17 18:48:4534
Carlos Caballerob25fe8472020-07-17 10:27:1735 DCHECK(!base::CurrentThread::Get());
Gabriel Charette12c0fc102018-03-30 02:03:2336
37 VLOG(1) << "Starting main message loop";
Alex Clarkef7fb8a82019-06-06 15:41:5338 ui_task_executor_.reset(
Carlos Caballerodd8bf7b042019-07-30 14:14:1539 new base::SingleThreadTaskExecutor(base::MessagePumpType::UI));
nicholss825f7eb2017-03-17 18:48:4540
41#if defined(DEBUG)
42 net::URLFetcher::SetIgnoreCertificateRequests(true);
43#endif // DEBUG
lambroslambroue0c2d0242016-03-23 01:21:2044
Alex Clarkef7fb8a82019-06-06 15:41:5345 // |ui_task_executor_| runs on the main thread, so |ui_task_runner_| will run
46 // on the main thread. We can not kill the main thread when the message loop
47 // becomes idle so the callback function does nothing (as opposed to the
48 // typical base::MessageLoop::QuitClosure())
49 ui_task_runner_ = new AutoThreadTaskRunner(ui_task_executor_->task_runner(),
50 base::DoNothing());
Scott Nichols77a375a2017-09-19 20:49:0251 audio_task_runner_ = AutoThread::Create("native_audio", ui_task_runner_);
nicholss825f7eb2017-03-17 18:48:4552 display_task_runner_ = AutoThread::Create("native_disp", ui_task_runner_);
53 network_task_runner_ = AutoThread::CreateWithType(
Carlos Caballerodd8bf7b042019-07-30 14:14:1554 "native_net", ui_task_runner_, base::MessagePumpType::IO);
Yuwei Huang4debbed72018-08-30 20:51:2555
56 mojo::core::Init();
lambroslambroue0c2d0242016-03-23 01:21:2057}
58
nicholss825f7eb2017-03-17 18:48:4559ChromotingClientRuntime::~ChromotingClientRuntime() {
60 if (delegate_) {
61 delegate_->RuntimeWillShutdown();
62 } else {
63 DLOG(ERROR) << "ClientRuntime Delegate is null.";
64 }
lambroslambroue0c2d0242016-03-23 01:21:2065
nicholss825f7eb2017-03-17 18:48:4566 // Block until tasks blocking shutdown have completed their execution.
Gabriel Charette43fd3702019-05-29 16:36:5167 base::ThreadPoolInstance::Get()->Shutdown();
nicholss825f7eb2017-03-17 18:48:4568
69 if (delegate_) {
70 delegate_->RuntimeDidShutdown();
71 }
72}
73
Yuwei Huang50afc832018-03-21 22:00:2674void ChromotingClientRuntime::Init(
nicholss825f7eb2017-03-17 18:48:4575 ChromotingClientRuntime::Delegate* delegate) {
Yuwei Huang50afc832018-03-21 22:00:2676 DCHECK(delegate);
77 DCHECK(!delegate_);
nicholss825f7eb2017-03-17 18:48:4578 delegate_ = delegate;
Yuwei Huanga1f0a5b2018-09-10 20:58:3479 url_requester_ = new URLRequestContextGetter(network_task_runner_);
Erik Jensen2c673d12019-05-31 00:00:1780 log_writer_ = std::make_unique<TelemetryLogWriter>(CreateOAuthTokenGetter());
Yuwei Huang4debbed72018-08-30 20:51:2581 network_task_runner()->PostTask(
82 FROM_HERE,
83 base::BindOnce(&ChromotingClientRuntime::InitializeOnNetworkThread,
84 base::Unretained(this)));
nicholss825f7eb2017-03-17 18:48:4585}
86
Yuwei Huang50afc832018-03-21 22:00:2687std::unique_ptr<OAuthTokenGetter>
88ChromotingClientRuntime::CreateOAuthTokenGetter() {
89 return std::make_unique<OAuthTokenGetterProxy>(
90 delegate_->oauth_token_getter(), ui_task_runner());
Yuwei Huang192209302017-11-09 00:06:0891}
lambroslambroue0c2d0242016-03-23 01:21:2092
Yuwei Huangfa4b0e72020-07-28 00:08:3893base::SequenceBound<DirectoryServiceClient>
94ChromotingClientRuntime::CreateDirectoryServiceClient() {
95 // A DirectoryServiceClient subclass that calls url_loader_factory() in its
96 // constructor, as we can't call it on a non-network thread then pass it via
97 // base::SequenceBound.
98 class ClientDirectoryServiceClient : public DirectoryServiceClient {
99 public:
100 ClientDirectoryServiceClient(ChromotingClientRuntime* runtime,
101 std::unique_ptr<OAuthTokenGetter> token_getter)
102 : DirectoryServiceClient(token_getter.get(),
103 runtime->url_loader_factory()),
104 token_getter_(std::move(token_getter)) {}
105 ~ClientDirectoryServiceClient() override = default;
106
107 private:
108 std::unique_ptr<OAuthTokenGetter> token_getter_;
109 };
110
111 return base::SequenceBound<ClientDirectoryServiceClient>(
112 network_task_runner(), this, CreateOAuthTokenGetter());
113}
114
Maks Orlovich8db7d0d62018-08-16 19:22:27115scoped_refptr<network::SharedURLLoaderFactory>
116ChromotingClientRuntime::url_loader_factory() {
Yuwei Huang4debbed72018-08-30 20:51:25117 DCHECK(network_task_runner()->BelongsToCurrentThread());
Maks Orlovich8db7d0d62018-08-16 19:22:27118 return url_loader_factory_owner_->GetURLLoaderFactory();
119}
120
Yuwei Huang4debbed72018-08-30 20:51:25121void ChromotingClientRuntime::InitializeOnNetworkThread() {
122 DCHECK(network_task_runner()->BelongsToCurrentThread());
Yuwei Huang4debbed72018-08-30 20:51:25123 url_loader_factory_owner_ =
124 std::make_unique<network::TransitionalURLLoaderFactoryOwner>(
125 url_requester_);
Yuwei Huang311227be2020-07-30 21:06:40126 log_writer_->Init(url_loader_factory_owner_->GetURLLoaderFactory());
Yuwei Huang4debbed72018-08-30 20:51:25127}
128
lambroslambroue0c2d0242016-03-23 01:21:20129} // namespace remoting