README
Bitmovin Player Conviva Analytics Integration
Compatibility
**This version of the Conviva Analytics Integration works only with Player Version >= 8.31.x. The recommended and tested version of the Conviva SDK is 4.0.15. See CHANGELOG for details.
Getting Started
Installation
Using NPM
Install the npm package:
npm i @bitmovin/player-integration-conviva --save-dev
Using custom build
Build the JS file by running npm run build
Developing
- Clone Git repository
- Install node.js
- Install required npm packages:
npm install - Run tasks:
npm run lintto lint TypeScript filesnpm run buildto build project intodistdirectorynpm run startto open test page in browser, build and reload changed files automatically
Usage
Include
conviva-core-sdk.min.jsas first of all scripts in your HTML documentCreate an instance of
ConvivaAnalyticsbefore callingplayer.load(...)and pass in your ConvivaCUSTOMER_KEYand optional configuration properties:Using NPM import:
Import ConvivaAnalytics:
import { ConvivaAnalytics } from '@bitmovin/player-integration-conviva';Usage
const playerConfig = { key: 'YOUR-PLAYER-KEY', // ... }; const player = new Player(document.getElementById('player'), playerConfig); const conviva = new ConvivaAnalytics(player, 'CUSTOMER_KEY', { debugLoggingEnabled: true, // optional gatewayUrl: 'https://youraccount-test.testonly.conviva.com', // optional, TOUCHSTONE_SERVICE_URL for testing deviceCategory: Conviva.Client.DeviceCategory.WEB, // optional, deprecated (Use deviceMetadata.category) (default: WEB) deviceMetadata: { // optional (default: let Conviva backend infer these fields from User Agent sring) category: Conviva.Client.DeviceCategory.WEB, // optional (default: WEB) brand: 'Device brand', // optional manufacturer: 'Device Manufacturer', // optional model: 'Device Model', // optional type: Conviva.Client.DeviceType.DESKTOP, // optional version: 'Device version', // optional osName: 'Operating system name', // optional osVersion: 'Operating system version' // optional } }); var sourceConfig = { // ... }; player.load(sourceConfig).then(function() { console.log('player loaded'); }, function(reason) { console.error('player setup failed', reason); });
Using custom Build:
Include
bitmovinplayer-analytics-conviva.jsafterconviva-core-sdk.min.jsin your HTML documentUsage
var playerConfig = { key: 'YOUR-PLAYER-KEY', // ... }; var container = document.getElementById('player'); var player = new bitmovin.player.Player(container, playerConfig); // A ConvivaAnalytics instance is always tied to one player instance var conviva = new bitmovin.player.analytics.ConvivaAnalytics(player, 'CUSTOMER_KEY', { debugLoggingEnabled: true, // optional gatewayUrl: 'https://youraccount-test.testonly.conviva.com', // optional, TOUCHSTONE_SERVICE_URL for testing deviceCategory: Conviva.Client.DeviceCategory.WEB // optional, (default: WEB) }); var sourceConfig = { // ... }; player.load(sourceConfig).then(function() { console.log('player loaded'); }, function(reason) { console.error('player setup failed', reason); });
Release the instance by calling
conviva.release()before destroying the player by callingplayer.destroy()
Advanced Usage
VPF tracking
If you would like to track custom VPF (Video Playback Failures) events when no actual player error happens (e.g.
the server closes the connection and return net::ERR_EMPTY_RESPONSE or after a certain time of stalling)
you can use following API to track those deficiencies.
conviva.reportPlaybackDeficiency('Some Error Message', Conviva.Client.ErrorSeverity.FATAL);
See ConvivaAnalytics.ts for parameter details.
Conviva suggests an timeout of about ~10 seconds and before reporting an error to conviva and providing feedback the user.
Content Metadata handling
If you want to override some content metadata attributes you can do so by adding the following:
let metadataOverrides = {
applicationName: 'App Name',
viewerId: 'uniqueViewerId',
custom: {
customTag: 'customValue',
},
encodedFrameRate: 24,
// …
};
// …
// Initialize ConvivaAnalytics
// …
conviva.updateContentMetadata(metadataOverrides);
Those values will be cleaned up after the session is closed.
See ConvivaAnalytics.ts for details about more attributes.
Consecutive playback
If you want to use the same player instance for multiple playback, just load a new source with player.load(…).
The integration will close the active session.
player.load({…});