watermarking

This module is available to use in your EdgeWorkers code bundles to perform operations related to forensic watermarking for Over-The-Top (OTT) content delivered in an Adaptive Bitrate (ABR) format. The watermarking module adheres to the DASH-IF watermarking specification. jwt and cwt modules are supported for token verification.

📘

Currently there is a known compatibility issue between partial object caching and the watermarking module. Reach out to your account team for more information.

You can use the watermarking module in both direct and indirect mode. For indirect mode, you need to obtain vendor specific wmid generator code and plug it into the module. Refer to the wm-indirect example in the EdgeWorkers GitHub repo for more details.

👍

To use the watermarking library you need to use EdgeWorkers Dynamic Compute resource tier.

Watermarking

Constructor for a new Watermarking Object. It performs type checks on the wmOptions Object parameters.

Watermarking(wmOptions: WMOptions,  vendorAlgorithms: Map<string,VendorAlgorithm> )

Throws an error if the type checks fail for the following wmOptions parameters.

WMOptions Object

ParameterTypeDescriptionDefault Value
tokenTypeenumThe type of auth token.'JWT' for JWT tokens
or
'CWT' for CWT tokens
issuerString(optional) The issuer to check with an iss claim in the JWT payload.
subjectString(optional) The subject to check with a sub claim in the JWT payload.
audienceString(optional) The audience to check with an aud claim in the JWT payload.
ignoreExpirationBoolean(optional) If false, validate the expiry of the token.true
ignoreNotBeforeBoolean(optional) If false, validate the not before claim of the token.true
allowUnsecuredTokenBoolean(optional) If true, Unsecured JWT tokens are supported.
For example, alg = NONE
If false, throws an unsupported unsecured JWT tokens error whenever unsecured JWT tokens are passed.
false
clockToleranceNumber(optional) Number of seconds to tolerate when checking the nbf and exp claims.60 seconds
isCWTTagAddedBoolean(optional) Adds a CWT tag to the token. Applies only for CWT based tokens.false
isCoseCborTagAddedBoolean(optional) Adds a COSE message structure tag to the generated CWT token. This only applies to CWT based tokens. Currently only the COSE_MAC0 structure is supported with the HS256-256 algorithm.true
headerValidationBoolean(optional) Specifies if the protected header of a CWT token needs to be validated. This is applicable only for CWT based tokens.false

vendorAlgorithms

A map with key as the vendor identifier. This should be the same as the wmvnd field from the watermarking token. The value should be an implementation of the vendor-algorithm interface shown below. Refer to the Indirect Watermarking example for more details.

/**
 * Abstract class to implement vendor specific algorithm to generate tmid.
 */
interface VendorAlgorithm {
    /**
     * Returns the generated WMID after executing vendor specific algorithm.
     * @param payload @instance of WMPaylaod.
     * @param secretKey key (if any) required to generate WMID. 
     * @returns WMID as hex string
     */
    generateTmid(payload: WMPayload, secretKey: string): Promise<string>;
}

validateToken

Validates the watermarking token as per the validation rules, performs signature verification for each key from the array. The token signature needs to be successfully verified by at least one key to consider the token as valid.

Returns a promise<WMJSON> upon successful verification of the token, otherwise throws an error.

validateToken( authToken: Uint8Array | string, keys: string[], keyAlg: string )

Throws a DOMException or a TypeError when trying to use invalid key data, when the key is not a supported key for the algorithm, or when trying to use an algorithm that is either unknown or isn't suitable for a verify operation.

ParameterTypeDescription
authTokenString or binaryWatermarking token, JWT or CWT.
JWT token must be passed as a string.
CWT token can be passed as binary (Uint8Array) or a hex encoded string.
keysArray of stringsSymmetric or public keys to use for signature verification.
Symmetric keys must be passed as hex string.
Public keys must be passed as PEM encoded string.
keyAlgStringThe algorithm used to generate the keys.

WMJSON

JSON object containing the header and payload.

ParameterTypeDescription
headerJWTHeader | CWT headerRefer JWT Header for more details.
Refer CWT Header for more details.
payloadWMPayloadJSON object containing watermarking claims

WMPayload

Contains watermarking fields in addition to fields from the CWT and JWT payload. Refer to CWT or JWT payload for details about other fields.

ParameterTypeDescription
wmverNumberVersion of the Watermarking Token.
wmvndNumberWatermarking vendor identification.
wmpatlenNumberProvides the length of wmpattern extracted or derived from wmid.
wmidString(optional) Specifies indirect mode. It is used as input to derive the WM pattern. The derivation algorithm is not defined in this document and is vendor specific.
wmpatternUint8Array(optional) Specifies direct mode. The value is bytes of COSE_Encrypt0 message structure. Refer to the COSE spec for more details on generating COSE_Encrypt0 message.
wmsegdurationArray(optional) Nominal duration of a segment.
wmopidNumber(optional) Required only for indirect mode. It may provide additional data for the vendor specific derivation algorithm that generates the WM pattern
wmkeyverNumber(optional) Identifies the key to use to derive and decrypt the WM pattern.

Note: This field is currently ignored. The derive and decrypt key is passed to the getWMPathWithVariant() function directly.

getWMPathWithVariant

Executes the relevant vendor algorithm (indirect) or performs decryption (direct) to generate the watermarking variant. Once the wmid is obtained from the token (either directly, decrypted or calculated), the CDN edge enforces big-endian convention to address a single bit in it when using the value of position obtained from side car file.

The following is an example with a WM pattern equal to 0x0A0B0C0D.

Byte0123
bit offset01234567012345670123456701234567
binary00001010000010110000110000001101
hex0A0B0C0D

For a value of position equal to 3, the bit to consider is highlighted in green (equal to 0). This is not any other bit,
especially, those highlighted in red.

Returns a promise<number> representing the computed watermarking variant.

getWMPathWithVariant(
    path: string,
    payload: WMPayload,
    secretKey: string,
    rangeHeader?: string
  ): Promise<number>

Throws an error if the type checks fails for the following parameters or if any validation check fails.

Throws a DOMException or a TypeError when trying to use invalid key data, when the key is not a supported key for the algorithm, or when trying to use an algorithm that is either unknown or isn't suitable for a verify operation.

ParameterTypeDescription
pathStringThe url path from the request. For example, request.path.
payloadWMPayloadContains watermarking fields in addition to fields from the CWT and JWT payload. See WMPayload object definition above.
secretKeyHex encoded stringSecret key if required to either perform decryption of wmpattern or required in the vendor algorithm to generate a watermarking identifier.
rangeHeaderString(optional) The requested byte range.

Use the format bytes=<range-start>-<range-end>
For example, bytes=200-1000.