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

Unified Diff: media/mojo/services/mojo_cdm.cc

Issue 763883006: Add Mojo CDM Service. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Add more comments. Created 6 years 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 side-by-side diff with in-line comments
Download patch
Index: media/mojo/services/mojo_cdm.cc
diff --git a/media/mojo/services/mojo_cdm.cc b/media/mojo/services/mojo_cdm.cc
new file mode 100644
index 0000000000000000000000000000000000000000..e8d99d56ce932f15f5fc9631ae8a4aa2b6e87012
--- /dev/null
+++ b/media/mojo/services/mojo_cdm.cc
@@ -0,0 +1,198 @@
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "media/mojo/services/mojo_cdm.h"
+
+#include "base/bind.h"
+#include "base/bind_helpers.h"
+#include "base/callback_helpers.h"
+#include "base/location.h"
+#include "media/base/bind_to_current_loop.h"
+#include "media/base/cdm_promise.h"
+#include "mojo/public/cpp/application/connect.h"
+#include "mojo/public/cpp/bindings/interface_impl.h"
+#include "mojo/public/interfaces/application/service_provider.mojom.h"
+#include "url/gurl.h"
+
+namespace media {
+
+static mojo::Array<uint8_t> CreateMojoArray(const uint8* data, int length) {
+ DCHECK(data);
+ DCHECK_GT(length, 0);
+ std::vector<uint8> vector(data, data + length);
+ mojo::Array<uint8_t> array;
+ array.Swap(&vector);
+ return array.Pass();
+}
+
+template <typename PromiseType>
+static void RejectPromise(scoped_ptr<PromiseType> promise,
+ mojo::CdmPromiseResultPtr result) {
+ promise->reject(static_cast<MediaKeys::Exception>(result->exception_code),
+ result->system_code, result->error_message);
+}
+
+MojoCdm::MojoCdm(mojo::ServiceProvider* media_renderer_provider,
+ const SessionMessageCB& session_message_cb,
+ const SessionReadyCB& session_ready_cb,
+ const SessionClosedCB& session_closed_cb,
+ const SessionErrorCB& session_error_cb,
+ const SessionKeysChangeCB& session_keys_change_cb,
+ const SessionExpirationUpdateCB& session_expiration_update_cb)
+ : 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),
+ weak_factory_(this) {
+ DVLOG(1) << __FUNCTION__;
+ DCHECK(media_renderer_provider);
+ mojo::ConnectToService(media_renderer_provider, &mojo_cdm_ptr_);
+ mojo_cdm_ptr_.set_client(this);
+}
+
+MojoCdm::~MojoCdm() {
+ DVLOG(1) << __FUNCTION__;
+ // Connection to |remote_media_renderer_| will error-out here.
+}
+
+void MojoCdm::SetServerCertificate(const uint8* certificate_data,
+ int certificate_data_length,
+ scoped_ptr<SimpleCdmPromise> promise) {
+ mojo_cdm_ptr_->SetServerCertificate(
+ CreateMojoArray(certificate_data, certificate_data_length),
+ base::Bind(&MojoCdm::OnResponse, weak_factory_.GetWeakPtr(),
+ base::Passed(&promise)));
+}
+
+void MojoCdm::CreateSession(const std::string& init_data_type,
+ const uint8* init_data,
+ int init_data_length,
+ SessionType session_type,
+ scoped_ptr<NewSessionCdmPromise> promise) {
+ mojo_cdm_ptr_->CreateSession(
+ init_data_type,
+ CreateMojoArray(init_data, init_data_length),
+ static_cast<mojo::ContentDecryptionModule::SessionType>(session_type),
+ base::Bind(&MojoCdm::OnNewSession, weak_factory_.GetWeakPtr(),
+ base::Passed(&promise)));
+}
+
+void MojoCdm::LoadSession(const std::string& session_id,
+ scoped_ptr<NewSessionCdmPromise> promise) {
+ mojo_cdm_ptr_->LoadSession(
+ session_id,
+ base::Bind(&MojoCdm::OnNewSession, weak_factory_.GetWeakPtr(),
+ base::Passed(&promise)));
+}
+
+void MojoCdm::UpdateSession(const std::string& session_id,
+ const uint8* response,
+ int response_length,
+ scoped_ptr<SimpleCdmPromise> promise) {
+ mojo_cdm_ptr_->UpdateSession(
+ session_id,
+ CreateMojoArray(response, response_length),
+ base::Bind(&MojoCdm::OnResponse, weak_factory_.GetWeakPtr(),
+ base::Passed(&promise)));
+}
+
+void MojoCdm::CloseSession(const std::string& session_id,
+ scoped_ptr<SimpleCdmPromise> promise) {
+ mojo_cdm_ptr_->CloseSession(
+ session_id,
+ base::Bind(&MojoCdm::OnResponse, weak_factory_.GetWeakPtr(),
+ base::Passed(&promise)));
+}
+
+void MojoCdm::RemoveSession(const std::string& session_id,
+ scoped_ptr<SimpleCdmPromise> promise) {
+ mojo_cdm_ptr_->RemoveSession(
+ session_id,
+ base::Bind(&MojoCdm::OnResponse, weak_factory_.GetWeakPtr(),
+ base::Passed(&promise)));
+}
+
+void MojoCdm::GetUsableKeyIds(const std::string& session_id,
+ scoped_ptr<KeyIdsPromise> promise) {
+ mojo_cdm_ptr_->GetUsableKeyIds(
+ session_id,
+ base::Bind(&MojoCdm::OnKeyIds, weak_factory_.GetWeakPtr(),
+ base::Passed(&promise)));
+}
+
+CdmContext* MojoCdm::GetCdmContext() {
+ NOTIMPLEMENTED();
+ return nullptr;
+}
+
+void MojoCdm::OnSessionMessage(const mojo::String& session_id,
+ mojo::Array<uint8_t> message,
+ const mojo::String& destination_url) {
+ GURL verified_gurl = GURL(destination_url);
+ if (!verified_gurl.is_valid() && !verified_gurl.is_empty()) {
+ DLOG(WARNING) << "SessionMessage destination_url is invalid : "
+ << verified_gurl.possibly_invalid_spec();
+ verified_gurl = GURL::EmptyGURL(); // Replace invalid destination_url.
+ }
+
+ session_message_cb_.Run(session_id, message.storage(), verified_gurl);
+}
+
+void MojoCdm::OnSessionReady(const mojo::String& session_id) {
+ session_ready_cb_.Run(session_id);
+}
+
+void MojoCdm::OnSessionClosed(const mojo::String& session_id) {
+ session_closed_cb_.Run(session_id);
+}
+
+void MojoCdm::OnSessionError(const mojo::String& session_id,
+ mojo::CdmException exception_code,
+ uint32_t system_code,
+ const mojo::String& error_message) {
+ session_error_cb_.Run(session_id,
+ static_cast<MediaKeys::Exception>(exception_code),
+ system_code, error_message);
+}
+
+void MojoCdm::OnSessionKeysChange(const mojo::String& session_id,
+ bool has_additional_usable_key) {
+ session_keys_change_cb_.Run(session_id, has_additional_usable_key);
+}
+
+void MojoCdm::OnSessionExpirationUpdate(const mojo::String& session_id,
+ int64_t new_expiry_time_usec) {
+ session_expiration_update_cb_.Run(
+ session_id, base::Time::FromInternalValue(new_expiry_time_usec));
+}
+
+void MojoCdm::OnResponse(scoped_ptr<SimpleCdmPromise> promise,
+ mojo::CdmPromiseResultPtr result) {
+ if (result->success)
+ promise->resolve();
+ else
+ RejectPromise(promise.Pass(), result.Pass());
+}
+
+void MojoCdm::OnNewSession(scoped_ptr<NewSessionCdmPromise> promise,
+ mojo::CdmPromiseResultPtr result,
+ mojo::String session_id) {
+ if (result->success)
+ promise->resolve(session_id);
+ else
+ RejectPromise(promise.Pass(), result.Pass());
+}
+
+void MojoCdm::OnKeyIds(scoped_ptr<KeyIdsPromise> promise,
+ mojo::CdmPromiseResultPtr result,
+ mojo::Array<mojo::Array<uint8_t>> key_ids) {
+ if (result->success)
+ promise->resolve(key_ids.To<std::vector<std::vector<uint8>>>());
+ else
+ RejectPromise(promise.Pass(), result.Pass());
+}
+
+} // namespace media

Powered by Google App Engine
This is Rietveld 408576698