Skip to main content
Version: 11.4.0

Getting started with CMCD on iOS

Media player clients can transmit useful information to Content Delivery Networks (CDNs) with each object request. This implementation is planned to fully support Common Media Client Data (CMCD) as defined in CTA-5004-B, published in April 2026.

CMCD supports two modes of transmission:

  • Request mode: CMCD data is sent as HTTP headers or query parameters on manifest and media segment requests.
  • Event mode (available since v11.4.0): CMCD events are POSTed to configured HTTP endpoints.

Request Mode

To enable CMCD, developers can set the cmcd parameter inside a SourceDescription.

let typedSource = TypedSource(src: "<HLS_STREAM_URL>", type: "application/x-mpegurl", cmcd: true)
let sourceDescription = SourceDescription(source: typedSource)
theoplayer.source = sourceDescription

Remarks

Note that request mode is only supported on iOS 18.0+.

Event Mode

Event mode allows posting CMCD events to configured HTTP endpoints.

info

Event mode is supported starting from version 11.4.0.

Player-level configuration

let cmcdConfig = CMCDConfiguration(
externalSessionId: "YOUR-EXTERNAL-SESSION-ID", // optional
userId: "YOUR-USER-ID", // optional
eventEndpoints: [
CMCDEndpointConfiguration(url: "https://example.com/cmcd-event-endpoint")
]
)
let config = THEOplayerConfigurationBuilder()
config.cmcd = cmcdConfig
let player = THEOplayer(configuration: config.build())

Source-level configuration

let sourceConfig = CMCDSourceConfiguration(
externalSessionId: "YOUR-EXTERNAL-SESSION-ID", // optional
sessionId: "YOUR-SESSION-ID", // optional
userId: "YOUR-USER-ID", // optional
eventEndpoints: [
CMCDEndpointConfiguration(url: "https://example.com/cmcd-event-other-endpoint")
]
)
player.source = SourceDescription(
source: TypedSource(src: "<HLS_STREAM_URL>"),
cmcdConfiguration: sourceConfig
)

Merging behavior

  • Source-level values take precedence for externalSessionId and userId.
  • eventEndpoints from both levels are merged (both player and source endpoints receive events).
warning

Event mode reporting currently only supports DRM and ad events.