Share via


MediaDrm Class

Definition

MediaDrm can be used to obtain keys for decrypting protected media streams, in conjunction with android.media.MediaCrypto.

[Android.Runtime.Register("android/media/MediaDrm", DoNotGenerateAcw=true)]
public sealed class MediaDrm : Java.Lang.Object, IDisposable, Java.Interop.IJavaPeerable, Java.Lang.IAutoCloseable
[<Android.Runtime.Register("android/media/MediaDrm", DoNotGenerateAcw=true)>]
type MediaDrm = class
    inherit Object
    interface IAutoCloseable
    interface IJavaObject
    interface IDisposable
    interface IJavaPeerable
Inheritance
MediaDrm
Attributes
Implements

Remarks

MediaDrm can be used to obtain keys for decrypting protected media streams, in conjunction with android.media.MediaCrypto. The MediaDrm APIs are designed to support the ISO/IEC 23001-7: Common Encryption standard, but may also be used to implement other encryption schemes.

Encrypted content is prepared using an encryption server and stored in a content library. The encrypted content is streamed or downloaded from the content library to client devices via content servers. Licenses to view the content are obtained from a License Server.

<img src="../../../images/mediadrm_overview.png" alt="MediaDrm Overview diagram" border="0" />

Keys are requested from the license server using a key request. The key response is delivered to the client app, which provides the response to the MediaDrm API.

A Provisioning server may be required to distribute device-unique credentials to the devices.

Enforcing requirements related to the number of devices that may play content simultaneously can be performed either through key renewal or using the secure stop methods.

The following sequence diagram shows the interactions between the objects involved while playing back encrypted content:

<img src="../../../images/mediadrm_decryption_sequence.png" alt="MediaDrm Overview diagram" border="0" />

The app first constructs android.media.MediaExtractor and android.media.MediaCodec objects. It accesses the DRM-scheme-identifying UUID, typically from metadata in the content, and uses this UUID to construct an instance of a MediaDrm object that is able to support the DRM scheme required by the content. Crypto schemes are assigned 16 byte UUIDs. The method #isCryptoSchemeSupported can be used to query if a given scheme is supported on the device.

The app calls #openSession to generate a sessionId that will uniquely identify the session in subsequent interactions. The app next uses the MediaDrm object to obtain a key request message and send it to the license server, then provide the server's response to the MediaDrm object.

Once the app has a sessionId, it can construct a MediaCrypto object from the UUID and sessionId. The MediaCrypto object is registered with the MediaCodec in the MediaCodec#configure method to enable the codec to decrypt content.

When the app has constructed android.media.MediaExtractor, android.media.MediaCodec and android.media.MediaCrypto objects, it proceeds to pull samples from the extractor and queue them into the decoder. For encrypted content, the samples returned from the extractor remain encrypted, they are only decrypted when the samples are delivered to the decoder.

MediaDrm methods throw android.media.MediaDrm.MediaDrmStateException when a method is called on a MediaDrm object that has had an unrecoverable failure in the DRM plugin or security hardware. android.media.MediaDrm.MediaDrmStateException extends java.lang.IllegalStateException with the addition of a developer-readable diagnostic information string associated with the exception.

In the event of a mediaserver process crash or restart while a MediaDrm object is active, MediaDrm methods may throw android.media.MediaDrmResetException. To recover, the app must release the MediaDrm object, then create and initialize a new one.

As android.media.MediaDrmResetException and android.media.MediaDrm.MediaDrmStateException both extend java.lang.IllegalStateException, they should be in an earlier catch() block than java.lang.IllegalStateException if handled separately.

"Callbacks"><h3>Callbacks</h3>

Applications should register for informational events in order to be informed of key state updates during playback or streaming. Registration for these events is done via a call to #setOnEventListener. In order to receive the respective callback associated with this listener, applications are required to create MediaDrm objects on a thread with its own Looper running (main UI thread by default has a Looper running).

Java documentation for android.media.MediaDrm.

Portions of this page are modifications based on work created and shared by the Android Open Source Project and used according to terms described in the Creative Commons 2.5 Attribution License.

Constructors

MediaDrm(UUID)

