as

Settings
Sign out
Notifications
Alexa
Amazon Appstore
AWS
Documentation
Support
Contact Us
My Cases
Get Started
Design and Develop
Publish
Reference
Support

IPlayerServer

Represent Kepler player server operations. This interface provides methods for managing Kepler player server handlers and updating Kepler player session status.

For runtime errors, apps are expected to reject the promise with Error object, and if possible send the error code and message received from media player using IPlayerSessionError

Properties

addTrack()

addTrack: (newTrack, sessionId?) => Promise<void>

Notifies interested clients about Kepler player new track. {Audio,Video}Player must register to "addtrack" EventListener in AudioTrackList | VideoTrackList | TextTrackList, and then call this API.

Parameters

newTrack

ITrackInfo

Read-only details of new track added.

sessionId?

IPlayerSessionId

Optional. The session ID of the session whose new track has been added. If not provided, treat as a request for data on all sessions.

Returns

Promise<void>

Promise that resolves when the update is complete.

Details

Updating the server session new track is crucial for reflecting changes in media playback status, currently selected media, and other related information. Apps can register to "addtrack" EventListener on HtmlMediaElement.{audioTracks,videoTracks,textTracks} attributes and then call IPlayerServer.addTrack if the event is emitted.

Example:

let media = useRef<VideoPlayer | AudioPlayer | null>(...);
let sessionId = useRef<IPlayerSessionId | undefined>(...);

const onAudioTrackAdded = (event: Event): void => {
  if (event instanceof TrackEvent) {
    let track = (event as TrackEvent).track;
    if (track !== undefined) {
      playerServerRef.current?.addTrack({
        id: track.id,
        type: "AUDIO",
        kind: track.kind,
        label: track.label,
        language: track.language,
        enabled: (track as AudioTrack).enabled
      }, sessionId.current);
      // Do other operations if needed.
    } else {
      console.error("Undefined audio track.");
    }
  }
}

const onVideoTrackAdded = (event: Event): void => {
  if (event instanceof TrackEvent) {
    let track = (event as TrackEvent).track;
    if (track !== undefined) {
      playerServerRef.current?.addTrack({
        id: track.id,
        type: "VIDEO",
        kind: track.kind,
        label: track.label,
        language: track.language,
        enabled: (track as VideoTrack).selected
      }, sessionId.current);
      // Do other operations if needed.
    } else {
      console.error("Undefined video track.");
    }
  }
}

const onTextTrackAdded = (event: Event): void => {
  if (event instanceof TrackEvent) {
    let track = (event as TrackEvent).track;
    if (track !== undefined) {
      playerServerRef.current?.addTrack({
        id: track.id,
        type: "TEXT",
        kind: track.kind,
        label: track.label,
        language: track.language,
        mode: (track as TextTrack).mode
      }, sessionId.current);
      // Do other operations if needed.
    } else {
      console.error("Undefined text track.");
    }
  }
}

media.current?.audioTracks.addEventListener("addtrack", onAudioTrackAdded);
media.current?.videoTracks.addEventListener("addtrack", onVideoTrackAdded);
media.current?.textTracks.addEventListener("addtrack", onTextTrackAdded);

removeTrack()

removeTrack: (removedTrack, sessionId?) => Promise<void>

Notifies interested clients about Kepler player existing track removed. {Audio,Video}Player must register to "removetrack" EventListener in AudioTrackList | VideoTrackList | TextTrackList, and then call this API.

Parameters

removedTrack

ITrackInfo

Readonly details of existing track removed.

sessionId?

IPlayerSessionId

Optional. The session ID of the session whose existing track has been removed. If not provided, treat as a request for data on all sessions.

Returns

Promise<void>

Promise that resolves when the update is complete.

Details

Updating the server session removed track is crucial for reflecting changes in media playback status, currently selected media, and other related information. Apps can register to "removetrack" EventListener on HtmlMediaElement.{audioTracks,videoTracks,textTracks} attributes and then call IPlayerServer.removeTrack if the event is emitted.

Example:

let media = useRef<VideoPlayer | AudioPlayer | null>(...);
let sessionId = useRef<IPlayerSessionId | undefined>(...);

const onAudioTrackRemoved = (event: Event): void => {
  if (event instanceof TrackEvent) {
    let track = (event as TrackEvent).track;
    if (track !== undefined) {
      playerServerRef.current?.removeTrack({
        id: track.id,
        type: "AUDIO",
        kind: track.kind,
        label: track.label,
        language: track.language,
        enabled: (track as AudioTrack).enabled
      }, sessionId.current);
      // Do other operations if needed.
    } else {
      console.error("Undefined audio track.");
    }
  }
}

const onVideoTrackRemoved = (event: Event): void => {
  if (event instanceof TrackEvent) {
    let track = (event as TrackEvent).track;
    if (track !== undefined) {
      playerServerRef.current?.removeTrack({
        id: track.id,
        type: "VIDEO",
        kind: track.kind,
        label: track.label,
        language: track.language,
        enabled: (track as VideoTrack).selected
      }, sessionId.current);
      // Do other operations if needed.
    } else {
      console.error("Undefined video track.");
    }
  }
}

const onTextTrackRemoved = (event: Event): void => {
  if (event instanceof TrackEvent) {
    let track = (event as TrackEvent).track;
    if (track !== undefined) {
      playerServerRef.current?.removeTrack({
        id: track.id,
        type: "TEXT",
        kind: track.kind,
        label: track.label,
        language: track.language,
        mode: (track as TextTrack).mode
      }, sessionId.current);
      // Do other operations if needed.
    } else {
      console.error("Undefined text track.");
    }
  }
}

media.current?.audioTracks.addEventListener("removetrack", onAudioTrackRemoved);
media.current?.videoTracks.addEventListener("removetrack", onVideoTrackRemoved);
media.current?.textTracks.addEventListener("removetrack", onTextTrackRemoved);

sendError()

sendError: (error, sessionId?) => Promise<void>

Provides the way to send the error from service component to interactive component.

Apps can register to "error" EventListener on HtmlMediaElement instance and then call IPlayerServer.addTrack if the event is emitted.

Parameters

error

IPlayerSessionError

Error object to be sent.

sessionId?

IPlayerSessionId

Optional. The session ID of the session for which custom message needs to be handled.

Returns

Promise<void>

Promise that resolves when the error is sent.

Example

let media = useRef<VideoPlayer | AudioPlayer | null>(...);
let sessionId = useRef<IPlayerSessionId | undefined>(...);

const onError = (error: MediaError) => {
  let errorObj: IPlayerSessionError = {
    code: error.code,
    message: error.message
  }

  try {
    playerServerRef.current?.sendError(errorObj, sessionId);
  } catch (error) {
    console.error('Error while calling sendError: ', error);
  }
};

media.current?.addEventListener("error", onError);

sendMessage()

sendMessage: (message, sessionId?) => Promise<void>

Provides a way to send custom message to interactive component. Any JSON type can be sent as a message (except undefined).

Parameters

message

any

Custom message to be sent. send JSON value (except undefined) as message.

sessionId?

IPlayerSessionId

Optional. The session ID of the session for which custom message needs to be handled.

Returns

Promise<void>

Promise that resolves when the message is sent or rejects with an error if the request fails, or message is undefined.

Details

This is particularly useful in providing custom messages which can be used to by client to update UI.

Example

// Create any object.
const customMessage = {
  video: {
    title: "Video 1",
    myVideoId: 34
  }
};
let sessionId = useRef<IPlayerSessionId | undefined>(...);

try {
  playerServerRef.current?.sendMessage(customMessage, sessionId);
} catch (error) {
  console.error('Error while calling sendMessage: ', error);
}

setHandler()

setHandler: (handler, componentId) => void

Assigns a handler to process requests for Kepler player actions associated with the given component ID.

Parameters

handler

IPlayerServerHandler

An instance of the IPlayerServerHandler interface to invoke when Kepler player requests arrive.

componentId

string

An id of the service component interface representing the component for which the handler is being set. This MUST match the service ID declared in the application manifest.

Returns

void

Details

Assigning a handler is essential for processing Kepler player requests and implementing custom Kepler player logic. This call allows one handler per component. The active handler is the one set by the last invocation to setHandler.

Example

import {PackageInfo, PackageManager} from '@amazon-devices/package-manager-lib';

const parseClientPackageManifest = async (): Promise<string> => {
  try {
    const selfPackageInfo: PackageInfo =
      await PackageManager.getSelfPackageInfo();
    for (const component of selfPackageInfo.components) {
      if (component.type === 'service') {
        return component.id;
      }
    }
    return '';
  } catch (error) {
    console.warn(
      `Interactive: Unable to retrieve info from Package manager, ${error.message}`,
    );
    return '';
  }
};

let serviceComponentId: string | undefined =
  await this.parseClientPackageManifest();
playerServerRef.current?.setHandler(handler, serviceComponentId);

updateBufferedRanges()

updateBufferedRanges: (bufferedRanges, sessionId?) => Promise<void>

Notifies interested clients about Kepler player buffered ranges.

Parameters

bufferedRanges

ITimeRange[]

Updated buffered ranges for player session.

sessionId?

IPlayerSessionId

session id for which the buffered ranges are being updated.

Returns

Promise<void>

Promise that resolves when the update is complete.

Details

Updating the server session playback buffered ranges is crucial for reflecting changes in media playback status, currently selected media, and other related information.

let sessionId1: IPlayerSessionId = { id: 1 };
let mediaPlayer1: HtmlMediaElement | VideoPlayer | AudioPlayer; // say associated with sessionId 1.
let sessionId2: IPlayerSessionId = { id: 2 };
let mediaPlayer2: HtmlMediaElement | VideoPlayer | AudioPlayer; // say associated with sessionId 2.

private getBufferedRanges(mediaPlayer: HtmlMediaElement | VideoPlayer | AudioPlayer): Array<ITimeRange> {
  const result: Array<ITimeRange> = [];
  const bufferedTimeRanges = mediaPlayer.buffered;
  for (let i = 0; i < bufferedTimeRanges.length; ++i) {
    result.push({
      start: bufferedTimeRanges.start(i),
      end: bufferedTimeRanges.end(i)
    });
  }
  return result;
}

playerServerRef.current?.updateBufferedRanges(getBufferedRanges(mediaPlayer1), sessionId1);
playerServerRef.current?.updateBufferedRanges(getBufferedRanges(mediaPlayer2), sessionId2);

updateStatus()

updateStatus: (status) => Promise<void>

Notifies interested clients about Kepler player session status updates.

Parameters

status

IPlayerSessionStatus[]

Array of IPlayerSessionStatus containing updated session status.

Returns

Promise<void>

Promise that resolves when the update is complete.

Details

Updating the kepler player server session status is crucial for reflecting changes in media playback status, currently selected media, and other related information. For instance, apps will register media related EventListener on AudioPlayer or VideoPlayer (https://html.spec.whatwg.org/#event-handlers-on-elements,-document-objects,-and-window-objects) and then update the parameters of IPlayerSessionStatus accordingly and call updateStatus. When applicable, a Kepler player server is expected to issue session status updates upon acting on a Kepler player request received through the installed IPlayerServerHandler instance.

Example

let mediaPlayer1: HtmlMediaElement | VideoPlayer | AudioPlayer; // say associated with sessionId 1.
let mediaPlayer2: HtmlMediaElement | VideoPlayer | AudioPlayer; // say associated with sessionId 2.

let sampleData_1: IPlayerSessionStatus = {
  sessionID: {id: 1},
  playbackSpeed: 1.0,
  playbackStatus: IPlaybackStatus.PAUSED,
  isMuted: true,
  volume: 0.0,
  seekable: false,
  duration: mediaPlayer1.duration || 0,
};

let sampleData_2: IPlayerSessionStatus = {
  sessionID: {id: 2},
  playbackSpeed: 2.0,
  playbackStatus: IPlaybackStatus.PLAYING,
  isMuted: false,
  volume: 0.75,
  seekable: true,
  duration: mediaPlayer2.duration || 0,
};

playerServerRef.current?.updateStatus([sampleData_1, sampleData_2]);

Last updated: Sep 30, 2025