Logo

Application collectors

Native Roku Media Player

Roku collector

The Native roku media player is a configuration option for the Roku collector by Datazoom that makes the following additional data points automatically collectable in real time.

Events

Buffer End

Supported Media Types
Content
Notes
A buffering event has just completed. The player fires this event which returns a value of 1 to indicate that playback has resumed.

Buffer Start

Supported Media Types
Content
Notes
When the Buffer Start event is thrown and a value received, it is correlated to a specific playback time by comparing it to the playback length within the manifest. Once the Buffer End event has thrown, the delta between the two can be used to forensically analyze a series of chunks to determine the veracity of the content files. If the issue is corrupt chunks, a new encode can be produced.

Error

Supported Media Types
Content

Heartbeat

Notes
Configure heartbeats by visiting your collector configurations pages from the Collectors page, scroll to the Heartbeats setting in the Event Control section. By default, heartbeats fire every 60 seconds.

Media Loaded

Supported Media Types
Content

Media Object Request

Supported Media Types
Content
Notes
Primarily intended for open tracing via CMCD.

Media Request

Supported Media Types
Content
Notes
Identify problems that may be occurring in the video player which prevent successful playback after a user requests playback.

Milestone

Supported Media Types
Content
Notes
Configure milestones by visiting your collector configurations pages from the Collectors page, scroll to the Milestones setting in the Event Control section. By default, for content, milestones fire when the user passes 5%, 10%, 25%, 50%, 75%, 90%, & 95% point in the content playback timeline and, for ads, when the user passes 25%, 50%, & 75% point in the ad playback timeline.

Pause

Supported Media Types
Content

Playback Complete

Supported Media Types
Content

Playback Start

Supported Media Types
Content

Player Ready

Notes
“player has been initialized” independent of any media selection and when the player instance is handed over to us. A player can remain idle waiting for the next event which may or may not happen.

Playing

Supported Media Types
Content

Qualified View

Supported Media Types
Content
Notes
Configure qualified view thresholds by visiting your collector configurations pages from the Collectors page, scroll to the Qualified View setting in the Event Control section. By default, for content, qualified view thresholds are 30 seconds and 60 seconds and, for ads, the qualified view threshold is 5 seconds.

Rendition Change

Supported Media Types
Content

Resume

Supported Media Types
Content

Seek End

Supported Media Types
Content
Notes
This event includes attributes Seek Start Point & Seek End Point to mark the starting & ending points of a seek event.

Seek Start

Supported Media Types
Content

Stall End

Supported Media Types
Content

Stall Start

Supported Media Types
Content

Stop

Supported Media Types
Content
Notes
Notable condition where the `stop` events is not triggered: When playback reaches the end of the content timeline (i.e., the same condition for triggering `playback_complete`), the content session remains open, unaffected by the fact that playback has reached the end of content so if post-roll ads are played or play-head is rewinded afterward, the subsequent events belong to the same content session.

Metadata

Attributes

ABS Shift

Data type
string
Number Type
Not set
Required
true
Permitted Values
value list

Error Code

Data type
string
Number Type
Not set
Required
true

Error Message

Data type
string
Number Type
Not set
Required
true

Milestone Percent

Data type
number
Number Type
Short
Unit
percentage
Required
true

Qualified View Trigger

Data type
number
Number Type
Not set
Unit
seconds
Required
true

Seek End Point

Data type
number
Number Type
Not set
Unit
milliseconds
Required
true

Seek Start Point

Data type
number
Number Type
Not set
Unit
milliseconds
Required
true

Startup Duration - Content

Data type
number
Number Type
Not set
Unit
milliseconds
Required
true

Startup Duration - Total

Data type
number
Number Type
Not set
Unit
milliseconds
Required
true

Video

Asset ID

Data type
string
Number Type
Not set

Duration

Data type
number
Number Type
Double
Unit
seconds

Media Type

Data type
string
Number Type
Not set
Required
true
Permitted Values
value list

Player Height