Instantiate a MediaDrm object

Fields

EventKeyExpired

This event type indicates that the licensed usage duration for keys in a session has expired.

EventKeyRequired
Obsolete.

This event type indicates that the app needs to request keys from a license server.

EventProvisionRequired

This event type indicates that the app needs to request a certificate from the provisioning server.

EventSessionReclaimed
Obsolete.

This event indicates that a session opened by the app has been reclaimed by the resource manager.

EventVendorDefined
Obsolete.

This event may indicate some specific vendor-defined condition, see your DRM provider documentation for details

HdcpLevelUnknown
Obsolete.

The DRM plugin did not report an HDCP level, or an error occurred accessing it

HdcpNoDigitalOutput
Obsolete.

No digital output, implicitly secure

HdcpNone
Obsolete.

HDCP is not supported on this device, content is unprotected

HdcpV1
Obsolete.

HDCP version 1.

HdcpV2
Obsolete.

HDCP version 2.

HdcpV21
Obsolete.

HDCP version 2.

HdcpV22
Obsolete.

HDCP version 2.

HdcpV23
Obsolete.

HDCP version 2.

KeyTypeOffline
Obsolete.

This key request type specifies that the keys will be for offline use, they will be saved to the device for use when the device is not connected to a network.

KeyTypeRelease
Obsolete.

This key request type specifies that previously saved offline keys should be released.

KeyTypeStreaming
Obsolete.

This key request type species that the keys will be for online use, they will not be saved to the device for subsequent use when the device is not connected to a network.

OfflineLicenseStateReleased
Obsolete.

Offline license is released, the keys have been marked for release using #getKeyRequest with KEY_TYPE_RELEASE but the key response has not been received.

OfflineLicenseStateUnknown
Obsolete.

Offline license state is unknown, an error occurred while trying to access it.

OfflineLicenseStateUsable
Obsolete.

Offline license is usable, the keys may be used for decryption.

PropertyAlgorithms

String property name: a comma-separated list of cipher and mac algorithms supported by CryptoSession.

PropertyDescription

String property name: describes the DRM plugin

PropertyDeviceUniqueId

Byte array property name: the device unique identifier is established during device provisioning and provides a means of uniquely identifying each device.

PropertyVendor

String property name: identifies the maker of the DRM plugin

PropertyVersion

String property name: identifies the version of the DRM plugin

SecurityLevelHwSecureAll
Obsolete.

DRM key management, crypto operations, decoding of content and all handling of the media (compressed and uncompressed) is handled within a hardware backed trusted execution environment.

SecurityLevelHwSecureCrypto
Obsolete.

DRM key management and crypto operations are performed within a hardware backed trusted execution environment.

SecurityLevelHwSecureDecode
Obsolete.

DRM key management, crypto operations and decoding of content are performed within a hardware backed trusted execution environment.

SecurityLevelSwSecureCrypto
Obsolete.

DRM key management uses software-based whitebox crypto.

SecurityLevelSwSecureDecode
Obsolete.

DRM key management and decoding use software-based whitebox crypto.

SecurityLevelUnknown
Obsolete.

The DRM plugin did not report a security level, or an error occurred accessing it

Properties

Class

Returns the runtime class of this Object.

(Inherited from Object)
ConnectedHdcpLevel

Return the HDCP level negotiated with downstream receivers the device is connected to.

Handle

The handle to the underlying Android instance.

(Inherited from Object)
JniIdentityHashCode (Inherited from Object)
JniPeerMembers
LogMessages

Returns recent LogMessage LogMessages associated with this MediaDrm instance.

MaxHdcpLevel

Return the maximum supported HDCP level.

MaxSecurityLevel

Returns a value that may be passed as a parameter to #openSession(int) requesting that the session be opened at the maximum security level of the device.

MaxSessionCount

Return the maximum number of MediaDrm sessions that may be opened simultaneosly among all MediaDrm instances for the active DRM scheme.

Metrics

Return Metrics data about the current MediaDrm instance.

OfflineLicenseKeySetIds

The keys in an offline license allow protected content to be played even if the device is not connected to a network.

OpenSessionCount

Return the number of MediaDrm sessions that are currently opened simultaneously among all MediaDrm instances for the active DRM scheme.

PeerReference (Inherited from Object)
SecureStopIds

Return a list of all secure stop IDs currently in persistent memory.

SecureStops

Secure stops are a way to enforce limits on the number of concurrent streams per subscriber across devices.

SupportedCryptoSchemes
ThresholdClass

This API supports the Mono for Android infrastructure and is not intended to be used directly from your code.

(Inherited from Object)
ThresholdType

This API supports the Mono for Android infrastructure and is not intended to be used directly from your code.

(Inherited from Object)

Methods

ClearOnEventListener()

Clear the OnEventListener.

ClearOnExpirationUpdateListener()

Clear the OnExpirationUpdateListener.

ClearOnKeyStatusChangeListener()

Clear the OnKeyStatusChangeListener.

ClearOnSessionLostStateListener()

Clear the OnSessionLostStateListener.

Clone()

Creates and returns a copy of this object.

(Inherited from Object)
Close()

Releases resources associated with the current session of MediaDrm.

CloseSession(Byte[])

Close a session on the MediaDrm object that was previously opened with #openSession.

Dispose() (Inherited from Object)
Dispose(Boolean) (Inherited from Object)
Equals(Object)

Indicates whether some other object is "equal to" this one.

(Inherited from Object)
GetCryptoSession(Byte[], String, String)

Obtain a CryptoSession object which can be used to encrypt, decrypt, sign and verify messages or data using the session keys established for the session using methods #getKeyRequest and #provideKeyResponse using a session key server.

GetHashCode()

Returns a hash code value for the object.

(Inherited from Object)
GetKeyRequest(Byte[], Byte[], String, Int32, IDictionary<String,String>)

A key request/response exchange occurs between the app and a license server to obtain or release keys used to decrypt encrypted content.

GetOfflineLicenseState(Byte[])

Request the state of an offline license.

GetPlaybackComponent(Byte[])

Obtain a PlaybackComponent associated with a DRM session.

GetPropertyByteArray(String)

Read a MediaDrm byte array property value, given the property name string.

GetPropertyString(String)

Read a MediaDrm String property value, given the property name string.

GetProvisionRequest()

A provision request/response exchange occurs between the app and a provisioning server to retrieve a device certificate.

GetSecureStop(Byte[])

Access a specific secure stop given its secure stop ID.

GetSecurityLevel(Byte[])

Return the current security level of a session.

IsCryptoSchemeSupported(UUID, String, SecurityLevel)

Query if the given scheme identified by its UUID is supported on this device, and whether the DRM plugin is able to handle the media container format specified by mimeType at the requested security level.

IsCryptoSchemeSupported(UUID, String)

Query if the given scheme identified by its UUID is supported on this device, and whether the DRM plugin is able to handle the media container format specified by mimeType.

IsCryptoSchemeSupported(UUID)

Query if the given scheme identified by its UUID is supported on this device.

JavaFinalize()

Called by the garbage collector on an object when garbage collection determines that there are no more references to the object.

(Inherited from Object)
Notify()

Wakes up a single thread that is waiting on this object's monitor.

(Inherited from Object)
NotifyAll()

Wakes up all threads that are waiting on this object's monitor.

(Inherited from Object)
OpenSession()

Open a new session with the MediaDrm object.

OpenSession(Int32)

Open a new session at a requested security level.

ProvideKeyResponse(Byte[], Byte[])

A key response is received from the license server by the app, then it is provided to the MediaDrm instance using provideKeyResponse.

ProvideProvisionResponse(Byte[])

After a provision response is received by the app, it is provided to the MediaDrm instance using this method.

QueryKeyStatus(Byte[])

Request an informative description of the key status for the session.

Release()

This member is deprecated.

ReleaseAllSecureStops()

Remove all secure stops without requiring a secure stop release message from the license server.

ReleaseSecureStops(Byte[])

Process the secure stop server response message ssRelease.

RemoveAllSecureStops()

Remove all secure stops without requiring a secure stop release message from the license server.

RemoveKeys(Byte[])

