Metrics Module


Version Metrics 1.3.0

Table of Contents

Usage

To use the Metrics module, you can import it into your project from the Firebolt SDK:

import { Metrics } from '@firebolt-js/sdk'

Overview

Methods for sending metrics

Methods

action

Inform the platform of something not covered by other Metrics APIs.

function action(
  category: string,
  type: string,
  parameters: FlatMap,
): Promise<boolean>

Parameters:

Param Type Required Description
category string true The category of action being logged. Must be ‘user’ for user-initated actions or ‘app’ for all other actions
values: 'user' \| 'app'
type string true A short, indexible identifier for the action, e.g. ‘SignIn Prompt Displayed’
maxLength: 256
parameters FlatMap false  

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:general

Examples

Send foo action

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.action('user', 'The user did foo', null)
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.action",
  "params": {
    "category": "user",
    "type": "The user did foo"
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

appInfo

Inform the platform about an app’s build info.

function appInfo(build: string): Promise<null>

Parameters:

Param Type Required Description
build string true The build / version of this app.

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:general

Examples

Send appInfo metric

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let result = await Metrics.appInfo('1.2.2')
console.log(result)

Value of result:

null
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.appInfo",
  "params": {
    "build": "1.2.2"
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": null
}

error

Inform the platform of an error that has occured in your app.

function error(
  type: ErrorType,
  code: string,
  description: string,
  visible: boolean,
  parameters: FlatMap,
): Promise<boolean>

Parameters:

Param Type Required Description
type ErrorType true The type of error
values: 'network' \| 'media' \| 'restriction' \| 'entitlement' \| 'other'
code string true an app-specific error code
description string true A short description of the error
visible boolean true Whether or not this error was visible to the user.
parameters FlatMap false Optional additional parameters to be logged with the error

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:general

Examples

Send error metric

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.error(
  'media',
  'MEDIA-STALLED',
  'playback stalled',
  true,
  null,
)
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.error",
  "params": {
    "type": "media",
    "code": "MEDIA-STALLED",
    "description": "playback stalled",
    "visible": true
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

mediaEnded

Called when playback has stopped because the end of the media was reached.

function mediaEnded(entityId: string): Promise<boolean>

Parameters:

Param Type Required Description
entityId string true The entityId of the media.

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:media

Examples

Send ended metric.

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.mediaEnded('345')
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.mediaEnded",
  "params": {
    "entityId": "345"
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

mediaLoadStart

Called when setting the URL of a media asset to play, in order to infer load time.

function mediaLoadStart(entityId: string): Promise<boolean>

Parameters:

Param Type Required Description
entityId string true The entityId of the media.

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:media

Examples

Send loadstart metric.

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.mediaLoadStart('345')
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.mediaLoadStart",
  "params": {
    "entityId": "345"
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

mediaPause

Called when media playback will pause due to an intentional pause operation.

function mediaPause(entityId: string): Promise<boolean>

Parameters:

Param Type Required Description
entityId string true The entityId of the media.

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:media

Examples

Send pause metric.

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.mediaPause('345')
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.mediaPause",
  "params": {
    "entityId": "345"
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

mediaPlay

Called when media playback should start due to autoplay, user-initiated play, or unpausing.

function mediaPlay(entityId: string): Promise<boolean>

Parameters:

Param Type Required Description
entityId string true The entityId of the media.

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:media

Examples

Send play metric.

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.mediaPlay('345')
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.mediaPlay",
  "params": {
    "entityId": "345"
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

mediaPlaying

Called when media playback actually starts due to autoplay, user-initiated play, unpausing, or recovering from a buffering interuption.

function mediaPlaying(entityId: string): Promise<boolean>

Parameters:

Param Type Required Description
entityId string true The entityId of the media.

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:media

Examples

Send playing metric.

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.mediaPlaying('345')
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.mediaPlaying",
  "params": {
    "entityId": "345"
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

mediaProgress

Called every 60 seconds as media playback progresses.

function mediaProgress(
  entityId: string,
  progress: MediaPosition,
): Promise<boolean>

Parameters:

Param Type Required Description
entityId string true The entityId of the media.
progress MediaPosition true Progress of playback, as a decimal percentage (0-0.999) for content with a known duration, or an integer number of seconds (0-86400) for content with an unknown duration.

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:media

Examples

Send progress metric.

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.mediaProgress('345', 0.75)
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.mediaProgress",
  "params": {
    "entityId": "345",
    "progress": 0.75
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

mediaRateChange

Called when the playback rate of media is changed.

function mediaRateChange(entityId: string, rate: number): Promise<boolean>

Parameters:

Param Type Required Description
entityId string true The entityId of the media.
rate number true The new playback rate.

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:media

Examples

Send ratechange metric.

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.mediaRateChange('345', 2)
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.mediaRateChange",
  "params": {
    "entityId": "345",
    "rate": 2
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

mediaRenditionChange

Called when the playback rendition (e.g. bitrate, dimensions, profile, etc) is changed.

function mediaRenditionChange(
  entityId: string,
  bitrate: number,
  width: number,
  height: number,
  profile: string,
): Promise<boolean>

Parameters:

Param Type Required Description
entityId string true The entityId of the media.
bitrate number true The new bitrate in kbps.
width number true The new resolution width.
height number true The new resolution height.
profile string false A description of the new profile, e.g. ‘HDR’ etc.

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:media

Examples

Send renditionchange metric.

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.mediaRenditionChange(
  '345',
  5000,
  1920,
  1080,
  'HDR+',
)
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.mediaRenditionChange",
  "params": {
    "entityId": "345",
    "bitrate": 5000,
    "width": 1920,
    "height": 1080,
    "profile": "HDR+"
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

mediaSeeked

Called when a seek is completed during media playback.

function mediaSeeked(
  entityId: string,
  position: MediaPosition,
): Promise<boolean>

Parameters:

Param Type Required Description
entityId string true The entityId of the media.
position MediaPosition true Resulting position of the seek operation, as a decimal percentage (0-0.999) for content with a known duration, or an integer number of seconds (0-86400) for content with an unknown duration.

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:media

Examples

Send seeked metric.

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.mediaSeeked('345', 0.51)
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.mediaSeeked",
  "params": {
    "entityId": "345",
    "position": 0.51
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

mediaSeeking

Called when a seek is initiated during media playback.

function mediaSeeking(entityId: string, target: MediaPosition): Promise<boolean>

Parameters:

Param Type Required Description
entityId string true The entityId of the media.
target MediaPosition true Target destination of the seek, as a decimal percentage (0-0.999) for content with a known duration, or an integer number of seconds (0-86400) for content with an unknown duration.

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:media

Examples

Send seeking metric.

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.mediaSeeking('345', 0.5)
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.mediaSeeking",
  "params": {
    "entityId": "345",
    "target": 0.5
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

mediaWaiting

Called when media playback will halt due to a network, buffer, or other unintentional constraint.

function mediaWaiting(entityId: string): Promise<boolean>

Parameters:

Param Type Required Description
entityId string true The entityId of the media.

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:media

Examples

Send waiting metric.

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.mediaWaiting('345')
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.mediaWaiting",
  "params": {
    "entityId": "345"
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

page

Inform the platform that your user has navigated to a page or view.

function page(pageId: string): Promise<boolean>

Parameters:

Param Type Required Description
pageId string true Page ID of the content.

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:general

Examples

Send page metric

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.page('xyz')
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.page",
  "params": {
    "pageId": "xyz"
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

Send startContent metric w/ entity

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.page('home')
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.page",
  "params": {
    "pageId": "home"
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

ready

This is an private RPC method.

Inform the platform that your app is minimally usable. This method is called automatically by Lifecycle.ready()

Result:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:general

Examples

Send ready metric

JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.ready",
  "params": {}
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

signIn

This is an private RPC method.

Log a sign in event, called by Discovery.signIn().

Result:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:general

Examples

Send signIn metric

JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.signIn",
  "params": {}
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

Send signIn metric with entitlements

JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.signIn",
  "params": {
    "entitlements": [
      {
        "entitlementId": "123",
        "startTime": "2025-01-01T00:00:00.000Z",
        "endTime": "2025-01-01T00:00:00.000Z"
      }
    ]
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

signOut

This is an private RPC method.

Log a sign out event, called by Discovery.signOut().

Result:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:general

Examples

Send signOut metric

JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.signOut",
  "params": {}
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

startContent

Inform the platform that your user has started content.

function startContent(entityId: string): Promise<boolean>

Parameters:

Param Type Required Description
entityId string false Optional entity ID of the content.

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:general

Examples

Send startContent metric

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.startContent(null)
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.startContent",
  "params": {}
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

Send startContent metric w/ entity

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.startContent('abc')
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.startContent",
  "params": {
    "entityId": "abc"
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

stopContent

Inform the platform that your user has stopped content.

function stopContent(entityId: string): Promise<boolean>

Parameters:

Param Type Required Description
entityId string false Optional entity ID of the content.

Promise resolution:

Capabilities:

Role Capability
uses xrn:firebolt:capability:metrics:general

Examples

Send stopContent metric

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.stopContent(null)
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.stopContent",
  "params": {}
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

Send stopContent metric w/ entity

JavaScript:

import { Metrics } from '@firebolt-js/sdk'

let success = await Metrics.stopContent('abc')
console.log(success)

Value of success:

true
JSON-RPC:

Request:

{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "Metrics.stopContent",
  "params": {
    "entityId": "abc"
  }
}

Response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

Types

ErrorType

ErrorType: {
    NETWORK: 'network',
    MEDIA: 'media',
    RESTRICTION: 'restriction',
    ENTITLEMENT: 'entitlement',
    OTHER: 'other',
},


MediaPosition

Represents a position inside playback content, as a decimal percentage (0-0.999) for content with a known duration, or an integer number of seconds (0-86400) for content with an unknown duration.

type MediaPosition = void | number | number