Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(730)

Side by Side Diff: content/renderer/media/crypto/proxy_media_keys.cc

Issue 1102363005: Initialize the CDM asynchronously (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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/renderer_cdm_manager.h" 12 #include "content/renderer/media/crypto/renderer_cdm_manager.h"
13 #include "media/base/cdm_key_information.h" 13 #include "media/base/cdm_key_information.h"
14 #include "media/base/cdm_promise.h" 14 #include "media/base/cdm_promise.h"
15 #include "media/base/key_systems.h" 15 #include "media/base/key_systems.h"
16 16
17 namespace content { 17 namespace content {
18 18
19 scoped_ptr<ProxyMediaKeys> ProxyMediaKeys::Create( 19 scoped_ptr<ProxyMediaKeys> ProxyMediaKeys::Create(
20 const std::string& key_system,
21 const GURL& security_origin,
22 RendererCdmManager* manager, 20 RendererCdmManager* manager,
23 const media::SessionMessageCB& session_message_cb, 21 const media::SessionMessageCB& session_message_cb,
24 const media::SessionClosedCB& session_closed_cb, 22 const media::SessionClosedCB& session_closed_cb,
25 const media::LegacySessionErrorCB& legacy_session_error_cb, 23 const media::LegacySessionErrorCB& legacy_session_error_cb,
26 const media::SessionKeysChangeCB& session_keys_change_cb, 24 const media::SessionKeysChangeCB& session_keys_change_cb,
27 const media::SessionExpirationUpdateCB& session_expiration_update_cb) { 25 const media::SessionExpirationUpdateCB& session_expiration_update_cb) {
28 DCHECK(manager); 26 DCHECK(manager);
29 scoped_ptr<ProxyMediaKeys> proxy_media_keys(new ProxyMediaKeys( 27 scoped_ptr<ProxyMediaKeys> proxy_media_keys(new ProxyMediaKeys(
30 manager, session_message_cb, session_closed_cb, legacy_session_error_cb, 28 manager, session_message_cb, session_closed_cb, legacy_session_error_cb,
31 session_keys_change_cb, session_expiration_update_cb)); 29 session_keys_change_cb, session_expiration_update_cb));
32 proxy_media_keys->InitializeCdm(key_system, security_origin);
33 return proxy_media_keys.Pass(); 30 return proxy_media_keys.Pass();
34 } 31 }
35 32
36 ProxyMediaKeys::~ProxyMediaKeys() { 33 ProxyMediaKeys::~ProxyMediaKeys() {
37 manager_->DestroyCdm(cdm_id_); 34 manager_->DestroyCdm(cdm_id_);
38 manager_->UnregisterMediaKeys(cdm_id_); 35 manager_->UnregisterMediaKeys(cdm_id_);
39 cdm_promise_adapter_.Clear(); 36 cdm_promise_adapter_.Clear();
40 } 37 }
41 38
39 void ProxyMediaKeys::InitializeCdm(
40 const std::string& key_system,
41 const GURL& security_origin,
42 scoped_ptr<media::SimpleCdmPromise> promise) {
43 // TODO(jrummell): |Pass promise| on. http://crbug.com/407435.
44 manager_->InitializeCdm(cdm_id_, this, key_system, security_origin);
45 promise->resolve();
46 }
47
42 void ProxyMediaKeys::SetServerCertificate( 48 void ProxyMediaKeys::SetServerCertificate(
43 const std::vector<uint8_t>& certificate, 49 const std::vector<uint8_t>& certificate,
44 scoped_ptr<media::SimpleCdmPromise> promise) { 50 scoped_ptr<media::SimpleCdmPromise> promise) {
45 uint32_t promise_id = cdm_promise_adapter_.SavePromise(promise.Pass()); 51 uint32_t promise_id = cdm_promise_adapter_.SavePromise(promise.Pass());
46 manager_->SetServerCertificate(cdm_id_, promise_id, certificate); 52 manager_->SetServerCertificate(cdm_id_, promise_id, certificate);
47 } 53 }
48 54
49 void ProxyMediaKeys::CreateSessionAndGenerateRequest( 55 void ProxyMediaKeys::CreateSessionAndGenerateRequest(
50 SessionType session_type, 56 SessionType session_type,
51 media::EmeInitDataType init_data_type, 57 media::EmeInitDataType init_data_type,
(...skipping 134 matching lines...) Expand 10 before | Expand all | Expand 10 after
186 const media::SessionExpirationUpdateCB& session_expiration_update_cb) 192 const media::SessionExpirationUpdateCB& session_expiration_update_cb)
187 : manager_(manager), 193 : manager_(manager),
188 session_message_cb_(session_message_cb), 194 session_message_cb_(session_message_cb),
189 session_closed_cb_(session_closed_cb), 195 session_closed_cb_(session_closed_cb),
190 legacy_session_error_cb_(legacy_session_error_cb), 196 legacy_session_error_cb_(legacy_session_error_cb),
191 session_keys_change_cb_(session_keys_change_cb), 197 session_keys_change_cb_(session_keys_change_cb),
192 session_expiration_update_cb_(session_expiration_update_cb) { 198 session_expiration_update_cb_(session_expiration_update_cb) {
193 cdm_id_ = manager->RegisterMediaKeys(this); 199 cdm_id_ = manager->RegisterMediaKeys(this);
194 } 200 }
195 201
196 void ProxyMediaKeys::InitializeCdm(const std::string& key_system,
197 const GURL& security_origin) {
198 manager_->InitializeCdm(cdm_id_, this, key_system, security_origin);
199 }
200
201 } // namespace content 202 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698