Data type
number
Number Type
Not set
Unit
pixels

Player Width

Data type
number
Number Type
Not set
Unit
pixels

Source

Data type
string
Number Type
Not set
Permitted Values
URL

Title

Data type
string
Number Type
Not set

CMCD

Content ID (CMCD)

Data type
string
Number Type
Not set

Measured throughput (CMCD)

Data type
number
Number Type
Int
Unit
kbps

Next Object Request (CMCD)

Data type
string
Number Type
Not set

Object Duration (CMCD)

Data type
number
Number Type
Int
Unit
milliseconds

Object Type (CMCD)

Data type
string
Number Type
Not set
Permitted Values
value list

Request ID (CMCD)

Data type
string
Number Type
Not set

Requested Maximum Throughput (CMCD)

Data type
number
Number Type
Int
Unit
kbps

Session ID (CMCD)

Data type
string
Number Type
Not set

Stream Type (CMCD)

Data type
string
Number Type
Not set
Permitted Values
value list

Streaming Format (CMCD)

Data type
string
Number Type
Not set
Permitted Values
value list

Top Bitrate (CMCD)

Data type
number
Number Type
Int
Unit
kbps

Version (CMCD)

Data type
number
Number Type
Short

User

Content Session ID

Data type
string
Number Type
Not set
Required
true
Permitted Values
UUID

Player

Player Name

Data type
string
Number Type
Not set
Required
true

Player Version

Data type
string
Number Type
Not set

Streaming Protocol

Data type
string
Number Type
Not set
Permitted Values
value list

Streaming Type

Data type
string
Number Type
Not set
Permitted Values
value list

Subtitles

Data type
bool
Number Type
Not set
Permitted Values
value list

FluxData

Bandwidth

Device Platforms
Browser,Console,DTV,Mobile

Buffer Duration

Device Platforms
Browser,Console,DTV,Mobile

Buffer Duration - Content

Device Platforms
Browser,Console,DTV,Mobile

Content Session Start Timestamp

Device Platforms
Browser,Console,DTV,Mobile

Current Audio Track

Device Platforms
Browser,Console,DTV,Mobile

Current Subtitles

Device Platforms
Browser,Console,DTV,Mobile

Number of Content Plays

Device Platforms
Browser,Console,DTV,Mobile

Number of Content Requests

Device Platforms
Browser,Console,DTV,Mobile

Number of Errors

Device Platforms
Browser,Console,DTV,Mobile

Number of Errors - Content

Device Platforms
Browser,Console,DTV,Mobile

Pause Duration

Device Platforms
Browser,Console,DTV,Mobile

Pause Duration - Content

Device Platforms
Browser,Console,DTV,Mobile

Playback Duration

Device Platforms
Browser,Console,DTV,Mobile

Playback Duration - Content

Device Platforms
Browser,Console,DTV,Mobile

Player State

Device Platforms
Browser,Console,DTV,Mobile
Permitted Values
value list

Playhead Position

Device Platforms
Browser,Console,DTV,Mobile
Required
true

Rendition Audio Bitrate

Device Platforms
Browser,Console,DTV,Mobile

Rendition Height

Device Platforms
Browser,Console,DTV,Mobile

Rendition Name

Device Platforms
Browser,Console,DTV,Mobile

Rendition Video Bitrate

Device Platforms
Browser,Console,DTV,Mobile

Rendition Width

Device Platforms
Browser,Console,DTV,Mobile

Stall Count

Device Platforms
Browser,Console,DTV,Mobile

Stall Count - Content

Device Platforms
Browser,Console,DTV,Mobile

Stall Duration

Device Platforms
Browser,Console,DTV,Mobile

Stall Duration - Content

Device Platforms
Browser,Console,DTV,Mobile

Time Since Content Request

Device Platforms
Browser,Console,DTV,Mobile

Time Since Content Started

Device Platforms
Browser,Console,DTV,Mobile

Time Since Last Buffer Start - Content

Device Platforms
Browser,Console,DTV,Mobile

