Application collectors
Akamai AMP Media Player
Android collector
The Akamai amp media player is a configuration option for the Android collector by Datazoom that makes the following additional data points automatically collectable in real time.
Data Points
Events
Discrete occurrences driven by user interactions or system actions
Metadata
Attributes
Video
User
Fluxdata
Metrics measuring changing parameters over time
Events
Error
This event fires if a error causes content or ad playback or retrieval of the video to fail.
Supported Media Types |
Content
|
Heartbeat
When configurable interval of time passes during video playback within a content session, or right after video playback is interrupted within a content session.
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 Request
When media type is 'content', this is triggered when playback is invoked. When the media type is 'ad', this is triggered when VAST request is made.
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
When the playhead position plays through a customer configurable percentile milestone of the video's duration (seeking through the milestone does not trigger the event). The event fires no more than once per ad or content session.
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.
|
Playback Complete
When the video player reaches the end of the currently playing content. The event can be triggered multiple times if the user reaches the end of the currently playing content, scrubs back and then reaches the end of the content again.
Supported Media Types |
Content
|
Playback Start
When the video starts playing for the user, also known as "first frame".
Supported Media Types |
Content
|
Stop
Triggered when: 1. A playback error results in the termination of content playback. 2. The context (or the logical equivalent) corresponding to a specific player is destroyed: 2(a). The application may destroy the context when playback is stopped by the user. 2(b). The application may destroy the context after playback has reached the end of content (and the player isn’t going to be reused any further). 2(c). The collector (in certain cases) may be able to detect when the application is terminated (e.g., user closes the browser tab) and destroy all player contexts automatically. 3. If a change in the content URL is detected by the collector, a new content session should begin and a `stop` event should be triggered for the previous content session.
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
User
Content Session ID
A unique id for the current video playback session.
Data type |
string
|
Number Type |
Not set
|
Required |
true
|
Permitted Values |
UUID
|
Video
Duration
The length of VOD content or ad media. Value is absent for live content.
Data type |
number
|
Number Type |
Double
|
Unit |
seconds
|
Media Type
Whether the event relates to an Ad or Content asset.
Data type |
string
|
Number Type |
Not set
|
Required |
true
|
Permitted Values |
value list
|
Title
The title of the content as reported by the media player.
Data type |
string
|
Number Type |
Not set
|
Attributes
Error Code
Error code emitted by the player
Data type |
string
|
Number Type |
Not set
|
Required |
true
|
Error Message
Error message emitted by the player
Data type |
string
|
Number Type |
Not set
|
Required |
true
|
Heartbeat Count
Count of Heartbeat events per content session.
Data type |
number
|
Number Type |
Int
|
Unit |
count
|
Required |
true
|
Milestone Percent
The point represented by the customer configurable percentage relative to the duration. Attribute of the Milestone event.
Data type |
number
|
Number Type |
Short
|
Unit |
percentage
|
Required |
true
|
Player
Player Name
The name of the media player.
Data type |
string
|
Number Type |
Not set
|
Required |
true
|
Player Version
The version of the media player.
Data type |
string
|
Number Type |
Not set
|
Streaming Type
Whether the content is Live, VOD or DVR as reported by the media player.
Data type |
string
|
Number Type |
Not set
|
Permitted Values |
value list
|
FluxData
Bandwidth
Estimated network bandwidth as derived from the player
Device Platforms |
Browser,Console,DTV,Mobile
|
Playback Duration - Content
Cumulative playback time where media type equals 'content' during the current content session regardless of playback rate, excluding stalls, buffers or pauses.
Device Platforms |
Browser,Console,DTV,Mobile
|
Playhead Position
The point in the video timeline in seconds.
Device Platforms |
Browser,Console,DTV,Mobile
|
Required |
true
|
Time Since Content Request
Time since "Media Request" event where "Media Type" equals "content"
Device Platforms |
Browser,Console,DTV,Mobile
|
Time Since Content Started
Time since "Playback Start" event where "Media Type" equals "content"
Device Platforms |
Browser,Console,DTV,Mobile
|
Time Since Last Heartbeat
Time since last "Heartbeat" event for the current content session.
Device Platforms |
Browser,Console,DTV,Mobile
|
Ad frameworks
Freewheel Ad Framework
Google IMA Ad Framework
Google IMA DAI Ad Framework
Player Default Ad Framework
MediaTailor Ad Framework
Yospace Ad Framework
Adding dependencies to your project
This library uses the amp-core library from Akamai Premier releases:
AMP for Devices - Premier: Android Build 9.9.6 (https://mdtp-a.akamaihd.net/amp-android-sdk/premier )
Add the following maven repository URL in your project's build.gradle file Add the following dependency in your project's build.gradle file's dependencies block Lib - AkamaiGoldCollector Add following compile options if you don't have it already Append the following rules to the Add AMP Core library to your project The Datazoom collector library uses the amp-core library for data collection. Add the following additional dependencies to your project Use the following code snippet to add AkamaiPlayerCollector to your project. The following code snippet illustrates the usage of the AkamaiPlayer collector. Open demo application's After the player is done playing a content, invoke the collector’s CUSTOM EVENTS & METADATA Datazoom allows customers to collect custom events and metadata that don't originate from a video player. Custom Metadata Create a JSONArray with necessary metadata Add the metadata to DZEventCollector Example: Custom Events Create an Event object Add the event to DZEventCollector Example: Add the following dependencies in your project's build.gradle file's dependencies block. Setup Google IMA Ad listener. Add the freewheel manager libraries from Akamai Premier releases to your project. Setup the Freewheel Manager listener.// Snapshot Repository
maven {
url 'https://gitlab.com/api/v4/projects/18323233/packages/maven'
}
// Release Repository
maven {
url 'https://gitlab.com/api/v4/projects/10353305/packages/maven'
}
dependencies {
implementation 'com.datazoom.android:base-collector-gold:3.6.4'
implementation 'com.datazoom.android:akamai-gold-collector:2.3.1'
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
proguard-rules
files, if you are using them in your app-keep class com.dz.collector.android.model.SuccessfulServerResponse**
-keepclassmembers class com.dz.collector.android.model.SuccessfulServerResponse* {;}
We've excluded the amp-core library from the collector library for customer convenience.
The version and link to download the core library is: AMP for Devices - Premier: Android Build 9.9.6 (https://mdtp-a.akamaihd.net/amp-android-sdk/premier)dependencies {
implementation 'com.google.guava:guava:27.1-android'
}
MainActivity.java
to see a running example.String configId = "<configuration id from Datazoom>";
String configUrl = "<url given by Datazoom>";
AkamaiPlayerCollector akamaiPlayerCollector = AkamaiPlayerCollector.create(videoPlayerView, MainActivity.this);
akamaiPlayerCollector.setConfig(new DatazoomConfig(configId, configUrl))
.connect(new DZBeaconConnector.ConnectionListener() {
public void onSuccess(DZEventCollector dzEventCollector) {
//Everything is setup, collector initialization complete.
}
public void onError(Throwable t) {
//Error while creating akamai player collector
//showAlert("Error", "Error while creating AkamaiPlayerCollector, error:" + t.getMessage());
}
});
releasePlayer()
method to stop data collection for the player. Later if the same or a different play instance is used to play contents again, invoke the collector’s setPlayer()
method to start data collection.// when content playing is done (completed or aborted)
akamaiPlayerCollector.releasePlayer();
...
// before requesting content playback again
akamaiPlayerCollector.setPlayer(videoPlayerView);
JSONArray metadata = new JSONArray( "[{\"customMetadata\": \"MetadataValue\"}]");
DZEventCollector.setCustomMetadata(metadata);
String configId = "<configuration id from Datazoom>";
String configUrl = "<url given by Datazoom>";
//Setup CustomMetadata here
try {
DZEventCollector.setCustomMetadata(new JSONArray("[{\"customPlayerName\": \"Akamai Player\"},{\"customDomain\": \"devplatform.io\"}] "));
} catch (JSONException e) {
e.printStackTrace();
}
AkamaiPlayerCollector.create(videoPlayerView, MainActivity.this)
.setConfig(new DatazoomConfig(configId, configUrl))
.connect(new DZBeaconConnector.ConnectionListener() {
public void onSuccess(DZEventCollector dzEventCollector) {
}
public void onError(Throwable t) {
}
});
Event event = new Event("Custom_Event_Name", new JSONArray());
The first constructor parameter is the event name, and the second is a list of custom metadata to be included in the event.dzEventCollector.addCustomEvent(event);
@Override
public void onSuccess(DZEventCollector dzEventCollector) {
Event event = new Event("SDKLoaded", new JSONArray());
dzEventCollector.addCustomEvent(event);
btnPush.setOnClickListener(v - > {
try {
Event event1 = new Event("buttonClick", new JSONArray("[{\"customakamaiPlay\": \"true\"}, {\"customakamaiPause\": \"true\"}] "));
dzEventCollector.addCustomEvent(event1);
} catch (JSONException e) {
e.printStackTrace();
}
});
}
Google IMA Ad Integration
dependencies {
implementation 'com.datazoom.android:plugin-google-ima:4.39.0'
api 'com.google.ads.interactivemedia.v3:interactivemedia:3.10.7'
}
After the collector initialization call this method.
private void setupAdListeners(final DZEventCollector dzEventCollector) {
if (adsManager != null) {
adsManager.addAdEventListener((AdEvent.AdEventListener)
dzEventCollector.adListener());
}
}
Sample code :- https://gitlab.com/datazoom/mobile-android-group/mobile-android-akamai-demo/-/tree/Plugin-Google-IMA Customers Using Freewheel Ads
After the collector initialization call this method @Override
public void onSuccess(DZEventCollector dzEventCollector) {
if (freewheelManager != null) {
freewheelManager.addEventsListener((IAdsComponentListener) dzEventCollector);
}
}