Socket
Book a DemoInstallSign in
Socket

@eyevinn/hls-proxy

Package Overview
Dependencies
Maintainers
3
Versions
2
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@eyevinn/hls-proxy

NPM library for proxying HLS requests

latest
Source
npmnpm
Version
0.1.1
Version published
Maintainers
3
Created
Source

hls-proxy

License: MIT Slack

Node library to intercept and proxy HLS requests.

With this library you can easily set up a proxy server to intercept and change the contents of an HLS manifest.

Installation

npm install --save @eyevinn/hls-proxy

Usage

Setup a proxy and provide request handlers.

const { HLSProxy } = require("@eyevinn/hls-proxy");

const proxy = new HLSProxy(handlers);
proxy.listen(process.env.PORT || 8000);

When a client requests a HLS to http://localhost:8000/example/master.m3u8 the following will happen:

  • Client will request the master manifest /example/master.m3u8 from the proxy
  • The handlers.originHandler(request) is called is expected to return the base URL (ORIGINBASE) for origin requests.
  • The master manifest is then fetched from <ORIGINBASE>/example/master.m3u.
  • Master manifest is parsed and the handlers.masterManifestHandler() is called with the parsed manifest as an m3u object. It is expected to return the manifest to be recevied by the client.
  • Client then request a media manifest /example/2000/2000.m3u8
  • The origin handler is called as in 2.
  • The media manfiest is then fetched from <ORIGINBASE>/example/2000/2000.m3u8
  • Media manifest is parsed and the handlers.mediaManifestHandler() is called with the parsed media manifest as an m3u object. The handler is expected to return the manifest for the client.
  • If the URLs to the segments have not been altered in the media manifest handler and a client tries to retrieve a segment from the proxy the following additional steps will take place.
  • The origin handler is called as in 2.
  • Then the segmentRedirectHandler() is called and this handler is expected to return the URL to the segment. A 302 redirect to this URL is then sent to the client.

Example

const { HLSProxy } = require("@eyevinn/hls-proxy");
const proxy = new HLSProxy({
  originHandler: async () => {
    return "https://maitv-vod.lab.eyevinn.technology";
  },
  segmentRedirectHandler: async (request, baseUrl) => {
    const redirectUrl = new URL(request.raw.url, baseUrl);
    return redirectUrl.href;
  }
});
proxy.listen(8000);

Point the video player to http://localhost:8000/VINN.mp4/master.m3u8 and it will fetch all manifests via the proxy and segment requests are redirected to https://maitv-vod.lab.eyevinn.technology.

See examples/rewrite.js for a working example where the segment URLs in the media manifest is rewritten to the origin URLs. And in examples/redirect.js you find an example of a 302 redirect.

Handlers interface

interface IHandlers {
  originHandler: (request: IProxyRequest) => Promise<string>;
  masterManifestHandler?: (request: IProxyRequest, baseUrl: URL, m3u: any) => Promise<string>;
  mediaManifestHandler?: (request: IProxyRequest, baseUrl: URL, m3u: any) => Promise<string>;
  segmentRedirectHandler?: (request: IProxyRequest, baseUrl: URL) => Promise<string>;
}

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!

FAQs

Package last updated on 01 Nov 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts