// Copyright 2017 The Chromium Authors
// 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_media_drm_storage.h"
#include <optional>
#include <string>
#include <utility>
#include "base/functional/bind.h"
#include "base/functional/callback_helpers.h"
#include "base/unguessable_token.h"
#include "media/mojo/mojom/media_drm_storage.mojom.h"
#include "mojo/public/cpp/bindings/callback_helpers.h"
namespace media {
// TODO(xhwang): When connection error happens, callbacks might be dropped and
// never run. Handle connection error to make sure callbacks will always run.
MojoMediaDrmStorage::MojoMediaDrmStorage(
mojo::PendingRemote<mojom::MediaDrmStorage> media_drm_storage)
: media_drm_storage_(std::move(media_drm_storage)) {
DVLOG(1) << __func__;
}
MojoMediaDrmStorage::~MojoMediaDrmStorage() {}
void MojoMediaDrmStorage::Initialize(InitCB init_cb) {
DVLOG(1) << __func__;
media_drm_storage_->Initialize(mojo::WrapCallbackWithDefaultInvokeIfNotRun(
std::move(init_cb), false, std::nullopt));
}
void MojoMediaDrmStorage::OnProvisioned(ResultCB result_cb) {
DVLOG(1) << __func__;
media_drm_storage_->OnProvisioned(
mojo::WrapCallbackWithDefaultInvokeIfNotRun(std::move(result_cb), false));
}
void MojoMediaDrmStorage::SavePersistentSession(const std::string& session_id,
const SessionData& session_data,
ResultCB result_cb) {
DVLOG(1) << __func__;
media_drm_storage_->SavePersistentSession(
session_id,
mojom::SessionData::New(session_data.key_set_id, session_data.mime_type,
session_data.key_type),
mojo::WrapCallbackWithDefaultInvokeIfNotRun(std::move(result_cb), false));
}
void MojoMediaDrmStorage::LoadPersistentSession(
const std::string& session_id,
LoadPersistentSessionCB load_persistent_session_cb) {
DVLOG(1) << __func__;
media_drm_storage_->LoadPersistentSession(
session_id,
mojo::WrapCallbackWithDefaultInvokeIfNotRun(
base::BindOnce(&MojoMediaDrmStorage::OnPersistentSessionLoaded,
weak_factory_.GetWeakPtr(),
std::move(load_persistent_session_cb)),
nullptr));
}
void MojoMediaDrmStorage::RemovePersistentSession(const std::string& session_id,
ResultCB result_cb) {
DVLOG(1) << __func__;
media_drm_storage_->RemovePersistentSession(
session_id,
mojo::WrapCallbackWithDefaultInvokeIfNotRun(std::move(result_cb), false));
}
void MojoMediaDrmStorage::OnPersistentSessionLoaded(
LoadPersistentSessionCB load_persistent_session_cb,
mojom::SessionDataPtr session_data) {
DVLOG(1) << __func__ << ": success = " << !!session_data;
std::move(load_persistent_session_cb)
.Run(session_data
? std::make_unique<SessionData>(
std::move(session_data->key_set_id),
std::move(session_data->mime_type), session_data->key_type)
: nullptr);
}
base::WeakPtr<MediaDrmStorage> MojoMediaDrmStorage::AsWeakPtr() {
return weak_factory_.GetWeakPtr();
}
} // namespace media