OLD | NEW |
---|---|
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 Loading... | |
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 |
OLD | NEW |