OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 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 | 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 "mash/init/init.h" | 5 #include "mash/init/init.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
9 #include "base/guid.h" | 9 #include "base/guid.h" |
10 #include "mash/login/public/interfaces/login.mojom.h" | 10 #include "mash/login/public/interfaces/login.mojom.h" |
11 #include "mojo/shell/public/cpp/connection.h" | 11 #include "mojo/shell/public/cpp/connection.h" |
12 #include "mojo/shell/public/cpp/connector.h" | 12 #include "mojo/shell/public/cpp/connector.h" |
13 | 13 |
14 namespace mash { | 14 namespace mash { |
15 namespace init { | 15 namespace init { |
16 | 16 |
17 Init::Init() : connector_(nullptr), login_user_id_(base::GenerateGUID()) {} | 17 Init::Init() |
| 18 : connector_(nullptr) {} |
18 Init::~Init() {} | 19 Init::~Init() {} |
19 | 20 |
20 void Init::Initialize(mojo::Connector* connector, | 21 void Init::Initialize(mojo::Connector* connector, |
21 const mojo::Identity& identity, | 22 const mojo::Identity& identity, |
22 uint32_t id) { | 23 uint32_t id) { |
23 connector_ = connector; | 24 connector_ = connector; |
24 connector_->Connect("mojo:mus"); | 25 connector_->Connect("mojo:mus"); |
| 26 StartTracing(); |
| 27 StartResourceProvider(); |
25 StartLogin(); | 28 StartLogin(); |
26 } | 29 } |
27 | 30 |
28 void Init::StartService(const mojo::String& name, | 31 void Init::StartService(const mojo::String& name, |
29 const mojo::String& user_id) { | 32 const mojo::String& user_id) { |
30 DCHECK(user_services_.find(user_id) == user_services_.end()); | 33 DCHECK(user_services_.find(user_id) == user_services_.end()); |
31 mojo::Connector::ConnectParams params(mojo::Identity(name, user_id)); | 34 mojo::Connector::ConnectParams params(mojo::Identity(name, user_id)); |
32 user_services_[user_id] = connector_->Connect(¶ms); | 35 user_services_[user_id] = connector_->Connect(¶ms); |
33 } | 36 } |
34 | 37 |
35 void Init::StopServicesForUser(const mojo::String& user_id) { | 38 void Init::StopServicesForUser(const mojo::String& user_id) { |
36 // TODO(beng): Make shell cascade shutdown of services. | |
37 auto it = user_services_.find(user_id); | 39 auto it = user_services_.find(user_id); |
38 if (it != user_services_.end()) | 40 if (it != user_services_.end()) |
39 user_services_.erase(it); | 41 user_services_.erase(it); |
40 } | 42 } |
41 | 43 |
42 void Init::Create(mojo::Connection* connection, mojom::InitRequest request) { | 44 void Init::Create(mojo::Connection* connection, mojom::InitRequest request) { |
43 init_bindings_.AddBinding(this, std::move(request)); | 45 init_bindings_.AddBinding(this, std::move(request)); |
44 } | 46 } |
45 | 47 |
| 48 void Init::StartTracing() { |
| 49 StartService("mojo:tracing", mojo::shell::mojom::kInheritUserID); |
| 50 } |
| 51 |
| 52 void Init::StartResourceProvider() { |
| 53 StartService("mojo:resource_provider", mojo::shell::mojom::kInheritUserID); |
| 54 } |
| 55 |
46 void Init::StartLogin() { | 56 void Init::StartLogin() { |
47 mojo::Connector::ConnectParams params( | 57 login_connection_ = connector_->Connect("mojo:login"); |
48 mojo::Identity("mojo:login", login_user_id_)); | |
49 login_connection_ = connector_->Connect(¶ms); | |
50 login_connection_->AddInterface<mojom::Init>(this); | 58 login_connection_->AddInterface<mojom::Init>(this); |
51 login_connection_->SetConnectionLostClosure( | 59 login_connection_->SetConnectionLostClosure( |
52 base::Bind(&Init::StartLogin, base::Unretained(this))); | 60 base::Bind(&Init::StartLogin, base::Unretained(this))); |
53 mash::login::mojom::LoginPtr login; | 61 mash::login::mojom::LoginPtr login; |
54 login_connection_->GetInterface(&login); | 62 login_connection_->GetInterface(&login); |
55 login->ShowLoginUI(); | 63 login->ShowLoginUI(); |
56 } | 64 } |
57 | 65 |
58 } // namespace init | 66 } // namespace init |
59 } // namespace main | 67 } // namespace main |
OLD | NEW |