OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "media/mojo/services/mojo_cdm_service.h" | 5 #include "media/mojo/services/mojo_cdm_service.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "media/base/cdm_config.h" | 8 #include "media/base/cdm_config.h" |
9 #include "media/base/cdm_factory.h" | 9 #include "media/base/cdm_factory.h" |
10 #include "media/base/cdm_key_information.h" | 10 #include "media/base/cdm_key_information.h" |
11 #include "media/base/key_systems.h" | 11 #include "media/base/key_systems.h" |
12 #include "media/mojo/services/media_type_converters.h" | 12 #include "media/mojo/services/media_type_converters.h" |
13 #include "media/mojo/services/mojo_cdm_service_context.h" | 13 #include "media/mojo/services/mojo_cdm_service_context.h" |
14 #include "mojo/common/common_type_converters.h" | 14 #include "mojo/common/common_type_converters.h" |
15 #include "mojo/common/url_type_converters.h" | 15 #include "mojo/common/url_type_converters.h" |
16 #include "url/gurl.h" | 16 #include "url/gurl.h" |
17 | 17 |
18 namespace media { | 18 namespace media { |
19 | 19 |
20 using NewSessionMojoCdmPromise = MojoCdmPromise<std::string>; | 20 using NewSessionMojoCdmPromise = MojoCdmPromise<std::string>; |
21 using SimpleMojoCdmPromise = MojoCdmPromise<>; | 21 using SimpleMojoCdmPromise = MojoCdmPromise<>; |
22 | 22 |
23 MojoCdmService::MojoCdmService( | 23 MojoCdmService::MojoCdmService( |
24 MojoCdmServiceContext* context, | 24 base::WeakPtr<MojoCdmServiceContext> context, |
25 mojo::ServiceProvider* service_provider, | 25 mojo::ServiceProvider* service_provider, |
26 CdmFactory* cdm_factory, | 26 CdmFactory* cdm_factory, |
27 mojo::InterfaceRequest<interfaces::ContentDecryptionModule> request) | 27 mojo::InterfaceRequest<interfaces::ContentDecryptionModule> request) |
28 : binding_(this, request.Pass()), | 28 : binding_(this, request.Pass()), |
29 context_(context), | 29 context_(context), |
30 service_provider_(service_provider), | 30 service_provider_(service_provider), |
31 cdm_factory_(cdm_factory), | 31 cdm_factory_(cdm_factory), |
32 cdm_id_(CdmContext::kInvalidCdmId), | 32 cdm_id_(CdmContext::kInvalidCdmId), |
33 weak_factory_(this) { | 33 weak_factory_(this) { |
34 DCHECK(context_); | 34 DCHECK(context_); |
35 DCHECK(cdm_factory_); | 35 DCHECK(cdm_factory_); |
36 } | 36 } |
37 | 37 |
38 MojoCdmService::~MojoCdmService() { | 38 MojoCdmService::~MojoCdmService() { |
39 if (cdm_id_ != CdmContext::kInvalidCdmId) | 39 if (cdm_id_ != CdmContext::kInvalidCdmId && context_) |
40 context_->UnregisterCdm(cdm_id_); | 40 context_->UnregisterCdm(cdm_id_); |
41 } | 41 } |
42 | 42 |
43 void MojoCdmService::SetClient( | 43 void MojoCdmService::SetClient( |
44 interfaces::ContentDecryptionModuleClientPtr client) { | 44 interfaces::ContentDecryptionModuleClientPtr client) { |
45 client_ = client.Pass(); | 45 client_ = client.Pass(); |
46 } | 46 } |
47 | 47 |
48 void MojoCdmService::Initialize( | 48 void MojoCdmService::Initialize( |
49 const mojo::String& key_system, | 49 const mojo::String& key_system, |
(...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
135 CdmContext* MojoCdmService::GetCdmContext() { | 135 CdmContext* MojoCdmService::GetCdmContext() { |
136 return cdm_->GetCdmContext(); | 136 return cdm_->GetCdmContext(); |
137 } | 137 } |
138 | 138 |
139 void MojoCdmService::OnCdmCreated(int cdm_id, | 139 void MojoCdmService::OnCdmCreated(int cdm_id, |
140 scoped_ptr<SimpleMojoCdmPromise> promise, | 140 scoped_ptr<SimpleMojoCdmPromise> promise, |
141 scoped_ptr<MediaKeys> cdm, | 141 scoped_ptr<MediaKeys> cdm, |
142 const std::string& error_message) { | 142 const std::string& error_message) { |
143 // TODO(xhwang): This should not happen when KeySystemInfo is properly | 143 // TODO(xhwang): This should not happen when KeySystemInfo is properly |
144 // populated. See http://crbug.com/469366 | 144 // populated. See http://crbug.com/469366 |
145 if (!cdm) { | 145 if (!cdm || !context_) { |
146 promise->reject(MediaKeys::NOT_SUPPORTED_ERROR, 0, error_message); | 146 promise->reject(MediaKeys::NOT_SUPPORTED_ERROR, 0, error_message); |
147 return; | 147 return; |
148 } | 148 } |
149 | 149 |
150 cdm_ = cdm.Pass(); | 150 cdm_ = cdm.Pass(); |
151 cdm_id_ = cdm_id; | 151 cdm_id_ = cdm_id; |
152 context_->RegisterCdm(cdm_id_, this); | 152 context_->RegisterCdm(cdm_id_, this); |
153 promise->resolve(); | 153 promise->resolve(); |
154 } | 154 } |
155 | 155 |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
192 MediaKeys::Exception exception, | 192 MediaKeys::Exception exception, |
193 uint32_t system_code, | 193 uint32_t system_code, |
194 const std::string& error_message) { | 194 const std::string& error_message) { |
195 DVLOG(2) << __FUNCTION__; | 195 DVLOG(2) << __FUNCTION__; |
196 client_->OnLegacySessionError( | 196 client_->OnLegacySessionError( |
197 session_id, static_cast<interfaces::CdmException>(exception), system_code, | 197 session_id, static_cast<interfaces::CdmException>(exception), system_code, |
198 error_message); | 198 error_message); |
199 } | 199 } |
200 | 200 |
201 } // namespace media | 201 } // namespace media |
OLD | NEW |