Time Since Last Heartbeat

Device Platforms
Browser,Console,DTV,Mobile

Time Since Last Milestone - Ad

Device Platforms
Browser,Console,DTV,Mobile

Time Since Last Milestone - Content

Device Platforms
Browser,Console,DTV,Mobile

Time Since Last Pause

Device Platforms
Browser,Console,DTV,Mobile

Time Since Last Seek Start

Device Platforms
Browser,Console,DTV,Mobile

Time Since Last Stall Start - Content

Device Platforms
Browser,Console,DTV,Mobile

Ad frameworks

Freewheel Ad Framework

Google IMA Ad Framework

Google IMA DAI Ad Framework

MediaTailor Ad Framework

Yospace Ad Framework

Player Default Ad Framework

Adding dependencies to your project

Roku Plugin for Eclipse IDE
For Roku plugin installation and usage in Eclipse IDE
https://sdkdocs.roku.com/display/sdkdoc/Roku+Plugin+for+Eclipse+IDE

Installation Instructions

Clone the latest version of the repository:

git clone https://gitlab.com/datazoom/roku/dz_collector_roku_release.git

Extract the components folder from latest version of the cloned repository

Copy the components folder in your channel project.

We assume that:

  1. The developer had already created a Roku project (in Eclipse IDE).

  2. The project does not have a components folder. If there is already a components folder, then copy the content of the components directory(DzLib folder) into your project's components directory.
    eg: /<your project>/components/DzLib

  3. This project contains the base and native-collector library (inside DzLib folder).

Configuring collector library in channel

Copy the following in MainScene.brs (in components folder) or in the brs file you intend to configure the collector library.
In Sub/function init(), add the following

m.player = m.top.findNode("<Player ID>")
m.DzLib = m.top.findNode("DzLib")
DzCollector()

Once the collector is successfully instantiated we can set desired console log level for the collector instance:

m.DzLib.callFunc("setLogLevel","info")

Valid log levels are: "off", "error", "warning", "info", "debug", or "verbose"

Default log level is set to “warning”

Also add the following function for initializing SDK

Sub DzCollector()
m.DzLib.libConfiguration = {
configURL : "<url given by Datazoom>",
configId: "<configuration id from Datazoom>"
}
m.DzLib.initiateCollector = true
End Sub

DzCollector() will call the above function when initialized.

IMPORTANT!

To confirm Datazoom SDK is successfully initialized and can be safely attached to player and start collecting data or fire custom events you MUST use following callback:

m.DzLib.observeField("connectionSuccess", "datazoomSDKInitialized")

or check following field:

m.DzLib.connectionSuccess '(true/false)

Change the configURL, configId, and <Player ID> as per the requirement.

Copy the following inside <children> in MainScene.xml or in the xml file you intend to configure the collector library.

<DzLib id="DzLib" />

At this point the Datazoom SDK is initialized. We can send Custom Events, Custom Metadata, user data, device data and geo location data.

Custom Events and Custom Metadata

We can set Custom Metadata for the Datazoom SDK independently for the app session and/or for player. Custom Metadata that is set for app session will be available during entire app session if not changed or removed. Custom Metadata that is set for player will be reset with each new player session.

To set Custom Metadata for app session we use following method:

 m.DzLib.callFunc("setDZSessionMeta","DataZoom SESSION Metadata Key", "DataZoom SESSION Metadata Value")
 or
 m.DzLib.callFunc("setDZSessionMeta","AnotherCustomSESSIONMetaKey","AnotherCustomSESSIONMetaValue")
 or
 m.DzLib.callFunc("setDZSessionMeta",{customMetaKeyDict1 : "CustomSESSIONMetaValueDict1", customMetaKeyDict2 : "CustomSESSIONMetaValueDict2", customMetaKeyDictNth : "CustomSESSIONMetaValueDictNth" })

To set Custom Metadata for player session we use following method:

