summaryrefslogtreecommitdiffstats
path: root/chromecast/media
diff options
context:
space:
mode:
authorgunsch <gunsch@chromium.org>2015-02-02 12:05:47 -0800
committerCommit bot <commit-bot@chromium.org>2015-02-02 20:06:41 +0000
commit5857e9ed6883cd72c913aa180a5b01e543d72056 (patch)
treed3b8974ae6546db277eadcf80d42b399519909a7 /chromecast/media
parent4973f5bd100f56946f26a2547ecd242f0ca06ce3 (diff)
downloadchromium_src-5857e9ed6883cd72c913aa180a5b01e543d72056.zip
chromium_src-5857e9ed6883cd72c913aa180a5b01e543d72056.tar.gz
chromium_src-5857e9ed6883cd72c913aa180a5b01e543d72056.tar.bz2
Chromecast: updates BrowserCdmCast to handle new BrowserCdm API.
R=lcwu@chromium.org BUG=451482 Review URL: https://codereview.chromium.org/874663002 Cr-Commit-Position: refs/heads/master@{#314178}
Diffstat (limited to 'chromecast/media')
-rw-r--r--chromecast/media/cdm/browser_cdm_cast.cc46
-rw-r--r--chromecast/media/cdm/browser_cdm_cast.h22
2 files changed, 65 insertions, 3 deletions
diff --git a/chromecast/media/cdm/browser_cdm_cast.cc b/chromecast/media/cdm/browser_cdm_cast.cc
index bde43a4..c9fbee7 100644
--- a/chromecast/media/cdm/browser_cdm_cast.cc
+++ b/chromecast/media/cdm/browser_cdm_cast.cc
@@ -4,6 +4,8 @@
#include "chromecast/media/cdm/browser_cdm_cast.h"
+#include "media/base/cdm_key_information.h"
+
namespace chromecast {
namespace media {
@@ -14,6 +16,19 @@ BrowserCdmCast::~BrowserCdmCast() {
player_tracker_.NotifyCdmUnset();
}
+void BrowserCdmCast::SetCallbacks(
+ const ::media::SessionMessageCB& session_message_cb,
+ const ::media::SessionClosedCB& session_closed_cb,
+ const ::media::SessionErrorCB& session_error_cb,
+ const ::media::SessionKeysChangeCB& session_keys_change_cb,
+ const ::media::SessionExpirationUpdateCB& session_expiration_update_cb) {
+ session_message_cb_ = session_message_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;
+}
+
int BrowserCdmCast::RegisterPlayer(const base::Closure& new_key_cb,
const base::Closure& cdm_unset_cb) {
return player_tracker_.RegisterPlayer(new_key_cb, cdm_unset_cb);
@@ -23,7 +38,36 @@ void BrowserCdmCast::UnregisterPlayer(int registration_id) {
player_tracker_.UnregisterPlayer(registration_id);
}
-void BrowserCdmCast::NotifyKeyAdded() {
+void BrowserCdmCast::OnSessionMessage(const std::string& web_session_id,
+ const std::vector<uint8>& message,
+ const GURL& destination_url) {
+ // Note: Message type is not supported in Chromecast. Do our best guess here.
+ ::media::MediaKeys::MessageType message_type =
+ destination_url.is_empty() ? ::media::MediaKeys::LICENSE_REQUEST
+ : ::media::MediaKeys::LICENSE_RENEWAL;
+ session_message_cb_.Run(web_session_id,
+ message_type,
+ message,
+ destination_url);
+}
+
+void BrowserCdmCast::OnSessionClosed(const std::string& web_session_id) {
+ session_closed_cb_.Run(web_session_id);
+}
+
+void BrowserCdmCast::OnSessionKeysChange(
+ const std::string& web_session_id,
+ const ::media::KeyIdAndKeyPairs& keys) {
+ ::media::CdmKeysInfo cdm_keys_info;
+ for (const std::pair<std::string, std::string>& key : keys) {
+ scoped_ptr< ::media::CdmKeyInformation> cdm_key_information(
+ new ::media::CdmKeyInformation());
+ cdm_key_information->key_id.assign(key.first.begin(), key.first.end());
+ cdm_keys_info.push_back(cdm_key_information.release());
+ }
+ session_keys_change_cb_.Run(web_session_id, true, cdm_keys_info.Pass());
+
+ // Notify listeners of a new key.
player_tracker_.NotifyNewKey();
}
diff --git a/chromecast/media/cdm/browser_cdm_cast.h b/chromecast/media/cdm/browser_cdm_cast.h
index 6a51ddc..66c1794 100644
--- a/chromecast/media/cdm/browser_cdm_cast.h
+++ b/chromecast/media/cdm/browser_cdm_cast.h
@@ -14,6 +14,7 @@
#include "base/macros.h"
#include "base/memory/ref_counted.h"
#include "media/base/browser_cdm.h"
+#include "media/cdm/json_web_key.h"
#include "media/cdm/player_tracker_impl.h"
namespace chromecast {
@@ -32,6 +33,13 @@ class BrowserCdmCast : public ::media::BrowserCdm {
BrowserCdmCast();
~BrowserCdmCast() override;
+ void SetCallbacks(
+ const ::media::SessionMessageCB& session_message_cb,
+ const ::media::SessionClosedCB& session_closed_cb,
+ const ::media::SessionErrorCB& session_error_cb,
+ const ::media::SessionKeysChangeCB& session_keys_change_cb,
+ const ::media::SessionExpirationUpdateCB& session_expiration_update_cb);
+
// PlayerTracker implementation.
int RegisterPlayer(const base::Closure& new_key_cb,
const base::Closure& cdm_unset_cb) override;
@@ -44,10 +52,20 @@ class BrowserCdmCast : public ::media::BrowserCdm {
const std::string& key_id) const = 0;
protected:
- // Notifies all listeners a new key was added.
- void NotifyKeyAdded();
+ void OnSessionMessage(const std::string& web_session_id,
+ const std::vector<uint8>& message,
+ const GURL& destination_url);
+ void OnSessionClosed(const std::string& web_session_id);
+ void OnSessionKeysChange(const std::string& web_session_id,
+ const ::media::KeyIdAndKeyPairs& keys);
private:
+ ::media::SessionMessageCB session_message_cb_;
+ ::media::SessionClosedCB session_closed_cb_;
+ ::media::SessionErrorCB session_error_cb_;
+ ::media::SessionKeysChangeCB session_keys_change_cb_;
+ ::media::SessionExpirationUpdateCB session_expiration_update_cb_;
+
::media::PlayerTrackerImpl player_tracker_;
DISALLOW_COPY_AND_ASSIGN(BrowserCdmCast);