diff options
author | jrummell <jrummell@chromium.org> | 2014-09-25 17:10:38 -0700 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2014-09-26 00:10:48 +0000 |
commit | 80428d2eb359a2448c67ae45ece3ea5dbc2f8cef (patch) | |
tree | 8336dc22e94a678c64611314f66f7dee6488ab34 /content/renderer/media/crypto/ppapi_decryptor.cc | |
parent | 422b434274e09a95ca778dd29890d51ab2c15ae5 (diff) | |
download | chromium_src-80428d2eb359a2448c67ae45ece3ea5dbc2f8cef.zip chromium_src-80428d2eb359a2448c67ae45ece3ea5dbc2f8cef.tar.gz chromium_src-80428d2eb359a2448c67ae45ece3ea5dbc2f8cef.tar.bz2 |
Update MediaKeys interface for EME
To support CDM_6, make the following changes:
- add SetServerCertificate
- add GetUsableKeyIds
- rename ReleaseSession to CloseSession
- add RemoveSession
- add SessionKeysChange event
- add SessionExpirationChange event
This gets the new functionality up to the blink boundary. Changes to
use these new interfaces in blink in a future CL.
For backwards compatibility with existing prefixed EME code, calls
to CancelKeyRequest() call RemoveSession() instead of CloseSession().
BUG=358271,417481
TEST=existing EME tests still pass + manual testing
Review URL: https://codereview.chromium.org/555223004
Cr-Commit-Position: refs/heads/master@{#296838}
Diffstat (limited to 'content/renderer/media/crypto/ppapi_decryptor.cc')
-rw-r--r-- | content/renderer/media/crypto/ppapi_decryptor.cc | 87 |
1 files changed, 82 insertions, 5 deletions
diff --git a/content/renderer/media/crypto/ppapi_decryptor.cc b/content/renderer/media/crypto/ppapi_decryptor.cc index 8b88362..0a6c14c 100644 --- a/content/renderer/media/crypto/ppapi_decryptor.cc +++ b/content/renderer/media/crypto/ppapi_decryptor.cc @@ -93,7 +93,9 @@ scoped_ptr<PpapiDecryptor> PpapiDecryptor::Create( const media::SessionMessageCB& session_message_cb, const media::SessionReadyCB& session_ready_cb, const media::SessionClosedCB& session_closed_cb, - const media::SessionErrorCB& session_error_cb) { + const media::SessionErrorCB& session_error_cb, + const media::SessionKeysChangeCB& session_keys_change_cb, + const media::SessionExpirationUpdateCB& session_expiration_update_cb) { std::string plugin_type = GetPepperType(key_system); DCHECK(!plugin_type.empty()); scoped_ptr<PepperCdmWrapper> pepper_cdm_wrapper = @@ -109,7 +111,9 @@ scoped_ptr<PpapiDecryptor> PpapiDecryptor::Create( session_message_cb, session_ready_cb, session_closed_cb, - session_error_cb)); + session_error_cb, + session_keys_change_cb, + session_expiration_update_cb)); } PpapiDecryptor::PpapiDecryptor( @@ -118,12 +122,16 @@ PpapiDecryptor::PpapiDecryptor( const media::SessionMessageCB& session_message_cb, const media::SessionReadyCB& session_ready_cb, const media::SessionClosedCB& session_closed_cb, - const media::SessionErrorCB& session_error_cb) + const media::SessionErrorCB& session_error_cb, + const media::SessionKeysChangeCB& session_keys_change_cb, + const media::SessionExpirationUpdateCB& session_expiration_update_cb) : pepper_cdm_wrapper_(pepper_cdm_wrapper.Pass()), session_message_cb_(session_message_cb), session_ready_cb_(session_ready_cb), session_closed_cb_(session_closed_cb), session_error_cb_(session_error_cb), + session_keys_change_cb_(session_keys_change_cb), + session_expiration_update_cb_(session_expiration_update_cb), render_loop_proxy_(base::MessageLoopProxy::current()), weak_ptr_factory_(this) { DCHECK(pepper_cdm_wrapper_.get()); @@ -131,6 +139,8 @@ PpapiDecryptor::PpapiDecryptor( DCHECK(!session_ready_cb_.is_null()); DCHECK(!session_closed_cb_.is_null()); DCHECK(!session_error_cb_.is_null()); + DCHECK(!session_keys_change_cb.is_null()); + DCHECK(!session_expiration_update_cb.is_null()); base::WeakPtr<PpapiDecryptor> weak_this = weak_ptr_factory_.GetWeakPtr(); CdmDelegate()->Initialize( @@ -139,6 +149,8 @@ PpapiDecryptor::PpapiDecryptor( base::Bind(&PpapiDecryptor::OnSessionReady, weak_this), base::Bind(&PpapiDecryptor::OnSessionClosed, weak_this), base::Bind(&PpapiDecryptor::OnSessionError, weak_this), + base::Bind(&PpapiDecryptor::OnSessionKeysChange, weak_this), + base::Bind(&PpapiDecryptor::OnSessionExpirationUpdate, weak_this), base::Bind(&PpapiDecryptor::OnFatalPluginError, weak_this)); } @@ -146,6 +158,22 @@ PpapiDecryptor::~PpapiDecryptor() { pepper_cdm_wrapper_.reset(); } +void PpapiDecryptor::SetServerCertificate( + const uint8* certificate_data, + int certificate_data_length, + scoped_ptr<media::SimpleCdmPromise> promise) { + DVLOG(2) << __FUNCTION__; + DCHECK(render_loop_proxy_->BelongsToCurrentThread()); + + if (!CdmDelegate()) { + promise->reject(INVALID_STATE_ERROR, 0, "CdmDelegate() does not exist."); + return; + } + + CdmDelegate()->SetServerCertificate( + certificate_data, certificate_data_length, promise.Pass()); +} + void PpapiDecryptor::CreateSession( const std::string& init_data_type, const uint8* init_data, @@ -178,6 +206,8 @@ void PpapiDecryptor::LoadSession( return; } + // TODO(jrummell): Intercepting the promise should not be necessary once + // OnSessionKeysChange() is called in all cases. http://crbug.com/413413. scoped_ptr<SessionLoadedPromise> session_loaded_promise( new SessionLoadedPromise(promise.Pass(), base::Bind(&PpapiDecryptor::ResumePlayback, @@ -200,6 +230,8 @@ void PpapiDecryptor::UpdateSession( return; } + // TODO(jrummell): Intercepting the promise should not be necessary once + // OnSessionKeysChange() is called in all cases. http://crbug.com/413413. scoped_ptr<SessionUpdatedPromise> session_updated_promise( new SessionUpdatedPromise(promise.Pass(), base::Bind(&PpapiDecryptor::ResumePlayback, @@ -211,7 +243,19 @@ void PpapiDecryptor::UpdateSession( session_updated_promise.PassAs<media::SimpleCdmPromise>()); } -void PpapiDecryptor::ReleaseSession( +void PpapiDecryptor::CloseSession(const std::string& web_session_id, + scoped_ptr<media::SimpleCdmPromise> promise) { + DCHECK(render_loop_proxy_->BelongsToCurrentThread()); + + if (!CdmDelegate()) { + promise->reject(INVALID_STATE_ERROR, 0, "CdmDelegate() does not exist."); + return; + } + + CdmDelegate()->CloseSession(web_session_id, promise.Pass()); +} + +void PpapiDecryptor::RemoveSession( const std::string& web_session_id, scoped_ptr<media::SimpleCdmPromise> promise) { DCHECK(render_loop_proxy_->BelongsToCurrentThread()); @@ -221,7 +265,19 @@ void PpapiDecryptor::ReleaseSession( return; } - CdmDelegate()->CloseSession(web_session_id, promise.Pass()); + CdmDelegate()->RemoveSession(web_session_id, promise.Pass()); +} + +void PpapiDecryptor::GetUsableKeyIds(const std::string& web_session_id, + scoped_ptr<media::KeyIdsPromise> promise) { + DCHECK(render_loop_proxy_->BelongsToCurrentThread()); + + if (!CdmDelegate()) { + promise->reject(INVALID_STATE_ERROR, 0, "CdmDelegate() does not exist."); + return; + } + + CdmDelegate()->GetUsableKeyIds(web_session_id, promise.Pass()); } media::Decryptor* PpapiDecryptor::GetDecryptor() { @@ -436,9 +492,30 @@ void PpapiDecryptor::OnSessionMessage(const std::string& web_session_id, session_message_cb_.Run(web_session_id, message, destination_url); } +void PpapiDecryptor::OnSessionKeysChange(const std::string& web_session_id, + bool has_additional_usable_key) { + DCHECK(render_loop_proxy_->BelongsToCurrentThread()); + + // TODO(jrummell): Handling resume playback should be done in the media + // player, not in the Decryptors. http://crbug.com/413413. + if (has_additional_usable_key) + ResumePlayback(); + + session_keys_change_cb_.Run(web_session_id, has_additional_usable_key); +} + +void PpapiDecryptor::OnSessionExpirationUpdate( + const std::string& web_session_id, + const base::Time& new_expiry_time) { + DCHECK(render_loop_proxy_->BelongsToCurrentThread()); + session_expiration_update_cb_.Run(web_session_id, new_expiry_time); +} + void PpapiDecryptor::OnSessionReady(const std::string& web_session_id) { DCHECK(render_loop_proxy_->BelongsToCurrentThread()); + // TODO(jrummell): Calling ResumePlayback() here should not be necessary once + // OnSessionKeysChange() is called in all cases. http://crbug.com/413413. ResumePlayback(); session_ready_cb_.Run(web_session_id); } |