m.DzLib.callFunc("setDZPlayerMeta","DataZoom PLAYER Metadata Key", "DataZoom PLAYER Metadata Value")
or
m.DzLib.callFunc("setDZPlayerMeta","AnotherPLAYERCustomMetaKey","AnotherPLAYERCustomMetaValue")
or
m.DzLib.callFunc("setDZplayerMeta",{customMetaKeyDict1 : "CustomPLAYERMetaValueDict1", customMetaKeyDict2 : "CustomPLAYERMetaValueDict2", customMetaKeyDictNth : "CustomPLAYERMetaValueDictNth" })

Change "CustomMetaKey" and "CustomMetaValue" to any text or variable you want to send to collector service

To read Custom Metadata that are set using previous methods we use following methods:

For session Custom Metadata:

 customSessionMeta = m.DzLib.callFunc("getDZSessionMeta")

For player Custom Metadata:

 customSessionMeta = m.DzLib.callFunc("getDZPlayerMeta")

We delete Custom Metadata that are set for session and player by using this methods:

For session Custom Metadata:

m.DzLib.callFunc("rmDZSessionMeta")

For player Custom Metadata:

m.DzLib.callFunc("rmDZPlayerMeta")

Also, we can send Custom Events to the Datazoom SDK using following methods:

  m.DzLib.callFunc("generateDatazoomEvent","SOME CUSTOM EVENT")

We can also add Custom Metadata to generated Custom Event. Metadata sent using this method will be sent with the custom event only.

m.DzLib.callFunc("generateDatazoomEvent", "SOME CUSTOM EVENT", {customEventMetaKeyDict1 : "CustomEventMetaValueDict1", customEvemtMetaKeyDict2 : "CustomEventMetaValueDict2", customEventMetaKeyDictNth : "CustomEventMetaValueDictNth"})

Now, after we create player instance we can add player to Datazoom SDK
Add the following inside <children> in MainScene.xml or in the xml file you intend to configure the collector library.

<Video id="<Player ID>" />

and your xml file should look like this:

<children>
<DzLib id="DzLib" />
<Video id="<Player ID>" />
</children>

Change <Player ID> as per the requirement.

Now add the following function for initializing player to Datazoom SDK:

Sub DzPlayer()
    m.DzLib.playerInit = {
        player: m.video
    }
    m.DzLib.initiatePlayer = true 
End Sub

DzPlayer() will call the above function when initialized.

Optionally, m.DzLib.playerInit can include a noContentObserver field which, if set to true, will prevent the collector from observing the video node’s content metadata for the purpose of creating content sessions automatically. This may be useful for apps who prefer to manage content sessions explicitly through the setting of m.DzLib.initiatePlayer. The following demonstrates such a use case:

Sub DzPlayer()
    m.DzLib.playerInit = {
        player: m.video,
        noContentObserver: true
    }
    m.DzLib.initiatePlayer = true 
End Sub

At this point Datazoom SDK is fully initialized with player. Selected data points will be collected from player and sent to collector service.

Roku RAF

If Roku RAF is enabled and implemented in your app please use following method to pass CTX object to DZ SDK:

m.DzLib.callFunc("generateAdEvent",adCtx)

You can download Datazoom Roku DEMO app which demonstrates above methods from here :

git clone https://gitlab.com/datazoom/roku/roku-native-demo.git

Follow instructions in provided Readme.md file for importing demo project to Eclipse.

Instructions to create a compiled zip file

  1. Your-Project(Right click) > Export > BrightScript > BrightScript Deployment >[Change File name/path, if needed (.zip)] > Finish

  2. Open browser and go to Roku's local network IP address.(eg: 192.168.0.9). Provide username and password of developer mode.

  3. Click upload and select the newly created zip file. Click install.

  4. The channel will automatically start playing. This channel can also be played by-> go to Roku menu, select the Roku developer channel and play.

  5. To view the data points generated by Roku, go to Linux terminal and type

           telnet <Roku's Local IP> 8085
           eg: - telnet 192.168.0.9 8085