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 "content/renderer/media/crypto/proxy_media_keys.h" | 5 #include "content/renderer/media/crypto/proxy_media_keys.h" |
6 | 6 |
7 #include <vector> | 7 #include <vector> |
8 | 8 |
9 #include "base/basictypes.h" | 9 #include "base/basictypes.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
11 #include "base/stl_util.h" | 11 #include "base/stl_util.h" |
12 #include "content/renderer/media/crypto/cdm_initialized_promise.h" | |
12 #include "content/renderer/media/crypto/renderer_cdm_manager.h" | 13 #include "content/renderer/media/crypto/renderer_cdm_manager.h" |
13 #include "media/base/cdm_key_information.h" | 14 #include "media/base/cdm_key_information.h" |
14 #include "media/base/cdm_promise.h" | 15 #include "media/base/cdm_promise.h" |
15 #include "media/base/key_systems.h" | 16 #include "media/base/key_systems.h" |
16 | 17 |
17 namespace content { | 18 namespace content { |
18 | 19 |
19 scoped_ptr<ProxyMediaKeys> ProxyMediaKeys::Create( | 20 scoped_ptr<ProxyMediaKeys> ProxyMediaKeys::Create( |
20 const std::string& key_system, | 21 const std::string& key_system, |
21 const GURL& security_origin, | 22 const GURL& security_origin, |
22 RendererCdmManager* manager, | 23 RendererCdmManager* manager, |
23 const media::SessionMessageCB& session_message_cb, | 24 const media::SessionMessageCB& session_message_cb, |
24 const media::SessionClosedCB& session_closed_cb, | 25 const media::SessionClosedCB& session_closed_cb, |
25 const media::LegacySessionErrorCB& legacy_session_error_cb, | 26 const media::LegacySessionErrorCB& legacy_session_error_cb, |
26 const media::SessionKeysChangeCB& session_keys_change_cb, | 27 const media::SessionKeysChangeCB& session_keys_change_cb, |
27 const media::SessionExpirationUpdateCB& session_expiration_update_cb) { | 28 const media::SessionExpirationUpdateCB& session_expiration_update_cb, |
29 const media::CdmCreatedCB& cdm_created_cb) { | |
28 DCHECK(manager); | 30 DCHECK(manager); |
29 scoped_ptr<ProxyMediaKeys> proxy_media_keys(new ProxyMediaKeys( | 31 scoped_ptr<ProxyMediaKeys> proxy_media_keys(new ProxyMediaKeys( |
30 manager, session_message_cb, session_closed_cb, legacy_session_error_cb, | 32 manager, session_message_cb, session_closed_cb, legacy_session_error_cb, |
31 session_keys_change_cb, session_expiration_update_cb)); | 33 session_keys_change_cb, session_expiration_update_cb)); |
32 proxy_media_keys->InitializeCdm(key_system, security_origin); | 34 if (!proxy_media_keys) { |
ddorwin
2015/05/04 22:46:02
ditto
jrummell
2015/05/05 00:54:17
Done.
| |
33 return proxy_media_keys.Pass(); | 35 base::MessageLoopProxy::current()->PostTask( |
36 FROM_HERE, base::Bind(cdm_created_cb, nullptr)); | |
37 return; | |
38 } | |
39 | |
40 // ProxyMediaKeys ownership passed to the promise, but keep a copy in order | |
41 // to call InitializeCdm(). | |
42 ProxyMediaKeys* proxy_media_keys_copy = proxy_media_keys.get(); | |
43 scoped_ptr<CdmInitializedPromise> promise( | |
44 new CdmInitializedPromise(cdm_created_cb, proxy_media_keys.Pass())); | |
45 proxy_media_keys_copy->InitializeCdm(key_system, security_origin, | |
46 promise.Pass()); | |
34 } | 47 } |
35 | 48 |
36 ProxyMediaKeys::~ProxyMediaKeys() { | 49 ProxyMediaKeys::~ProxyMediaKeys() { |
37 manager_->DestroyCdm(cdm_id_); | 50 manager_->DestroyCdm(cdm_id_); |
38 manager_->UnregisterMediaKeys(cdm_id_); | 51 manager_->UnregisterMediaKeys(cdm_id_); |
39 cdm_promise_adapter_.Clear(); | 52 cdm_promise_adapter_.Clear(); |
40 } | 53 } |
41 | 54 |
42 void ProxyMediaKeys::SetServerCertificate( | 55 void ProxyMediaKeys::SetServerCertificate( |
43 const std::vector<uint8_t>& certificate, | 56 const std::vector<uint8_t>& certificate, |
(...skipping 142 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
186 const media::SessionExpirationUpdateCB& session_expiration_update_cb) | 199 const media::SessionExpirationUpdateCB& session_expiration_update_cb) |
187 : manager_(manager), | 200 : manager_(manager), |
188 session_message_cb_(session_message_cb), | 201 session_message_cb_(session_message_cb), |
189 session_closed_cb_(session_closed_cb), | 202 session_closed_cb_(session_closed_cb), |
190 legacy_session_error_cb_(legacy_session_error_cb), | 203 legacy_session_error_cb_(legacy_session_error_cb), |
191 session_keys_change_cb_(session_keys_change_cb), | 204 session_keys_change_cb_(session_keys_change_cb), |
192 session_expiration_update_cb_(session_expiration_update_cb) { | 205 session_expiration_update_cb_(session_expiration_update_cb) { |
193 cdm_id_ = manager->RegisterMediaKeys(this); | 206 cdm_id_ = manager->RegisterMediaKeys(this); |
194 } | 207 } |
195 | 208 |
196 void ProxyMediaKeys::InitializeCdm(const std::string& key_system, | 209 void ProxyMediaKeys::InitializeCdm( |
197 const GURL& security_origin) { | 210 const std::string& key_system, |
211 const GURL& security_origin, | |
212 scoped_ptr<media::SimpleCdmPromise> promise) { | |
213 // TODO(jrummell): |Pass promise| on. http://crbug.com/407435. | |
ddorwin
2015/05/04 22:46:02
This bug only refers to CdmAdapater. Did you mean
jrummell
2015/05/05 00:54:17
Done.
| |
198 manager_->InitializeCdm(cdm_id_, this, key_system, security_origin); | 214 manager_->InitializeCdm(cdm_id_, this, key_system, security_origin); |
215 promise->resolve(); | |
199 } | 216 } |
200 | 217 |
201 } // namespace content | 218 } // namespace content |
OLD | NEW |