The VASTTracker
class provides methods to track the execution of an Ad.
At key points during ad playback you will need to call thoses methods to fire corresponding tracking elements.
The constructor signature is:
constructor(client, ad, creative, variation = null, muted = false)
client: VASTClient
- An optional instance of VASTClient that can be updated by the tracker.ad: Ad
- The ad to trackcreative: Creative
- The creative to trackvariation: CompanionAd|NonLinearAd
- An optional variation of the creative, for Companion and NonLinear Adsmuted: Boolean
- The initial muted state of the video. (optional,false
by default)
To get an instance of VASTTracker
, simply import it and create one using the constructor:
import {
VASTClient,
VASTTracker
} from 'vast-client'
// With a client instance
const vastClient = new VASTClient();
const vastTracker = new VASTTracker(vastClient, ad, creative);
// For a companion ad
const vastTracker = new VASTTracker(vastClient, ad, creative, companion);
// With the initial muted state
const vastTracker = new VASTTracker(vastClient, ad, creative, null, muted);
// Without a client instance
const vastTracker = new VASTTracker(null, ad, creative);
VASTTracker
extends a custom EventEmitter
, therefore is possible to add event listeners like this:
vastTracker.on('exitFullscreen', () => {
// Deal with the event
});
Event | Description | Payload |
---|---|---|
acceptInvitation |
Emitted when calling acceptInvitation() |
{ trackingURLTemplates: Array<String> } |
adCollapse |
Emitted when calling adCollapse() |
{ trackingURLTemplates: Array<String> } |
adExpand |
Emitted when calling adExpand() |
{ trackingURLTemplates: Array<String> } |
clickthrough |
Emitted when calling click() if there is at least one <clickThroughURLTemplate> element. A URL will be passed as a data |
String |
close |
Only for non-linear ads, emitted when close() is called |
{ trackingURLTemplates: Array<String> } |
closeLinear |
Only for linear ads, emitted when close() is called |
{ trackingURLTemplates: Array<String> } |
collapse |
Emitted when calling setExpand(expanded) and changing the expand state from true to false |
{ trackingURLTemplates: Array<String> } |
complete |
Only for linear ads with a duration. Emitted after complete() has been called. |
{ trackingURLTemplates: Array<String> } |
creativeView |
Emitted when trackImpression() is called. |
{ trackingURLTemplates: Array<String> } |
exitFullscreen |
Emitted when calling setFullscreen(fullscreen) and changing the fullscreen state from true to false |
{ trackingURLTemplates: Array<String> } |
expand |
Emitted when calling setExpand(expanded) and changing the expand state from false to true |
{ trackingURLTemplates: Array<String> } |
firstQuartile |
Only for linear ads with a duration. Emitted when the adunit has reached 25% of its duration | { trackingURLTemplates: Array<String> } |
fullscreen |
Emitted when calling setFullscreen(fullscreen) and changing the fullscreen state from false to true |
{ trackingURLTemplates: Array<String> } |
loaded |
Only for linear ad. Emitted when calling load() |
{ trackingURLTemplates: Array<String> } |
midpoint |
Only for linear ads with a duration. Emitted when the adunit has reached 50% of its duration | { trackingURLTemplates: Array<String> } |
minimize |
Emitted when calling minimize() |
{ trackingURLTemplates: Array<String> } |
mute |
Emitted when calling setMuted(muted) and changing the mute state from false to true |
{ trackingURLTemplates: Array<String> } |
notUsed |
Emitted when calling notUsed() .This is a terminal event; no other tracking events are sent when this is used |
{ trackingURLTemplates: Array<String> } |
otherAdInteraction |
Emitted when calling otherAdInteraction() |
{ trackingURLTemplates: Array<String> } |
overlayViewDuration |
Emitted when calling overlayViewDuration() |
{ trackingURLTemplates: Array<String> } |
pause |
Emitted when calling setPaused(paused) and changing the pause state from false to true |
{ trackingURLTemplates: Array<String> } |
playerCollapse |
Emitted when calling setExpand(false) is called. This event replaces the exitFullscreen event in VAST 4.1 |
{ trackingURLTemplates: Array<String> } |
playerExpand |
Emitted when calling setExpand(true) is called. This event replaces the fullscreen event in VAST 4.1 |
{ trackingURLTemplates: Array<String> } |
progress-[0-100]% |
Only for linear ads with a duration. Emitted on every setProgress(duration) calls, where [0-100] is the adunit percentage completion |
{ trackingURLTemplates: Array<String> } |
progress-[currentTime] |
Only for linear ads with a duration. Emitted on every setProgress(duration) calls, where [currentTime] is the adunit current time |
{ trackingURLTemplates: Array<String> } |
resume |
Emitted when calling setPaused(paused) and changing the pause state from true to false |
{ trackingURLTemplates: Array<String> } |
rewind |
Emitted when setProgress(duration) is called with a smaller duration than the previous one |
{ trackingURLTemplates: Array<String> } |
skip |
Emitted when calling skip() |
{ trackingURLTemplates: Array<String> } |
skip-countdown |
Only for linear ads with a duration. Emitted on every setProgress(duration) calls, the updated countdown will be passed as a data |
Number |
start |
Only for linear ads with a duration. Emitted on the 1st non-null setProgress(duration) call |
{ trackingURLTemplates: Array<String> } |
thirdQuartile |
Only for linear ads with a duration. Emitted when the adunit has reached 75% of its duration | { trackingURLTemplates: Array<String> } |
unmute |
Emitted when calling setMuted(muted) and changing the mute state from true to false |
{ trackingURLTemplates: Array<String> } |
verificationNotExecuted |
Emitted when calling verificationNotExecuted() |
{ trackingURLTemplates: Array<String> } |
VAST tracking is implemented using a number of individual tracking elements that map to
video events. To trigger a tracker you will need to call the corresponding VASTTracker
public method please refer to below table to see the mapping and method definitions for more details.
Method name | VAST element(s) |
---|---|
error | <Error> |
load | <Tracking event="loaded"> |
complete | <Tracking event="complete"> |
click | <ClickTracking> |
close | <Tracking event="close"> , <Tracking event="closeLinear"> |
skip | <Tracking event="skip"> |
setExpand | <Tracking event="playerExpand"> ,<Tracking event="playerCollapse"> |
setFullscreen | <Tracking event="fullscreen"> , <Tracking event="exitFullscreen"> |
setMuted | <Tracking event="mute"> , <Tracking event="mute"> |
setPaused | <Tracking event="pause"> |
setProgress | <Tracking event="start"> , <Tracking event="firstQuartile"> , <Tracking event="midpoint"> , <Tracking event="thirdQuartile"> , <Tracking event="progress"> , <Tracking event="rewind"> |
trackImpression | <Impression> , <Tracking event="creativeView"> |
notUsed | <Tracking event="notUsed"> |
otherAdInteraction | <Tracking event="otherAdInteraction"> |
acceptInvitation | <Tracking event="acceptInvitation"> |
adExpand | <Tracking event="adExpand"> |
adCollapse | <Tracking event="adCollapse"> |
minimize | <Tracking event="minimize"> |
overlayViewDuration | <Tracking event="overlayViewDuration"> |
verificationNotExecuted | <Tracking event="verificationNotExecuted"> |
trackViewableImpression | <Viewable> |
trackNotViewableImpression | <NotViewable> |
trackUndeterminedImpression | <ViewUndetermined> |
Ad servers and other entities need access to additional data from the publisher to meet client needs for a clearer view into the details of how and where their video is being shown. This is done through the use of macros.
The list of supported macros is in the file macros.js. The following macro value will be set automatically by vast-client if it exists in the tracking url:
- CACHEBUSTING
- TIMESTAMP
- ADPLAYHEAD
- ASSETURI
- PODSEQUENCE
- UNIVERSALADID
- ADTYPE
- ADSERVINGID
- ADCATEGORIES
For any others supported macros, they need to be passed as a parameter when calling tracking methods and must exists in tracking url to be replaced.
If a macro is not passed as param but exist in the tracking url and is supported it will be replaced with -1
as specified by iAB.
Considering having the following tracker in the VAST xml
<Tracking event="skip"><![CDATA[https://example.com/tracking/skip?d=[DOMAIN]&adcount=[ADCOUNT]&podseq=[PODSEQUENCE]&contentplayhead=[CONTENTPLAYHEAD]&mediaplayhead=[MEDIAPLAYHEAD]playerstate=[PLAYERSTATE]]]></Tracking>
Call the vastTracker method with specified macros and values
const macrosParam = {
CONTENTURI: 'https://mycontentserver.com/video.mp4',
ADCOUNT: 2,
CONTENTPLAYHEAD: vastTracker.convertToTimecode(120),
MEDIAPLAYHEAD: vastTracker.convertToTimecode(120)
}
vastTracker.skip(macrosParam);
Macros will be replaced and the skip tracking URL will be called with the following URL:
https://example.com/tracking/skip?curi=https%3A%2F%2Fmycontentserver.com%2Fvideo.mp4&adcount=2&podseq=1&contentplayhead=00:02:00.000&mediaplayhead=00:02:00.000&playerstate=-1
Send a request to the URI provided by the VAST element. macros
is an optional Object containing macros and their values to be used and replaced in the tracking calls.
Pass isCustomCode
as true only if you want to use a custom code for the [ERRORCODE]
macro. If false, and a value is provided for [ERRORCODE]
macro the macro will be replaced in the tracking call only if the code is a number between 100 and 999 (see https://gist.github.com/rhumlover/5747417). Otherwise 900 will be used.
macros : Object
- An optional Object containing macros and their values to be used and replaced in the tracking calls.isCustomCode: Boolean
- Flag to allow custom values on error code.
const customCode = '405';
const macrosParam = {
CONTENTURI: 'https://mycontentserver.com/video.mp4',
ERRORCODE : customCode
}
// Bind error listener to the player
player.on('error', () => {
vastTracker.error(macrosParam);
});
errorWithCode(errorCode, isCustomCode) : ⚠️ This method is deprecated in favor of the error method
Sends a request to the URI provided by the VAST <Error>
element. If an [ERRORCODE]
macro is included, it will be substituted with errorCode
. isCustomCode
and its value are related to [ERRORCODE]
. Pass isCustomCode
as true only if you want to use a custom code for the [ERRORCODE]
macro. If false, and a value is provided for [ERRORCODE]
macro the macro will be replaced in the tracking call only if the code is a number between 100 and 999 (see https://gist.github.com/rhumlover/5747417). Otherwise 900 will be used.
errorCode: String
- Replaces[ERRORCODE]
macro.[ERRORCODE]
values are listed in the VAST specificationisCustomCode: Boolean
- Flag to allow custom values on error code.
const MEDIAFILE_PLAYBACK_ERROR = '405';
// Bind error listener to the player
player.on('error', () => {
vastTracker.errorWithCode(MEDIAFILE_PLAYBACK_ERROR);
});
Must be called when the player considers that it has loaded and buffered the creative’s media and assets either fully or to the extent that it is ready to play the media.
macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
loaded
// Bind ended listener to the player
player.on('loaded', () => {
vastTracker.load();
});
vastTracker.on('loaded', () => {
// loaded tracking URLs have been called
});
Must be called when the user watched the linear creative until its end. Calls the complete tracking URLs.
macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
complete
// Bind ended listener to the player
player.on('ended', () => {
vastTracker.complete();
});
vastTracker.on('complete', () => {
// complete tracking URLs have been called
});
Must be called when the user clicks on the creative. Calls the tracking URLs.
-
macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification. -
fallbackClickThroughURL: String
Optional parameter. A clickThroughURL template that could be used as a fallback
clickthrough
// Bind click listener to the player
player.on('click', () => {
vastTracker.click();
});
vastTracker.on('clickthrough', url => {
// Open the resolved clickThrough url
document.location.href = url;
});
Must be called when the player or the window is closed during the ad. Calls the closeLinear
(in VAST 3.0) and close
tracking URLs
macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
closeLinear
close
// When user exits the page
window.onbeforeunload = () => {
vastTracker.close();
};
// event for VAST 3.0 linear ads
vastTracker.on('closeLinear', () => {
// ...
});
// event for VAST 2.0 linear ads or companion ads
vastTracker.on('close', () => {
// ...
});
Must be called when the skip button is clicked. Calls the skip tracking URLs.
macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
skip
// Bind click listener to the skip button
skipButton.on('click', () => {
vastTracker.skip();
});
vastTracker.on('skip', () => {
// skip tracking URLs have been called
});
Sets the duration of the ad and updates the quartiles based on that.
duration: Number
- The duration of the ad
Updates the expand state and calls the expand/collapse as well as playerExpand/playerCollapse for VAST 4.1. tracking URLs.
expanded: Boolean
- Indicates if the video is expanded or notmacros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
expand
playerExpand
collapse
playerCollapse
// Sample function for a button that increase/decrease player size
let playerExpanded = false;
expandButton.addEventListener('click', e => {
playerExpanded = !playerExpanded
if (playerExpanded) {
increasePlayerSize()
} else {
decreasePlayerSize()
}
vastTracker.setExpand(playerExpanded);
});
vastTracker.on('expand', () => {
// expand tracking URLs have been called
});
vastTracker.on('collapse', () => {
// collapse tracking URLs have been called
});
Updates the fullscreen state and calls the fullscreen tracking URLs.
fullscreen: Boolean
- Indicates if the video is in fulscreen mode or notmacros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
fullscreen
exitFullscreen
// Bind fullscreenchange listener to the player
// Note that the fullscreen API is still vendor-prefixed in browsers
player.addEventListener('fullscreenchange', e => {
const isFullscreen = !!document.fullscreenElement;
vastTracker.setFullscreen(isFullscreen);
});
vastTracker.on('fullscreen', () => {
// fullscreen tracking URLs have been called
});
vastTracker.on('exitFullscreen', () => {
// exitFullscreen tracking URLs have been called
});
Updates the mute state and calls the mute/unmute tracking URLs.
⚠️ setMuted is relying on an internal mute state, which isunmuted
by default. If the initial mute state ismuted
, be sure to set it up when initializing the VASTTracker. Otherwise, the first unmute event will not be fired.
muted: Boolean
- Indicates if the video is muted or notmacros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
mute
unmute
// Bind a volumechange listener to the player
player.addEventListener('volumechange', e => {
vastTracker.setMuted(e.target.muted);
});
vastTracker.on('mute', () => {
// mute tracking URLs have been called
});
vastTracker.on('unmute', () => {
// unmute tracking URLs have been called
});
Update the pause state and call the resume/pause tracking URLs.
paused: Boolean
- Indicates if the video is paused or notmacros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
pause
resume
// Bind play/pause listeners to the player
player.addEventListener('play', () => vastTracker.setPaused(false) );
player.addEventListener('pause', () => vastTracker.setPaused(true) );
vastTracker.on('resume', () => {
// resume tracking URLs have been called
});
vastTracker.on('pause', () => {
// pause tracking URLs have been called
});
Sets the duration of the ad and updates the quartiles based on that. This is required for tracking time related events such as start
, firstQuartile
, midpoint
, thirdQuartile
or rewind
.
progress: Number
- Current playback time in secondsmacros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
start
skip-countdown
progress-[0-100]%
progress-[currentTime]
rewind
midpoint
firstQuartile
thirdQuartile
// Bind a timeupdate listener to the player
player.addEventListener('timeupdate', e => {
vastTracker.setProgress(e.target.currentTime);
});
vastTracker.on('firstQuartile', () => {
// firstQuartile tracking URLs have been called
});
Must be called if you want to overwrite the <Linear> Skipoffset
value. This will init the skip countdown duration. Then, every time setProgress()
is called, it will decrease the countdown and emit a skip-countdown
event with the remaining time.
Do not call this method if you want to keep the original Skipoffset
value.
duration: Number
- The time in seconds until the skip button is displayed
// Overwrite linear Skipoffset value – 5s countdown
vastTracker.setSkipDelay(5);
Reports the impression URI. Can only be called once. Will report the following URI:
- All
<Impression>
URI from the<InLine>
and<Wrapper>
tracking elements. - The
creativeView
URI from the<Tracking>
events
macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
creativeView
// Bind canplay listener to the player
player.on('canplay', () => {
vastTracker.trackImpression();
});
vastTracker.on('creativeView', () => {
// impression tracking URLs have been called
});
Reports the viewable impression URI. Will report the following URI:
- All
<Viewable>
URI from the<InLine>
and<Wrapper>
tracking elements
This method should be used when the ad meets criteria for Viewable impression as described in MRC Viewable Ad Impression Guidelines
-
macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
// Use case where the ad meet the IAB viewable criteria
if(isAdViewable){
vastTracker.trackViewableImpression()
}
Reports the NotViewable impression URI. Will report the following URI:
- All
<NotViewable>
URI from the<InLine>
and<Wrapper>
tracking elements
This method should be used when the ad meets criteria for NotViewable impression as described in MRC Viewable Ad Impression Guidelines
-
macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
// Use case where the ad meet the IAB viewable criteria
if(!isAdViewable){
vastTracker.trackNotViewableImpression();
}
Reports the ViewUndetermined impression URI. Will report the following URI:
- All
<ViewUndetermined>
URI from the<InLine>
and<Wrapper>
tracking elements
This method should be used when the ad meets criteria for ViewUndetermined impression as described in MRC Viewable Ad Impression Guidelines
-
macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
// Use case where the ad meet the IAB viewable criteria
if(isViewUndetermined){
vastTracker.trackUndeterminedImpression();
}
Must be called if the ad was not and will not be played (e.g. it was prefetched for a particular ad break but was not chosen for playback). This allows ad servers to reuse an ad earlier than otherwise would be possible due to budget/frequency capping. Player support is optional and if implemented is provided on a best effort basis as it is not technically possible to fire this event for every unused ad (e.g. when the player itself is terminated before playback). This is a terminal event; no other tracking events should be sent when this is used.
Calls the notUsed tracking URLs.
macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
notUsed
vastTracker.on('notUsed', () => {
// notUsed tracking URLs have been called
});
// Called notUsed if the ad was not and will not be played.
vastTracker.notUsed();
An optional metric that can capture all other user interactions under one metric such as hover-overs, or custom clicks. It should NOT replace clickthrough events or other existing events like mute, unmute, pause, etc.
Calls the otherAdInteraction tracking URLs.
macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
otherAdInteraction
// Bind mouseover listener to the player
player.addEventListener('mouseover', () => vastTracker.otherAdInteraction() );
vastTracker.on('otherAdInteraction', () => {
// otherAdInteraction tracking URLs have been called
});
The user clicked or otherwise activated a control used to pause streaming content, which either expands the ad within the player’s viewable area or “takes-over” the streaming content area by launching an additional portion of the ad. An ad in video format ad is usually played upon acceptance, but other forms of media such as games, animation, tutorials, social media, or other engaging media are also used.
Calls the acceptInvitation tracking URLs.
macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
acceptInvitation
// Bind click listener to the invitation button
invitationButton.on('click', () => {
vastTracker.acceptInvitation();
});
vastTracker.on('acceptInvitation', () => {
// acceptInvitation tracking URLs have been called
});
The user activated a control to expand the creative.
Calls the adExpand tracking URLs.
macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
adExpand
// Bind click listener to the ad expand button
adExpandButton.on('click', () => {
vastTracker.adExpand();
});
vastTracker.on('adExpand', () => {
// adExpand tracking URLs have been called
});
The user activated a control to reduce the creative to its original dimensions.
Calls the adCollapse tracking URLs.
macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
adCollapse
// Bind click listener to the ad collapse button
adCollapseButton.on('click', () => {
vastTracker.adCollapse();
});
vastTracker.on('adCollapse', () => {
// adCollapse tracking URLs have been called
});
The user clicked or otherwise activated a control used to minimize the ad to a size smaller than a collapsed ad but without fully dispatching the ad from the player environment. Unlike a collapsed ad that is big enough to display it’s message, the minimized ad is only big enough to offer a control that enables the user to redisplay the ad if desired.
Calls the minimize tracking URLs.
macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
minimize
// Bind click listener to the ad collapse button
minimizeButton.on('click', () => {
vastTracker.minimize();
});
vastTracker.on('minimize', () => {
// minimize tracking URLs have been called
});
Converts given seconds into a VAST compliant timecode (Format: HH:MM:SS.sss
). Useful for passing in a proper duration
as timecode to overlayViewDuration
or setting MEDIAPLAYHEAD
or CONTENTPLAYHEAD
as macro.
timeInSeconds: Number
- A time in seconds
timecode: String
- The given seconds converted to timecode
The time that the initial ad is displayed. This time is based on the time between the impression and either the completed length of display based on the agreement between transactional parties or a close, minimize, or accept invitation event. The macro [ADPLAYHEAD] will be replaced with given duration value.
Calls the overlayViewDuration tracking URLs.
duration: String
- The time that the initial ad is displayed as timecode (Format:00:00:00.000
, usevastTracker.convertToTimecode
to convert a duration in seconds to a valid ADPLAYHEAD timecode)macros: Object
- Optional parameter. Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
overlayViewDuration
vastTracker.on('overlayViewDuration', () => {
// overlayViewDuration tracking URLs have been called
});
// Trigger the overlayViewDuration event, and call tracking URLs
vastTracker.overlayViewDuration();
Must be called if the player did not or was not able to execute the provided verification code.The [REASON] macro must be filled with reason code. Reason code values can be found in the VAST specification.
Calls the verificationNotExecuted trackings URLs.
vendor: String
An identifier for the verification vendor. The recommended format is [domain]-[useCase], to avoid name collisions. For example, "company.com-omid".macros: Object
- Object containing macros and their values to be replaced. Macros must be supported by VAST specification.
verificationNotExecuted
vastTracker.on('verificationNotExecuted', () => {
// verificationNotExecuted tracking URLs have been called
});
const vendor = "company.com-omid"
// Trigger the verificationNotExecuted event, and call tracking URLs
vastTracker.verificationNotExecuted(vendor, {REASON: 3});
Calls the tracking URLs for the given eventName and emits the event.
eventName: String
- The event namemacros: Object
- An optional Object of macros to be used in the tracking calls.once: Boolean
- An optional Boolean to define if the event has to be tracked only once. Set tofalse
by default
given eventName
// Track the tracking URLs for skip event
vastTracker.track('skip', { macros });
These methods documentation is provided in order to make the tracker internal logic clearer. It should not be considered as part of the class public API.
Calls the tracking urls templates with the given macros. Also automatically replaces the deducted value for following macros:
- CACHEBUSTING
- TIMESTAMP
- ADPLAYHEAD
- ASSETURI
- PODSEQUENCE
- UNIVERSALADID
- ADTYPE
- ADSERVINGID
- ADCATEGORIES
- BLOCKEDADCATEGORIES
URLTemplates: Array<String|Object>
- An array of tracking url templates.macros: Object
- An optional Object of macros to be used in the tracking calls.option: Object
- An optional Object of options to be used in the tracking calls.