Skip to main content

Command line tools for HLS manipulation at origin or edge server

Project description

Description

This package contains useful scripts to manipulate HLS manifests at origin or edge server.

Script

Description

hls-capture

Create a VOD playlist between two timestamps in a LIVE playlist

hls-live-from-vod

Create a LIVE playlist from a set of VOD playlists

hls-startover

Create a LIVE playlist from a specific starttime in another LIVE playlist

Preconditions

These scripts are based on the assumption that all HLS manifest files and segments are archived at the origin server where these scripts are executed. The archive for a specific live stream contains the history for all HLS manifest updates. For example:

Live HLS stream called ‘foo’ is archived in the directory /archive/foo on the server. It contains all updated HLS manifest files with a unix timestamp when it was last updated.

master800.m3u8-1472977456
master800.m3u8-1472977465
master800.m3u8-1472977475

All video segments are also stored in the same directory.

Installation

From source

git clone https://github.com/Eyevinn/hls-origin-scripts.git
cd hls-origin-scripts
python setup.py install

From Python Package Index

pip install hlsorigin

Usage

These scripts are executed by the request handler at the origin webserver. The scripts output the generated manifest file to stdout

hls-capture

Generate a VOD playlist from a LIVE HLS where segments and manifest files are archived at /hlsarchive/stream/. A 20 minutes VOD manifest from 11:45 to 12:05 is created in this case.

hls-capture /hlsarchive/stream/ --mediaplaylist master800.m3u8 --in "2016-09-04 11:45:00" --out "2016-09-04 12:05:00"

By default any cueout periods (e.g. ads) are removed and a discontinuity tag is added in the generated manifest. Available options:

--help                  show help message and exit
--in TS             YYYY-mm-dd HH:MM:SS
--out TS                YYYY-mm-dd HH:MM:SS
--mediaplaylist PL  name of media playlist
--noremovecueout        do not remove segments in cue out periods

hls-startover

Generate a new LIVE HLS playlist with a new start position. This is useful when needing a startover functionality but the user should not be able to watch before the startover position.

hls-startover /hlsarchive/stream/ --mediaplaylist master800.m3u8 --startover "2016-09-04 16:25:00"

Available options:

--help                  show help message and exit
--mediaplaylist PL  name of media playlist
--startover TS      YYYY-mm-dd HH:MM:SS

hls-live-from-vod

TBD

Contribution

We welcome contributions to this project. Just follow the normal procedures by forking this repository, create a topic branch for your fix and then submit a pull request.

License

See LICENSE for details

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hlsorigin-0.0.16.tar.gz (5.3 kB view details)

Uploaded Source

Built Distribution

hlsorigin-0.0.16-py2-none-any.whl (9.0 kB view details)

Uploaded Python 2

File details

Details for the file hlsorigin-0.0.16.tar.gz.

File metadata

  • Download URL: hlsorigin-0.0.16.tar.gz
  • Upload date:
  • Size: 5.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for hlsorigin-0.0.16.tar.gz
Algorithm Hash digest
SHA256 3fa8cdc6de326b50a03cb90bb256d20bb801cfa44a7995ad20933b7f9b7d8447
MD5 0396ef327891efbac39af4265d8cbca9
BLAKE2b-256 d96b4ac909e6e2fcc3a6a3e592c66cd0ca8877eb123ceb1725ae9be3e9771d18

See more details on using hashes here.

File details

Details for the file hlsorigin-0.0.16-py2-none-any.whl.

File metadata

File hashes

Hashes for hlsorigin-0.0.16-py2-none-any.whl
Algorithm Hash digest
SHA256 d70b9cb9b432e400e89941b044bdc3fd29bbf9a7d36ccadaca3df81678434661
MD5 e7a0da1d79c7a1200e6a579a62b13b55
BLAKE2b-256 ea101b41343f7c639e82e4b78c304554d85233f824c5d3a044adb3a347486ca3

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page