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

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

Issue 193523002: Encrypted Media: Implement IPC based SetCdm(). (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: comments addressed Created 6 years, 9 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 | Annotate | Revision Log
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/content_decryption_module_factory.h" 5 #include "content/renderer/media/crypto/content_decryption_module_factory.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "content/renderer/media/crypto/key_systems.h" 8 #include "content/renderer/media/crypto/key_systems.h"
9 #include "media/cdm/aes_decryptor.h" 9 #include "media/cdm/aes_decryptor.h"
10 10
(...skipping 10 matching lines...) Expand all
21 #endif // defined(ENABLE_PEPPER_CDMS) 21 #endif // defined(ENABLE_PEPPER_CDMS)
22 22
23 namespace content { 23 namespace content {
24 24
25 scoped_ptr<media::MediaKeys> ContentDecryptionModuleFactory::Create( 25 scoped_ptr<media::MediaKeys> ContentDecryptionModuleFactory::Create(
26 const std::string& key_system, 26 const std::string& key_system,
27 #if defined(ENABLE_PEPPER_CDMS) 27 #if defined(ENABLE_PEPPER_CDMS)
28 const CreatePepperCdmCB& create_pepper_cdm_cb, 28 const CreatePepperCdmCB& create_pepper_cdm_cb,
29 #elif defined(OS_ANDROID) 29 #elif defined(OS_ANDROID)
30 RendererMediaPlayerManager* manager, 30 RendererMediaPlayerManager* manager,
31 int cdm_id,
32 const GURL& frame_url, 31 const GURL& frame_url,
32 int* cdm_id,
33 #endif // defined(ENABLE_PEPPER_CDMS) 33 #endif // defined(ENABLE_PEPPER_CDMS)
34 const media::SessionCreatedCB& session_created_cb, 34 const media::SessionCreatedCB& session_created_cb,
35 const media::SessionMessageCB& session_message_cb, 35 const media::SessionMessageCB& session_message_cb,
36 const media::SessionReadyCB& session_ready_cb, 36 const media::SessionReadyCB& session_ready_cb,
37 const media::SessionClosedCB& session_closed_cb, 37 const media::SessionClosedCB& session_closed_cb,
38 const media::SessionErrorCB& session_error_cb) { 38 const media::SessionErrorCB& session_error_cb) {
39 #if defined(OS_ANDROID)
40 DCHECK_EQ(*cdm_id, RendererMediaPlayerManager::kInvalidCdmId);
ddorwin 2014/03/25 23:03:59 You could move this to 68 and avoid this extra ifd
xhwang 2014/03/26 06:02:04 Done.
41 #endif // defined(OS_ANDROID)
39 if (CanUseAesDecryptor(key_system)) { 42 if (CanUseAesDecryptor(key_system)) {
40 return scoped_ptr<media::MediaKeys>( 43 return scoped_ptr<media::MediaKeys>(
41 new media::AesDecryptor(session_created_cb, 44 new media::AesDecryptor(session_created_cb,
42 session_message_cb, 45 session_message_cb,
43 session_ready_cb, 46 session_ready_cb,
44 session_closed_cb, 47 session_closed_cb,
45 session_error_cb)); 48 session_error_cb));
46 } 49 }
47
48 #if defined(ENABLE_PEPPER_CDMS) 50 #if defined(ENABLE_PEPPER_CDMS)
49 return scoped_ptr<media::MediaKeys>( 51 return scoped_ptr<media::MediaKeys>(
50 PpapiDecryptor::Create(key_system, 52 PpapiDecryptor::Create(key_system,
51 create_pepper_cdm_cb, 53 create_pepper_cdm_cb,
52 session_created_cb, 54 session_created_cb,
53 session_message_cb, 55 session_message_cb,
54 session_ready_cb, 56 session_ready_cb,
55 session_closed_cb, 57 session_closed_cb,
56 session_error_cb)); 58 session_error_cb));
57 #elif defined(OS_ANDROID) 59 #elif defined(OS_ANDROID)
58 scoped_ptr<ProxyMediaKeys> proxy_media_keys( 60 scoped_ptr<ProxyMediaKeys> proxy_media_keys(
59 new ProxyMediaKeys(manager, 61 new ProxyMediaKeys(manager,
60 cdm_id,
61 session_created_cb, 62 session_created_cb,
62 session_message_cb, 63 session_message_cb,
63 session_ready_cb, 64 session_ready_cb,
64 session_closed_cb, 65 session_closed_cb,
65 session_error_cb)); 66 session_error_cb));
66 proxy_media_keys->InitializeCdm(key_system, frame_url); 67 proxy_media_keys->InitializeCdm(key_system, frame_url);
68 *cdm_id = proxy_media_keys->GetCdmId();
67 return proxy_media_keys.PassAs<media::MediaKeys>(); 69 return proxy_media_keys.PassAs<media::MediaKeys>();
68 #else 70 #else
69 return scoped_ptr<media::MediaKeys>(); 71 return scoped_ptr<media::MediaKeys>();
70 #endif // defined(ENABLE_PEPPER_CDMS) 72 #endif // defined(ENABLE_PEPPER_CDMS)
71 } 73 }
72 74
73 } // namespace content 75 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698