Información general de la interfaz DRM

El TVSDK del explorador proporciona una interfaz DRM que puede utilizar para reproducir contenido protegido por distintas soluciones DRM, incluidas FairPlay, PlayReady y Widevine.

IMPORTANTE

La compatibilidad con DRM está disponible para flujos MPEG-Dash protegidos con sistemas Microsoft PlayReady (en Internet Explorer en Windows 8.1 y Edge) y Widevine (en Google Chrome) DRM. La compatibilidad con DRM está disponible para flujos HLS en Safari que están protegidos con FairPlay.

La interfaz clave del flujo de trabajo de DRM es DRMManager. Se puede obtener una referencia a la instancia DRMManager mediante la instancia de MediaPlayer:

  • var mediaPlayer = new AdobePSDK.MediaPlayer();
  • var drmManager = mediaPlayer.drmManager;

Este es un flujo de trabajo de alto nivel para la reproducción de contenido protegido con DRM:

  1. Para adjuntar los datos específicos del sistema DRM que utilizará el SDK de TVSDK del explorador en el proceso de adquisición de licencias para un flujo protegido, realice la siguiente llamada antes de invocar a mediaPlayer.replaceCurrentResource:

    var protectionData = {
        "com.adobe.primetime": {
           "serverURL": {
              "individualization-request": "https://individualization.adobe.com/flashaccess/i15n/v5",
              "license-request": "https://example.com:8096/flashaccess/req",
              "license-release": "https://example.com:8096/flashaccess/req"
           },
           "httpRequestHeaders": {
           }
        }
    };
    var drmManager = mediaPlayer.drmManager;
    drmManager.setProtectionData(protectionData);
    
  2. Si se espera que el mismo contenido funcione con diferentes sistemas DRM en distintos navegadores, se pueden especificar datos de protección para varios sistemas DRM.

    var protectionData = {
        "com.adobe.primetime": {
            "serverURL": {
                "individualization-request": "https://individualization.adobe.com/flashaccess/i15n/v5",
                "license-request": "https://example.com:8096/flashaccess/req",
                "license-release": "https://example.com:8096/flashaccess/req"
            },
            "httpRequestHeaders": {
            }
        },
        "com.widevine.alpha": {
            "serverURL": "https://wv.service.expressplay.com/hms/wv/rights/?ExpressPlayToken=<token value>",
            "httpRequestHeaders": {
                "dt-custom-data": "eyJ1c2VySWQiOiIxMjM0NS"
            }
        },
        "com.microsoft.playready": {
            "serverURL": "https://pr.test.expressplay.com/playready/RightsManager.asmx?ExpressPlayToken=<token value>",
            "httpRequestHeaders": {
                "http-header-CustomData": "eyJ1c2VySWQiOiIxMjM0NS"
            }
        },
        "com.apple.fps.1_0": {
            "serverURL": "https://fp.service.expressplay.com:80/hms/fp/rights/?ExpressPlayToken=<token value>",
            "certificateURL": "Path_To_certificate.cer",
            "licenseResponseType": "arraybuffer",
            "httpRequestHeaders": {
                "Content-type": "application/octet-stream"
            }
        },
        "org.w3.clearkey": {
            "clearkeys": {
                "H3JbV93QV3mPNBKQON2UtQ": "ClKhDPHMtCouEx1vLGsJsA",
                "IAAAACAAIAAgACAAAAAAAg": "5t1CjnbMFURBou087OSj2w"
            }
        }
    };
    
    var drmManager = mediaPlayer.drmManager;
    drmManager.setProtectionData(protectionData);
    
  3. Cuando no se establecen los datos de protección, se recupera la información necesaria, como la URL de la licencia, del cuadro PSSH para los sistemas DRM, cuando corresponde.

    SUGERENCIA

    Si se especifican datos de protección, se anula la URL de licencia especificada en el cuadro PSSH.

  4. De forma predeterminada, el tipo de sesión de la licencia de DRM es temporal, lo que significa que la licencia no se almacena una vez cerrada la sesión.

    Puede especificar un tipo de sesión mediante una API en DRMManager. Para la compatibilidad con versiones anteriores, los tipos de sesión incluyen temporary, persistent-license, persistent-usage-record y persistent.

    var drmManager = mediaPlayer.drmManager;
     drmManager.setEMESessionType(“<YOUR_SESSION_TYPE>”);
    
  5. Cuando el sessionType utilizado es persistent-license o persistent, la licencia de DRM puede devolverse invocando DRMManager.returnLicense.

    var onLicenseReturnFunc = function () {
        console.log("DRM: License Return Complete ");
    },
    
    onLicenseReturnErrorFunc = function (major, minor, errorString/*, errorServerUrl*/) {
       console.log("DRM: License Return Error: " + errorString);
    },
    
    drmManager = mediaPlayer.drmManager;
    
    if (drmManager) {
        var returnLicenseListener = new
            AdobePSDK.DRMReturnLicenseListener(onLicenseReturnFunc, onLicenseReturnErrorFunc);
        drmManager.returnLicense(null, null, null, false, returnLicenseListener, drmLicense.session);
    }
    

En esta página