blob: 0399beb1d7da4928e5c20a8fe77adacf2b926508 [file] [log] [blame]
// Copyright (c) 2013 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.
#ifndef MEDIA_BASE_ANDROID_MEDIA_DRM_BRIDGE_H_
#define MEDIA_BASE_ANDROID_MEDIA_DRM_BRIDGE_H_
#include <jni.h>
#include <string>
#include <vector>
#include "base/android/scoped_java_ref.h"
#include "base/callback.h"
#include "base/memory/scoped_ptr.h"
#include "media/base/media_export.h"
#include "media/base/media_keys.h"
#include "url/gurl.h"
class GURL;
namespace media {
class MediaPlayerManager;
// This class provides DRM services for android EME implementation.
// TODO(qinmin): implement all the functions in this class.
class MEDIA_EXPORT MediaDrmBridge : public MediaKeys {
public:
enum SecurityLevel {
SECURITY_LEVEL_NONE = 0,
SECURITY_LEVEL_1 = 1,
SECURITY_LEVEL_3 = 3,
};
typedef base::Callback<void(bool)> ResetCredentialsCB;
virtual ~MediaDrmBridge();
// Returns a MediaDrmBridge instance if |scheme_uuid| is supported, or a NULL
// pointer otherwise.
static scoped_ptr<MediaDrmBridge> Create(
int media_keys_id,
const std::vector<uint8>& scheme_uuid,
const GURL& frame_url,
const std::string& security_level,
MediaPlayerManager* manager);
// Checks whether MediaDRM is available.
static bool IsAvailable();
static bool IsSecurityLevelSupported(const std::vector<uint8>& scheme_uuid,
const std::string& security_level);
static bool IsCryptoSchemeSupported(const std::vector<uint8>& scheme_uuid,
const std::string& container_mime_type);
static bool IsSecureDecoderRequired(const std::string& security_level_str);
static bool RegisterMediaDrmBridge(JNIEnv* env);
// MediaKeys implementations.
virtual bool GenerateKeyRequest(const std::string& type,
const uint8* init_data,
int init_data_length) OVERRIDE;
virtual void AddKey(const uint8* key, int key_length,
const uint8* init_data, int init_data_length,
const std::string& session_id) OVERRIDE;
virtual void CancelKeyRequest(const std::string& session_id) OVERRIDE;
// Returns a MediaCrypto object if it's already created. Returns a null object
// otherwise.
base::android::ScopedJavaLocalRef<jobject> GetMediaCrypto();
// Sets callback which will be called when MediaCrypto is ready.
// If |closure| is null, previously set callback will be cleared.
void SetMediaCryptoReadyCB(const base::Closure& closure);
// Called after a MediaCrypto object is created.
void OnMediaCryptoReady(JNIEnv* env, jobject);
// Called after we got the response for GenerateKeyRequest().
void OnKeyMessage(JNIEnv* env, jobject, jstring j_session_id,
jbyteArray message, jstring destination_url);
// Called when key is added.
void OnKeyAdded(JNIEnv* env, jobject, jstring j_session_id);
// Called when error happens.
void OnKeyError(JNIEnv* env, jobject, jstring j_session_id);
// Reset the device credentials.
void ResetDeviceCredentials(const ResetCredentialsCB& callback);
// Called by the java object when credential reset is completed.
void OnResetDeviceCredentialsCompleted(JNIEnv* env, jobject, bool success);
// Helper function to determine whether a protected surface is needed for the
// video playback.
bool IsProtectedSurfaceRequired();
int media_keys_id() const { return media_keys_id_; }
GURL frame_url() const { return frame_url_; }
static void set_can_use_media_drm(bool can_use_media_drm) {
can_use_media_drm_ = can_use_media_drm;
}
private:
static bool IsSecureDecoderRequired(SecurityLevel security_level);
static bool can_use_media_drm_;
MediaDrmBridge(int media_keys_id,
const std::vector<uint8>& scheme_uuid,
const GURL& frame_url,
const std::string& security_level,
MediaPlayerManager* manager);
// Get the security level of the media.
SecurityLevel GetSecurityLevel();
// ID of the MediaKeys object.
int media_keys_id_;
// UUID of the key system.
std::vector<uint8> scheme_uuid_;
// media stream's frame URL.
const GURL frame_url_;
// Java MediaDrm instance.
base::android::ScopedJavaGlobalRef<jobject> j_media_drm_;
// Non-owned pointer.
MediaPlayerManager* manager_;
base::Closure media_crypto_ready_cb_;
ResetCredentialsCB reset_credentials_cb_;
DISALLOW_COPY_AND_ASSIGN(MediaDrmBridge);
};
} // namespace media
#endif // MEDIA_BASE_ANDROID_MEDIA_DRM_BRIDGE_H_