UNPKG

@playkit-js/playkit-js-dash

Version:

[![Build Status](https://github.com/kaltura/playkit-js-dash/actions/workflows/run_canary_full_flow.yaml/badge.svg)](https://github.com/kaltura/playkit-js-dash/actions/workflows/run_canary_full_flow.yaml) [![code style: prettier](https://img.shields.io/bad

48 lines (42 loc) 1.79 kB
import { IDrmProtocol, DrmScheme, getLogger, PKDrmConfigObject } from '@playkit-js/playkit-js'; const PlayReady: IDrmProtocol = class PlayReady { public static _logger = getLogger('PlayReady'); /** * PLAYREADY is the configure key system. * @param {Array<Object>} drmData - The drm data. * @param {PKDrmConfigObject} drmConfig - The drm config. * @return {boolean} - Whether PLAYREADY is the configure key system. */ public static isConfigured(drmData: Array<any>, drmConfig: PKDrmConfigObject): boolean { return DrmScheme.PLAYREADY === drmConfig.keySystem && !!drmData.find(drmEntry => drmEntry.scheme === drmConfig.keySystem); } /** * PlayReady playback supports in case 2 conditions are met: * 1. The environment supports PlayReady playback. * 2. The drm data of the source object contains entry with PlayReady scheme. * @param {Array<Object>} drmData - The drm data to check. * @return {boolean} - Whether PlayReady can be play on the current environment. */ public static canPlayDrm(drmData: Array<any>): boolean { PlayReady._logger.debug('Can play DRM scheme of: ' + DrmScheme.PLAYREADY); return !!drmData.find(drmEntry => drmEntry.scheme === DrmScheme.PLAYREADY); } /** * Sets the PlayReady playback. * @param {Object} config - The shaka player config. * @param {Array<Object>} drmData - The drm data. * @returns {void} */ public static setDrmPlayback(config: any, drmData: Array<any>): void { PlayReady._logger.debug('Sets drm playback'); const prDrmEntry = drmData.find(drmEntry => drmEntry.scheme === DrmScheme.PLAYREADY); if (prDrmEntry) { config.drm = { servers: { [DrmScheme.PLAYREADY]: prDrmEntry.licenseUrl } }; } } }; export {PlayReady};