MediaKeys
Secure context: This feature is available only in secure contexts (HTTPS), in some or all supporting browsers.
The MediaKeys interface of Encrypted Media Extensions API represents a set of keys that an associated HTMLMediaElement can use for decryption of media data during playback.
Instance properties
None.
Instance methods
MediaKeys.createSession()-
Returns a new
MediaKeySessionobject, which represents a context for message exchange with a content decryption module (CDM). MediaKeys.getStatusForPolicy()-
Returns a
Promisethat resolves to a status string indicating whether the CDM would allow the presentation of encrypted media data using the keys, based on specified policy requirements. MediaKeys.setServerCertificate()-
Returns a
Promiseto a server certificate to be used to encrypt messages to the license server.
Examples
Check if keys are usable with HDCP restriction
This example shows how getStatusForPolicy() can be used to check if keys can decrypt a particular video format in a setup that has a minimum HDCP version of 2.2.
For more information, see the MediaKeys: getStatusForPolicy() method documentation.
HTML
<pre id="log"></pre>
JavaScript
const config = [
{
videoCapabilities: [
{
contentType: 'video/mp4; codecs="avc1.640028"',
encryptionScheme: "cenc",
robustness: "SW_SECURE_DECODE", // Widevine L3
},
],
},
];
getMediaStatus(config);
async function getMediaStatus(config) {
try {
const mediaKeySystemAccess = await navigator.requestMediaKeySystemAccess(
"com.widevine.alpha",
config,
);
const mediaKeys = await mediaKeySystemAccess.createMediaKeys();
const mediaStatus = await mediaKeys.getStatusForPolicy({
minHdcpVersion: "2.2",
});
log(mediaStatus);
// Get the content or fallback to an alternative if the
// keys are not usuable
if (mediaStatus === "usable") {
console.log("HDCP 2.2 can be enforced.");
// Fetch the high resolution protected content
} else {
log("HDCP 2.2 cannot be enforced");
// Fallback other content, get license, etc.
}
} catch (error) {
log(error);
}
}
Results
Specifications
| Specification |
|---|
| Encrypted Media Extensions # mediakeys-interface |
Browser compatibility
BCD tables only load in the browser