player-analytics-client-sdk-web 0.0.13
Install from the command line:
Learn more about npm packages
$ npm install @eyevinn/player-analytics-client-sdk-web@0.0.13
Install via package.json:
"@eyevinn/player-analytics-client-sdk-web": "0.0.13"
About this version
Part of Eyevinn Player Analytics Specification. To be used together with Eyevinn Player Analytics Eventsink
npm install @eyevinn/player-analytics-client-sdk-web
import { PlayerAnalyticsConnector } from "@eyevinn/player-analytics-client-sdk-web";
// Create your instance and set the analytics eventsink endpoint
const playerAnalytics = new PlayerAnalyticsConnector("https://your-eventsink-url.io");
// Initiate the analytics with the base data needed
// This will create you session in the backend
await playerAnalytics.init({
sessionId: "generated-unique-uuid-session-id",
live: false,
contentId: "big-buck-bunny-720",
contentUrl:
"https://test-videos.co.uk/vids/bigbuckbunny/mp4/h264/720/Big_Buck_Bunny_720_10s_1MB.mp4",
});
// Get you video element from the site, or your video player of choice
const videoElement = document.querySelector("video");
// Load the analytics library with the video element to fetch the events
playerAnalytics.load(videoElement);
Due to bitrate changes not being reported, and errors not being reported in any descriptive way, there is a possibility to do separate calls for these events - which you may trigger based on you video player of choice following these examples.
playerAnalytics.reportBitrateChange({
bitrate: "", // bitrate in Kbps
width: "", // optional, video width in pixels
height: "", // optional, video height in pixels
videoBitrate: "", // optional, if available provide the bitrate for the video track
audioBitrate: "", // optional, if available provide the bitrate for the audio track
});
// error is fatal, i.e. sends an end event as well
playerAnalytics.reportError({
category: "", // optional, eg. NETWORK, DECODER, etc.
code: "",
message: "", // optional
data: {}, // optional
});
// warning is not fatal
playerAnalytics.reportWarning({
category: "", // optional, eg. NETWORK, DECODER, etc.
code: "",
message: "", // optional
data: {}, // optional
});
// when leaving the player, to stop the analytics in a correct manor
playerAnalytics.reportStop();
playerAnalytics.destroy();
import { PlayerAnalytics } from "@eyevinn/player-analytics-client-sdk-web";
// Create your instance and set the analytics eventsink endpoint
const playerAnalytics = new PlayerAnalytics("https://your-eventsink-url.io");
await playerAnalytics.initiateAnalyticsReporter({
sessionId: "generated-unique-uuid-session-id",
live: false,
contentId: "big-buck-bunny-720",
contentUrl:
"https://test-videos.co.uk/vids/bigbuckbunny/mp4/h264/720/Big_Buck_Bunny_720_10s_1MB.mp4",
});
// then trigger the method calls accordingly, e.g.
const videoElement = document.querySelector("video");
videoElement.addEventListener("play", () => {
playerAnalytics.playing({
event: "playing",
timestamp: Date.now(),
playhead: 0,
duration: 3600,
sessionId: "generated-unique-uuid-session-id"
});
});
These applies to both the PlayerAnalyticsConnector
and PlayerAnalytics
.
-
eventsinkUrl
, the url to your event sink. -
debug
, default false, triggers output to dev console rather than actual http posts.
export interface IPlayerAnalyticsInitOptions {
sessionId?: string; // should be generated by the backend if not sent in
live: boolean;
contentId: string;
contentUrl: string;
drmType?: string;
userId?: string;
deviceId?: string;
deviceModel?: string;
deviceType?: string;
}
Run the demo page by npm start
Details
- player-analytics-client-sdk-web
- Eyevinn
- almost 3 years ago
- ISC
- 13 dependencies
Assets
- player-analytics-client-sdk-web-0.0.13-npm.tgz
Download activity
- Total downloads 1
- Last 30 days 0
- Last week 0
- Today 0