MediaMelon JS Custom Multi-Player SDK Integration Document

This guide is for integrating the MediaMelon Custom Multi-Player SDK for the JavaScript-based Web Players

Step 1: Add MediaMelon Player SDK

Step 2: Instantiate and Register SDK

Step 3: Initialize Playback Session

Step 4: Custom Metadata

Step 5: Stream and Network Information

Step 6: Chunk/Segment Information

Step 7: Player Events

Step 8: Fallback & Request Status

Step 9: Ad Data & Ad Events

Step 10: Custom Events

Release Notes

Step 1: Add MediaMelon SDK

  • NPM (2.1.0):

npm i mediamelon-js-custom-sdk
import { mmJSCustomAdapter, MMPlayerState, RenditionInfo, RequestStatus} from 'mediamelon-js-custom-sdk'

Step 2: Instantiate and Register SDK

circle-info

CUSTOMER_ID is your MediaMelon assigned Customer ID. If you do not know your Customer ID, contact MediaMelon at [email protected]envelope.

Step 2.1: Instantiate and Report Registration Information:

circle-info

hashSubscriberId: Set it to true to hash the subscriber ID, and to false to process the subscriber ID without hashing.

Step 2.2: Report Player Information:

Step 2.3: Report Application Information:

Step 2.4: Report Device Information:

Step 2.5: Report Sub Property ID:

Step 3: Initialize Playback Session

Step 3.1: Initialize Session with Content Metadata:

circle-exclamation

Step 3.2: Report View Session ID:

Step 3.3: Report Experiment Name:

Step 3.4: Report Preload:

Step 3.5: Report Player Resolution:

Step 3.6: Report User-Initiated Playback:

circle-info

This function indicates the intent for playback and must be invoked after initializeSession. Any metadata fields reported before this API call will be included in the first payload sent to the dashboard. To avoid Null values in metadata fields, it is recommended to report all available metadata before calling this API.

Step 4: Custom Metadata

Check the custom tags configuration in your dashboardarrow-up-right and report accordingly. If the custom tags are not configured, please configure and use them accordingly.

Step 5: Stream and Network Information

Step 5.1: Report Stream Information:

Step 5.2: Update Stream URL:

Step 5.3: Report Presentation Info:

circle-info
  • is_live: Set to true for live video stream and to false for the VOD stream.

  • video_duration: Integer value in milliseconds.

Step 5.4: Report Track Information

Call this API with initial values, and every time there is a change in the track info. Call this API when the user enables/disables subtitles or when the user changes the audio track.

circle-info

is_subtitle_active: Set it to true if the subtitles are active; otherwise, set it to false.

is_vds_active: Set it to true if the type of audio is Virtual Dialogue Sound, otherwise, set it to false.

Step 5.5: Report Rendition:

At the start of the video, create a ReditionInfo object, assign initial rendition values to the object, and report it to the SDK. For any subsequent rendition change, update only the fields that changed in the same RenditionInfo object. Leave the unchanged fields as-is, and report the updated object to the SDK.

Step 5.6: Update DRM Type:

triangle-exclamation

Step 5.7: Report Network Information:

circle-info

Use the reportNetworkInfo API to report the CDN along with other network information. If additional network information is not available, use reportCDN instead.

Step 5.8: Report CDN Information:

Step 5.9: Report Encoding Service:

Step 6: Chunk/Segment Information

Step 6.1: Report Download Rate:

Report the latest chunk download rate using this method. Trigger this method for every chunk.

Step 7: Player Events

Step 7.1: Report Player State:

Step 7.2: Report Buffering:

Step 7.3: Report Seek:

Step 7.4: Report Error:

Step 7.5: Report Warning:

Step 7.6: Report Playback Position:

Call this every 0.5 sec or 1 sec to report the playback position from the player

Step 7.7: Report Player Resolution:

Step 8: Fallback & Request Status

Step 8.1: Report Fallback Event:

Step 8.2: Report Request Status:

Step 9: Ad Data & Ad Events

Step 9.1: Report Ad Break Start & End:

Step 9.2: Report Ad Data, Ad Start & End:

chevron-rightAdInfo Object descriptionhashtag

adInfo.adTitle

String

The title or name of the ad, usually provided in the VAST metadata or by the ad server.

adInfo.adId

String

A unique identifier for the ad creative, often defined by the ad server or DSP.

adInfo.adCreativeId

String

The creative ID associated with the specific ad asset (video, image, etc.). Helps in tracking and reporting creative-level performance.

adInfo.adCreativeType

String

The format or type of the ad creative. For example, video/mp4, image/jpeg, etc., or linear, non-linear.

adInfo.adClient

String

The SDK or client library responsible for requesting and playing the ad. Example: Google IMA, Freewheel, SpotX.

adInfo.adPosition

String

The timing of the ad in relation to the main content: "pre" (before), "mid" (during), or "post" (after).

adInfo.adServer

String

The ad server or source that delivered the ad. Example: Google Ad Manager, Freewheel, etc.

adInfo.adResolution

String

The resolution of the ad video (e.g., 1920x1080), useful for reporting and quality monitoring.

adInfo.adUrl

String

The URL from which the ad video is fetched. Typically a media file or stream URL.

adInfo.adDuration

Integer

The total duration of the ad, in milliseconds. Example: 30000 = 30 seconds.

adInfo.adPodIndex

Integer

The index of the ad pod within the stream. Ad pods are groups of ads played together (like a commercial break).

adInfo.adPositionInPod

Integer

The position of the ad within its pod (e.g., 1st ad, 2nd ad in the group).

adInfo.adPodLendth

Integer

The total number of ads in the current pod. Useful for showing “Ad 2 of 5” type of UI.

adInfo.isBumper

Boolean

A boolean (true/false) indicating whether the ad is a bumper ad (short ad, usually <6s, played at the start or end of ad breaks).

Step 9.3: Report Ad Buffering:

Use Ad Buffering APIs to report any buffering that occurs during ad playback. For any buffering event, either content buffering or ad buffering should be reported, but not both.

Step 10: Custom Events

The Custom Events API can be used to report events that are not covered by the default MediaMelon-supported events. Custom events must be reported within the SDK activity lifecycle. Events reported before SDK initialization or after session end will be ignored. Please refer to the guidelines and constraints below.

circle-info

Guidelines & Constraints

  • Event Name

    • Maximum length: 35 characters

    • Allowed characters: Alphanumeric and underscore (_) only

    • Special characters are not supported

    • Recommended format: UPPERCASE with underscores (e.g., DRM_CHANGE)

  • Event Limits

    • A maximum of 35 custom events per session is allowed.

Custom events that violate these constraints (invalid event name or exceeding the per-session limit) will be dropped. Event values exceeding 1000 characters will be truncated to 1000 characters.

Release Notes

chevron-rightCurrent Releasehashtag

v2.1.0

  • Added support for multiple player instances within a single application.

  • Added the following new metadata fields:

    • Player ID - report it using reportPlayerId.

    • DRM Level - report it as part of Content Metadata.

    • Ad Universal ID - report it as part of Ad Info.

  • updateDRMType(drmType)Deprecated

    • Use updateDRM(drmProtection, drmLevel) (refer to Step 5.6)

  • Buffering events exceeding the stats interval are now included in the stats payload.

  • Updated metadata lifecycle handling:

    • Step 2 metadata fields persist across the SDK instance lifecycle.

    • All Metadata fields from Step 3 are reset for every playback session.


chevron-rightPrevious Releaseshashtag

Last updated