0.5.5 • Published 2 years ago

@eyevinn/hls-recorder v0.5.5

Weekly downloads
-
License
MIT
Repository
github
Last release
2 years ago

hls-recorder

License: MIT Slack

Node library for recording HLS Live

Prerequisites

  • nodejs >= 12.0.0

Installation

npm install --save @eyevinn/hls-recorder

Usage (with Eyevinn Channel Engine)

const { HLSRecorder } = require("@eyevinn/hls-recorder");
const ChannelEngine = require("eyevinn-channel-engine");

/*
  For instructions on how to properly set up a channel engine, see:
  https://www.npmjs.com/package/eyevinn-channel-engine
*/

// First set up your channel engine instance
const assetMgr = new YourAssetManager();
const channelMgr = new YourChannelManager();

const engineOptions = {
  heartbeat: '/',
  channelManager: channelMgr
}

const engine = new ChannelEngine(assetMgr, engineOptions);

// Then use the instance as first input argument in HLSRecorder instance
const opts = {
  recordDuration: 4000, // seconds (-1 for infinite)
  windowSize: 240000, // seconds | -1 for infinite* (will fallback to Default if source is not EVENT or VOD type) | Default = 300000
  vod: true // insert EXT-X-ENDLIST on end (creating a VOD)
};
const recorder = new HLSRecorder(engine, opts);

recorder.on("mseq-increment", mseq => {
  // Do stuff with media seq
});

recorder.start(); // Start recording VOD2live stream

/** 
 * The recording can also be played back, in the form of an event Hls stream.
 *  If you want to view the recorded stream locally, then use the follwoing lines: 
 **/

// (!) Be sure to have 'restify' imported first 
recorder.setRestifyServer(restify); // Create a Restify server instance in recorder
recorder.listen(8001); // Have server listening on port 8001

// View Recorder Stream Playback at: "http://localhost:8001/live/master.m3u8"

Usage (with HLS Live Stream URL)

const { HLSRecorder } = require("@eyevinn/hls-recorder");

const source = "https://true.live.stream/hls/master.m3u8"

const opts = {
  recordDuration: 4000, // seconds | -1 for infinite | Default = -1
  windowSize: 240000, // seconds | -1 for infinite* (will fallback to Default if source is not EVENT or VOD type) | Default = 300000
  vod: true // insert EXT-X-ENDLIST on end (creating a VOD)
const recorder = new HLSRecorder(source, opts);

recorder.on("mseq-increment", mseq => {
  // Do stuff with media seq
});

recorder.start(); // Start recording live stream

/** 
 * The recording can also be played back, in the form of an event Hls stream.
 *  If you want to view the recorded stream locally, then use the follwoing lines: 
 **/

// (!) Be sure to have 'restify' imported first 
recorder.setRestifyServer(restify); // Create a Restify server instance in recorder
recorder.listen(8001); // Have server listening on port 8001

// View Recorder Stream Playback at: "http://localhost:8001/live/master.m3u8"

Stopping

To stop the recorder use:

recorder.stop()

This will close the server, if listening, and will add an ENDLIST tag to the bottom of each playlist manifest

About Eyevinn Technology

Eyevinn Technology is an independent consultant firm specialized in video and streaming. Independent in a way that we are not commercially tied to any platform or technology vendor.

At Eyevinn, every software developer consultant has a dedicated budget reserved for open source development and contribution to the open source community. This give us room for innovation, team building and personal competence development. And also gives us as a company a way to contribute back to the open source community.

Want to know more about Eyevinn and how it is to work here. Contact us at work@eyevinn.se!