Index: chromecast/browser/media/cast_browser_cdm_factory.cc |
diff --git a/chromecast/browser/media/cast_browser_cdm_factory.cc b/chromecast/browser/media/cast_browser_cdm_factory.cc |
index e93927b0f488c4e1d8641ac0ad7703ced9dcf571..c657a691ddfe159fff3081b444ee1d1e546a20f5 100644 |
--- a/chromecast/browser/media/cast_browser_cdm_factory.cc |
+++ b/chromecast/browser/media/cast_browser_cdm_factory.cc |
@@ -10,51 +10,60 @@ |
#include "chromecast/media/base/media_message_loop.h" |
#include "chromecast/media/cdm/browser_cdm_cast.h" |
#include "media/base/bind_to_current_loop.h" |
+#include "media/base/cdm_config.h" |
#include "media/base/cdm_key_information.h" |
namespace chromecast { |
namespace media { |
-scoped_refptr<::media::MediaKeys> CastBrowserCdmFactory::CreateBrowserCdm( |
- const std::string& key_system_name, |
- bool use_hw_secure_codecs, |
+void CastBrowserCdmFactory::Create( |
+ const std::string& key_system, |
+ const GURL& security_origin, |
+ const ::media::CdmConfig& cdm_config, |
const ::media::SessionMessageCB& session_message_cb, |
const ::media::SessionClosedCB& session_closed_cb, |
const ::media::LegacySessionErrorCB& legacy_session_error_cb, |
const ::media::SessionKeysChangeCB& session_keys_change_cb, |
- const ::media::SessionExpirationUpdateCB& session_expiration_update_cb) { |
- DCHECK(!use_hw_secure_codecs) |
+ const ::media::SessionExpirationUpdateCB& session_expiration_update_cb, |
+ const ::media::CdmCreatedCB& cdm_created_cb) { |
+ // Bound |cdm_created_cb| so we always fire it asynchronously. |
+ ::media::CdmCreatedCB bound_cdm_created_cb = |
+ ::media::BindToCurrentLoop(cdm_created_cb); |
+ |
+ DCHECK(!cdm_config.use_hw_secure_codecs) |
<< "Chromecast does not use |use_hw_secure_codecs|"; |
- CastKeySystem key_system(GetKeySystemByName(key_system_name)); |
+ CastKeySystem cast_key_system(GetKeySystemByName(key_system)); |
scoped_refptr<chromecast::media::BrowserCdmCast> browser_cdm; |
- if (key_system == chromecast::media::KEY_SYSTEM_CLEAR_KEY) { |
+ if (cast_key_system == chromecast::media::KEY_SYSTEM_CLEAR_KEY) { |
// TODO(gunsch): handle ClearKey decryption. See crbug.com/441957 |
} else { |
- browser_cdm = CreatePlatformBrowserCdm(key_system); |
+ browser_cdm = CreatePlatformBrowserCdm(cast_key_system); |
} |
- if (browser_cdm) { |
- MediaMessageLoop::GetTaskRunner()->PostTask( |
- FROM_HERE, |
- base::Bind(&BrowserCdmCast::Initialize, |
- base::Unretained(browser_cdm.get()), |
- ::media::BindToCurrentLoop(session_message_cb), |
- ::media::BindToCurrentLoop(session_closed_cb), |
- ::media::BindToCurrentLoop(legacy_session_error_cb), |
- ::media::BindToCurrentLoop(session_keys_change_cb), |
- ::media::BindToCurrentLoop(session_expiration_update_cb))); |
- return scoped_refptr<::media::MediaKeys>( |
- new BrowserCdmCastUi(browser_cdm, MediaMessageLoop::GetTaskRunner())); |
+ if (!browser_cdm) { |
+ LOG(INFO) << "No matching key system found: " << cast_key_system; |
+ bound_cdm_created_cb.Run(nullptr, "No matching key system found."); |
+ return; |
} |
- LOG(INFO) << "No matching key system found."; |
- return nullptr; |
+ MediaMessageLoop::GetTaskRunner()->PostTask( |
+ FROM_HERE, |
+ base::Bind(&BrowserCdmCast::Initialize, |
+ base::Unretained(browser_cdm.get()), |
+ ::media::BindToCurrentLoop(session_message_cb), |
+ ::media::BindToCurrentLoop(session_closed_cb), |
+ ::media::BindToCurrentLoop(legacy_session_error_cb), |
+ ::media::BindToCurrentLoop(session_keys_change_cb), |
+ ::media::BindToCurrentLoop(session_expiration_update_cb))); |
+ |
+ bound_cdm_created_cb.Run( |
+ new BrowserCdmCastUi(browser_cdm, MediaMessageLoop::GetTaskRunner()), ""); |
} |
scoped_refptr<BrowserCdmCast> CastBrowserCdmFactory::CreatePlatformBrowserCdm( |
- const CastKeySystem& key_system) { |
+ const CastKeySystem& cast_key_system) { |
return nullptr; |
} |