API & Config
Create instance
var engine = new P2pEngineBitmovin({p2pConfig: [opts]});
Create a new P2pEngineBitmovin instance .
If opts is specified, then the default options (shown below) will be overridden.
Field | Type | Default | Description |
---|---|---|---|
logLevel | string|boolean | 'error' | Print log level(warn, error, none,false=none, true=warn). |
token | string | undefined | Token is used to summarize and display multi domain name data on the console. In addition, token is required while customizing channelId. |
trackerZone | string | 'eu' | The country code name of the tracker server address('eu', 'hk', 'us'). |
memoryCacheLimit | Object | {"pc": 400 1024 1024, "mobile": 100 1024 1024} | The max size of binary data that can be stored in the cache. |
useDiskCache | boolean | true | Use IndexedDB to cache data for VOD streaming. |
diskCacheLimit | Object | {"pc": 1500 1024 1024, "mobile": 1000 1024 1024} | The max size of binary data that can be stored in the disk cache. |
p2pEnabled | boolean | true | Enable or disable p2p engine. |
webRTCConfig | Object | {} | A Configuration dictionary providing options to configure WebRTC connections. |
useHttpRange | boolean | true | Use HTTP ranges requests where it is possible. Allows to continue (and not start over) aborted P2P downloads over HTTP. |
sharePlaylist | boolean | false | Allow the P2P transmission of m3u8 file. |
showSlogan | boolean | false | Display slogan of SwarmCloud on console. |
strictSegmentId | boolean | false | Use segment url based segment id instead of sequence number based one. |
prefetchOnly | boolean | false | Only use prefetch strategy in p2p downloading(Only for HLS). |
startFromSegmentOffset | number | 3 | The segment offset that start to connect to tracker server. |
P2pEngineBitmovin API
P2pEngineBitmovin.version (static method)
Get the version of P2pEngineBitmovin.
P2pEngineBitmovin.protocolVersion (static method)
Get the version of P2P protocol.
P2pEngineBitmovin.isSupported() (static method)
Returns true if WebRTC data channel is supported by the browser.
engine.getNetworkConfig()
Get network configuration for Bitmovin player.
engine.setPlayer(player)
Set Bitmovin player instance for engine.
engine.enableP2P()
Resume P2P if it has been stopped.
engine.disableP2P()
Disable engine to stop p2p and free used resources.
engine.destroy()
Stop p2p and free used resources.
P2pEngineBitmovin Events
engine.on('peerId', function (peerId) {})
Emitted when the peer Id of this client is obtained from server.
engine.on('peers', function (peers) {})
Emitted when successfully connected with new peer.
engine.on('stats', function (stats) {})
Emitted when data is downloaded/uploaded.
stats.totalHTTPDownloaded: total data downloaded by HTTP(KB).
stats.totalP2PDownloaded: total data downloaded by P2P(KB).
stats.totalP2PUploaded: total data uploaded by P2P(KB).
stats.p2pDownloadSpeed: p2p download speed(KB/s).
engine.on('serverConnected', function (connected) {})
Emitted when websocket is opened/closed.
engine.on('exception', function (e) {})
Emitted when exception occured.
e.code: Exception identifier(TRACKER_EXPT SIGNAL_EXPT)
e.message: Exception message
e.stack: Exception stack
Get p2p information from p2pConfig
p2pConfig: {
getStats: function (totalP2PDownloaded, totalP2PUploaded, totalHTTPDownloaded, p2pDownloadSpeed) {
// get the downloading statistics
},
getPeerId: function (peerId) {
// get peer Id
},
getPeersInfo: function (peers) {
// get peers information
},
onHttpDownloaded: function (traffic) {
// listen to http downloaded traffic
},
onP2pDownloaded: function (traffic, speed) {
// listen to p2p downloaded traffic
},
onP2pUploaded: function (traffic) {
// listen to p2p uploaded traffic
},
}
The unit of download and upload is KB. The unit of download speed is KB/s.
Advanced Usage
Dynamic M3u8/mpd Path Support
Some m3u8/mpd urls play the same live/vod but have different paths on them. For example, example.com/clientId1/streamId.mpd and example.com/clientId2/streamId.mpd. In this case, you can format a common channelId for them.
// Set token in p2pConfig before setting channelId!
p2pConfig: {
token: YOUR_TOKEN,
channelId: function (mpdUrl) {
const videoId = extractVideoIdFromUrl(mpdUrl); // make a channelId by removing the different part which is defined by yourself
return videoId;
}
// channelId: VIDEO_ID // for fixed channel id
}
Dynamic Segment Path Support
Like dynamic mpd path, you should format a common segmentId for the same segment file. You can override the segment ID like this:
- .mpd
- .m3u8
p2pConfig: {
/*
segmentUrl: The url of segment
range: The byte range of segment
*/
segmentId: function (segmentUrl, range) {
const segId = extractSegmentIdFromUrl(segmentUrl, range);
return segId;
}
}
p2pConfig: {
/*
streamId: The id of stream
sn: The serial number of segment
segmentUrl: The url of segment
range: The byte range of segment
*/
segmentId: function (streamId, sn, segmentUrl, range) {
const tsId = extractSegmentIdFromUrl(segmentUrl);
return tsId;
}
}