Remove the current keys from a session.

RemoveOfflineLicense(Byte[])

Normally offline licenses are released using a key request/response exchange using #getKeyRequest where the key type is KEY_TYPE_RELEASE, followed by #provideKeyResponse.

RemoveSecureStop(Byte[])

Remove a specific secure stop without requiring a secure stop release message from the license server.

RequiresSecureDecoder(String, Int32)

Query if the crypto scheme requires the use of a secure decoder to decode data of the given mime type at the given security level.

RequiresSecureDecoder(String)

Query if the crypto scheme requires the use of a secure decoder to decode data of the given mime type at the default security level.

RestoreKeys(Byte[], Byte[])

Restore persisted offline keys into a new session.

SetHandle(IntPtr, JniHandleOwnership)

Sets the Handle property.

(Inherited from Object)
SetOnEventListener(IExecutor, MediaDrm+IOnEventListener)

Register a callback to be invoked when an event occurs

SetOnEventListener(MediaDrm+IOnEventListener, Handler)

Register a callback to be invoked when an event occurs

SetOnEventListener(MediaDrm+IOnEventListener)

Register a callback to be invoked when an event occurs

SetOnExpirationUpdateListener(IExecutor, MediaDrm+IOnExpirationUpdateListener)

Register a callback to be invoked when a session expiration update occurs.

SetOnExpirationUpdateListener(MediaDrm+IOnExpirationUpdateListener, Handler)

Register a callback to be invoked when a session expiration update occurs.

SetOnKeyStatusChangeListener(IExecutor, MediaDrm+IOnKeyStatusChangeListener)

Register a callback to be invoked when the state of keys in a session change, e.

SetOnKeyStatusChangeListener(MediaDrm+IOnKeyStatusChangeListener, Handler)

Register a callback to be invoked when the state of keys in a session change, e.

SetOnSessionLostStateListener(IExecutor, MediaDrm+IOnSessionLostStateListener)

Register a callback to be invoked when session state has been lost.

SetOnSessionLostStateListener(MediaDrm+IOnSessionLostStateListener, Handler)

Register a callback to be invoked when session state has been lost.

SetPropertyByteArray(String, Byte[])

Set a MediaDrm byte array property value, given the property name string and new value for the property.

SetPropertyString(String, String)

Set a MediaDrm String property value, given the property name string and new value for the property.

ToArray<T>() (Inherited from Object)
ToString()

Returns a string representation of the object.

(Inherited from Object)
UnregisterFromRuntime() (Inherited from Object)
Wait()

Causes the current thread to wait until it is awakened, typically by being <em>notified</em> or <em>interrupted</em>.

(Inherited from Object)
Wait(Int64, Int32)

Causes the current thread to wait until it is awakened, typically by being <em>notified</em> or <em>interrupted</em>, or until a certain amount of real time has elapsed.

(Inherited from Object)
Wait(Int64)

Causes the current thread to wait until it is awakened, typically by being <em>notified</em> or <em>interrupted</em>, or until a certain amount of real time has elapsed.

(Inherited from Object)

Events

MediaDrmEvent

Explicit Interface Implementations

IJavaPeerable.Disposed() (Inherited from Object)
IJavaPeerable.DisposeUnlessReferenced() (Inherited from Object)
IJavaPeerable.Finalized() (Inherited from Object)
IJavaPeerable.JniManagedPeerState (Inherited from Object)
IJavaPeerable.SetJniIdentityHashCode(Int32) (Inherited from Object)
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates) (Inherited from Object)
IJavaPeerable.SetPeerReference(JniObjectReference) (Inherited from Object)

Extension Methods

JavaCast<TResult>(IJavaObject)

Performs an Android runtime-checked type conversion.

JavaCast<TResult>(IJavaObject)
GetJniTypeName(IJavaPeerable)

Gets the JNI name of the type of the instance self.

JavaAs<TResult>(IJavaPeerable)

Try to coerce self to type TResult, checking that the coercion is valid on the Java side.

TryJavaCast<TResult>(IJavaPeerable, TResult)

Try to coerce self to type TResult, checking that the coercion is valid on the Java side.

Applies to