Analytics
We provide pre-integrations with multiple analytics vendors. In most cases, you will only need to initialize the plugin with your account credentials and optional custom data. The SDK will take care of sending the required playback events (e.g. playback start/pause/stop, buffering, seeking, ad start/stop…) to the analytics backend.
Youbora
Youbora Analytics
is a comprehensive analytics and monitoring platform specifically designed for online video streaming services. It provides real-time insights and data analytics to help content providers and broadcasters understand the performance and usage of their video content.
Developed by Nice People At Work, Youbora Analytics offers a wide range of features and capabilities to track, measure, and optimize video streaming performance. It collects data from various sources, including video players, content delivery networks (CDNs), and end-user devices, and transforms that data into meaningful metrics and reports.
Our integration is validated by Nice People at Work QA.
Integrate
To start with Youbora Analytics first register a plugin to PRESTOplay SDK:
import PRESTOplay
import CastlabsYoubora
...
let youboraSettings = YouboraSettings(accountCode: "...")
let youboraPlugin = YouboraPlugin(youboraSettings)
PRESTOplaySDK.shared.register("LICENSE", [youboraPlugin])
Analytics instance and custom metadata
After creating an analytics instance with the player and the .youbora
option, set the custom metadata. If you want to use custom Youbora client settings you will have to import NpawPlugin
to your project.
The easiest way is to add it via Podfile
:
pod 'NpawPlugin'
To pass custom data:
import PRESTOplay
import CastlabsYoubora
import NpawPlugin
var analytics = PRESTOplaySDK.shared.analytics(for: player, .youbora)
...
let youboraMetadata = YouboraMetadata(
live: false,
assetId: "assetId")
youboraMetadata.analyticsOptions = NpawPlugin.AnalyticsOptions()
youboraMetadata.analyticsOptions?.adCustomDimension1 = "test"
youboraMetadata.analyticsOptions?.contentTitle = "test"
youboraMetadata.analyticsOptions?.autoDetectBackground = false
youboraMetadata.accountCode = "ACCOUNT_CODE"
analytics?.metadata = youboraMetadata
To prevent the plugin from sending a Stop
event when switching to Picture in Picture mode, set analyticsOptions?.autoDetectBackground
to false
.
Please check our examples/YouboraDemo
for complete implementation.
Broadpeak
Integrate
Register a Broadpeak plugin to PRESTOplay SDK:
import PRESTOplay
import CastlabsBroadpeak
...
let broadpeakSettings = BroadpeakSettings(
analyticsAddress: "YOUR-ANALYTICS-SERVER-ADDRESS",
nanoCDNHost: "",
domainNames: "")
let broadpeakPlugin = BroadpeakPlugin(broadpeakSettings)
PRESTOplaySDK.shared.register("LICENSE", [broadpeakPlugin])
Analytics instance and custom metadata
After creating an analytics instance with the player and the .broadpeak
option, set the custom metadata.
var analytics = PRESTOplaySDK.shared.analytics(for: player, .broadpeak)
...
let broadpeakMetadata = AnalyticsMetadata(
live: false,
assetId: "assetId")
analytics.metadata = broadpeakMetadata
Please check our examples/BroadpeakDemo
for complete implementation.
Conviva
Integrate
First, include the ConvivaSDK
library in your project. Here is an example using CocoaPods:
pod 'ConvivaSDK'
Please find a list of supported versions in configs/deps-versions
.
Next, register the Conviva plugin to PRESTOplay SDK:
import PRESTOplay
import CastlabsConviva
...
let convivaSettings = ConvivaSettings(
customerKey,: "YOUR-CUSTOMER-KEY",
gatewayUrl: "YOUR-GATEWAY-URL")
let convivaPlugin = ConvivaPlugin(convivaSettings)
PRESTOplaySDK.shared.register("LICENSE", [convivaPlugin])
Analytics instance
Creating an analytics instance with the player and the .conviva
option.
var analytics: AnalyticsAPI = PRESTOplaySDK.shared.analytics(for: player, .conviva)
Please check our examples/ConvivaDemo
for complete implementation.
Mux Data
Integrate
First, include the Mux-Stats-Core
library in your project. Here is an example using CocoaPods:
pod 'Mux-Stats-Core'
Please find a list of supported versions in configs/deps-versions
.
Next, register the Mux Data plugin to PRESTOplay SDK:
import PRESTOplay
import CastlabsMux
...
let muxSettings = MuxSettings(environmentKey: "ENV_KEY")
let muxPlugin = MuxPlugin(muxSettings)
PRESTOplaySDK.shared.register("LICENSE", [muxPlugin])
Analytics instance
Creating an analytics instance with the player and the .mux
option.
var analytics: AnalyticsAPI = PRESTOplaySDK.shared.analytics(for: player, .mux)