Constructor
new DrmEngine(networkingEnginenon-null, onError, onKeyStatus)
Parameters:
| Name | Type | Description |
|---|---|---|
networkingEngine |
shaka.net.NetworkingEngine | |
onError |
function(!shaka.util.Error) | Called when an error occurs. |
onKeyStatus |
function(!Object.<string, string>) | Called when key status changes. Argument is a map of hex key IDs to statuses. |
- Implements:
- Source:
Members
-
(private, non-null) activeSessions_ :Array.<shaka.media.DrmEngine.ActiveSession>
-
Type:
- Source:
-
(private, non-null) allSessionsLoaded_ :shaka.util.PublicPromise
-
Type:
- Source:
-
(private, nullable) config_ :shakaExtern.DrmConfiguration
-
Type:
- Source:
-
(private, nullable) currentDrmInfo_ :shakaExtern.DrmInfo
-
Type:
- Source:
-
(private) destroyed_ :boolean
-
Type:
- boolean
- Source:
-
(private) eventManager_ :shaka.util.EventManager
-
Type:
- Source:
-
(private) initialized_ :boolean
-
Type:
- boolean
- Source:
-
(private) isOffline_ :boolean
-
Type:
- boolean
- Source:
-
(private, non-null) keyStatusByKeyId_ :Object.<string, string>
-
Type:
- Object.<string, string>
- Source:
-
(private) keyStatusTimer_ :shaka.util.Timer
-
Type:
- Source:
-
(private) mediaKeys_ :MediaKeys
-
Type:
- MediaKeys
- Source:
-
(private) networkingEngine_ :shaka.net.NetworkingEngine
-
Type:
- Source:
-
(private, non-null) offlineSessionIds_ :Array.<string>
-
Type:
- Array.<string>
- Source:
-
(private, nullable) onError_ :?function(!shaka.util.Error)
-
Type:
- ?function(!shaka.util.Error)
- Source:
-
(private, nullable) onKeyStatus_ :?function(!Object.<string, string>)
-
Type:
- ?function(!Object.<string, string>)
- Source:
-
(private) supportedTypes_ :Array.<string>
-
Type:
- Array.<string>
- Source:
-
(private) video_ :HTMLMediaElement
-
Type:
- HTMLMediaElement
- Source:
Methods
-
(static) isBrowserSupported() → {boolean}
-
Returns true if the browser has recent EME APIs.
- Source:
Returns:
- Type
- boolean
-
(static) probeSupport() → (non-null) {Promise.<!Object.<string, ?shakaExtern.DrmSupportType>>}
-
Returns a Promise to a map of EME support for well-known key systems.
- Source:
Returns:
- Type
- Promise.<!Object.<string, ?shakaExtern.DrmSupportType>>
-
attach(video) → (non-null) {Promise}
-
Attach MediaKeys to the video element and start processing events.
Parameters:
Name Type Description videoHTMLMediaElement - Source:
Returns:
- Type
- Promise
-
configure(config)
-
Called by the Player to provide an updated configuration any time it changes. Must be called at least once before init().
Parameters:
Name Type Description configshakaExtern.DrmConfiguration - Source:
-
(private) configureClearKey_() → (nullable) {shakaExtern.DrmInfo}
-
Create a DrmInfo using configured clear keys. The server URI will be a data URI which decodes to a clearkey license.
- Source:
- See:
Returns:
or null if clear keys are not configured.- Type
- shakaExtern.DrmInfo
-
(private) createCurrentDrmInfo_(keySystem, config, drmInfosnon-null)
-
Creates a DrmInfo object describing the settings used to initialize the engine.
Parameters:
Name Type Description keySystemstring configMediaKeySystemConfiguration drmInfosArray.<shakaExtern.DrmInfo> - Source:
-
createOrLoad() → (non-null) {Promise}
-
Creates the sessions for the init data and waits for them to become ready.
- Source:
Returns:
- Type
- Promise
-
(private) createTemporarySession_(initDataType, initDatanon-null)
-
Parameters:
Name Type Description initDataTypestring initDataUint8Array - Source:
-
destroy() → (non-null) {Promise}
-
Destroys the object, releasing all resources and shutting down all operations. Returns a Promise which is resolved when destruction is complete. This Promise should never be rejected.
- Implements:
- Source:
Returns:
- Type
- Promise
-
(private) fillInDrmInfoDefaults_(drmInfo)
-
Use this.config_ to fill in missing values in drmInfo.
Parameters:
Name Type Description drmInfoshakaExtern.DrmInfo - Source:
-
getDrmInfo() → (nullable) {shakaExtern.DrmInfo}
-
Returns the DrmInfo that was used to initialize the current key system.
- Source:
Returns:
- Type
- shakaExtern.DrmInfo
-
getSessionIds() → (non-null) {Array.<string>}
-
Returns the ID of the sessions currently active.
- Source:
Returns:
- Type
- Array.<string>
-
getSupportedTypes() → {Array.<string>}
-
Returns an array of the media types supported by the current key system. These will be full mime types (e.g. 'video/webm; codecs="vp8"').
- Source:
Returns:
- Type
- Array.<string>
-
init(manifestnon-null, offline) → (non-null) {Promise}
-
Negotiate for a key system and set up MediaKeys.
Parameters:
Name Type Description manifestshakaExtern.Manifest The manifest is read for MIME type and DRM information to query EME. If the 'clearKeys' configuration is used, the manifest will be modified to force the use of Clear Key. offlineboolean True if we are storing or loading offline content. - Source:
Returns:
Resolved if/when a key system has been chosen.- Type
- Promise
-
initialized() → {boolean}
-
- Source:
Returns:
- Type
- boolean
-
keySystem() → {string}
-
- Source:
Returns:
- Type
- string
-
(private) loadOfflineSession_(sessionId) → (non-null) {Promise.<MediaKeySession>}
-
Parameters:
Name Type Description sessionIdstring - Source:
Returns:
- Type
- Promise.<MediaKeySession>
-
(private) onEncrypted_(eventnon-null)
-
Parameters:
Name Type Description eventMediaEncryptedEvent - Source:
-
(private) onKeyStatusesChange_(eventnon-null)
-
Parameters:
Name Type Description eventEvent - Source:
-
(private) onSessionMessage_(eventnon-null)
-
Parameters:
Name Type Description eventMediaKeyMessageEvent - Source:
-
(private) prepareMediaKeyConfigs_(manifestnon-null, offline, configsByKeySystemnon-null, keySystemsInOrdernon-null)
-
Parameters:
Name Type Description manifestshakaExtern.Manifest offlineboolean True if we are storing or loading offline content. configsByKeySystemObject.<string, MediaKeySystemConfiguration> (Output parameter.) A dictionary of configs, indexed by key system. keySystemsInOrderArray.<string> (Output parameter.) A list of key systems in the order in which we encounter them. -
(private) processDrmInfos_(drmInfosnon-null, licenseServersnon-null, serverCertsnon-null, initDatasnon-null)
-
Extract license server, server cert, and init data from DrmInfos, taking care to eliminate duplicates.
Parameters:
Name Type Description drmInfosArray.<shakaExtern.DrmInfo> licenseServersArray.<string> serverCertsArray.<!Uint8Array> initDatasArray.<!shakaExtern.InitDataOverride> - Source:
-
(private) processKeyStatusChanges_()
-
- Source:
-
(private) queryMediaKeys_(configsByKeySystemnon-null, keySystemsInOrdernon-null) → (non-null) {Promise}
-
Parameters:
Name Type Description configsByKeySystemObject.<string, MediaKeySystemConfiguration> A dictionary of configs, indexed by key system. keySystemsInOrderArray.<string> A list of key systems in the order in which we should query them. On a browser which supports multiple key systems, the order may indicate a real preference for the application. - Source:
Returns:
Resolved if/when a key system has been chosen.- Type
- Promise
-
removeSessions(sessionsnon-null) → (non-null) {Promise}
-
Removes the given offline sessions and deletes their data. Must call init() before this.
Parameters:
Name Type Description sessionsArray.<string> - Source:
Returns:
- Type
- Promise
-
(private) unpackPlayReadyRequest_(request)
-
Unpack PlayReady license requests. Modifies the request object.
Parameters:
Name Type Description requestshakaExtern.Request - Source:
Type Definitions
-
ActiveSession
-
A record to track sessions and suppress duplicate init data.
Type:
- {loaded: boolean, initData: Uint8Array, session: !MediaKeySession}
Properties:
Name Type Description loadedboolean True once the key status has been updated (to a non-pending state). This does not mean the session is 'usable'. initDataUint8Array The init data used to create the session. sessionMediaKeySession The session object. - Source: