Skip to main content

Package media content for online streaming(DASH and HLS) using ffmpeg

Project description

📼 Python FFmpeg Video Streaming

Build Status Build status Downloads PyPI version Software License

This package uses the FFmpeg to package media content for online streaming(DASH and HLS)

Contents

Requirements

  1. This version of the package is only compatible with Python 3.6 or higher.

  2. To use this package, you need to install the FFMpeg. You will need both FFMpeg and FFProbe binaries to use it.

Installation

The latest version of ffmpeg-streaming can be acquired via pip:

pip install python-ffmpeg-video-streaming

Quickstart

The best way to learn how to use this library is to review the examples and browse the source code.

opening a file

There are two ways to open a file:

1. From a Local Path

video = '/var/www/media/videos/test.mp4'

2. From a cloud

from ffmpeg_streaming.from_clouds import from_url

url = 'https://github.com/aminyazdanpanah/python-ffmpeg-video-streaming/blob/master/examples/_example.mp4?raw=true'
video = from_url(url)

NOTE: This package uses Requests to send and receive files.

DASH

Dynamic Adaptive Streaming over HTTP (DASH), also known as MPEG-DASH, is an adaptive bitrate streaming technique that enables high quality streaming of media content over the Internet delivered from conventional HTTP web servers.

Similar to Apple's HTTP Live Streaming (HLS) solution, MPEG-DASH works by breaking the content into a sequence of small HTTP-based file segments, each segment containing a short interval of playback time of content that is potentially many hours in duration, such as a movie or the live broadcast of a sports event. The content is made available at a variety of different bit rates, i.e., alternative segments encoded at different bit rates covering aligned short intervals of playback time. While the content is being played back by an MPEG-DASH client, the client uses a bit rate adaptation (ABR) algorithm to automatically select the segment with the highest bit rate possible that can be downloaded in time for playback without causing stalls or re-buffering events in the playback. The current MPEG-DASH reference client dash.js offers both buffer-based (BOLA) and hybrid (DYNAMIC) bit rate adaptation algorithms. Thus, an MPEG-DASH client can seamlessly adapt to changing network conditions and provide high quality playback with fewer stalls or re-buffering events. Learn more

Create DASH Files:

import ffmpeg_streaming

video = '/var/www/media/videos/test.mp4'

(
    ffmpeg_streaming
        .dash(video, adaption='"id=0,streams=v id=1,streams=a"')
        .format('libx265')
        .auto_rep()
        .package('/var/www/media/videos/dash/test.mpd')
)

You can also create representations manually:

import ffmpeg_streaming
from ffmpeg_streaming import Representation
from ffmpeg_streaming.from_clouds import from_url

url = 'https://github.com/aminyazdanpanah/python-ffmpeg-video-streaming/blob/master/examples/_example.mp4?raw=true'
video = from_url(url)

rep1 = Representation(width=256, height=144, kilo_bitrate=200)
rep2 = Representation(width=426, height=240, kilo_bitrate=500)
rep3 = Representation(width=640, height=360, kilo_bitrate=1000)

(
    ffmpeg_streaming
        .dash(video, adaption='"id=0,streams=v id=1,streams=a"')
        .format('libx265')
        .add_rep(rep1, rep2, rep3)
        .package('/var/www/media/videos/dash/test.mpd')
)

See DASH examples for more information.

See also DASH options for more information about options.

HLS

HTTP Live Streaming (also known as HLS) is an HTTP-based adaptive bitrate streaming communications protocol implemented by Apple Inc. as part of its QuickTime, Safari, OS X, and iOS software. Client implementations are also available in Microsoft Edge, Firefox and some versions of Google Chrome. Support is widespread in streaming media servers.

HLS resembles MPEG-DASH in that it works by breaking the overall stream into a sequence of small HTTP-based file downloads, each download loading one short chunk of an overall potentially unbounded transport stream. A list of available streams, encoded at different bit rates, is sent to the client using an extended M3U playlist. Learn more

Create HLS files based on original video(auto generate qualities).

import ffmpeg_streaming
from ffmpeg_streaming.from_clouds import from_url

url = 'https://github.com/aminyazdanpanah/python-ffmpeg-video-streaming/blob/master/examples/_example.mp4?raw=true'
video = from_url(url)

(
    ffmpeg_streaming
        .hls(video, hls_time=10, hls_allow_cache=1)
        .format('libx264')
        .auto_rep()
        .package('/var/www/media/videos/hls/test.m3u8')
)

You can also create representations manually:

import ffmpeg_streaming
from ffmpeg_streaming import Representation

video = '/var/www/media/videos/test.mp4'

rep1 = Representation(width=256, height=144, kilo_bitrate=200)
rep2 = Representation(width=426, height=240, kilo_bitrate=500)
rep3 = Representation(width=640, height=360, kilo_bitrate=1000)

(
    ffmpeg_streaming
        .hls(video, hls_time=10, hls_allow_cache=1)
        .format('libx264')
        .add_rep(rep1, rep2, rep3)
        .package('/var/www/media/videos/hls/test.m3u8')
)

NOTE: You cannot use HEVC(libx265) and VP9 formats for HLS packaging.

Encrypted HLS

The encryption process requires some kind of secret (key) together with an encryption algorithm. HLS uses AES in cipher block chaining (CBC) mode. This means each block is encrypted using the ciphertext of the preceding block. Learn more

You need to pass both URL to the key and path to save a random key to the encryption method:

import ffmpeg_streaming
from ffmpeg_streaming.from_clouds import from_url

url = 'https://github.com/aminyazdanpanah/python-ffmpeg-video-streaming/blob/master/examples/_example.mp4?raw=true'
video = from_url(url)

(
    ffmpeg_streaming
        .hls(video, hls_time=10, hls_allow_cache=1)
        .encryption('https://www.aminyazdanpanah.com/keys/enc.key', '/var/www/my_website_project/keys/enc.key')
        .format('libx264')
        .auto_rep()
        .package('/var/www/media/videos/hls/test.m3u8')
)

NOTE: It is very important to protect your key on your website using a token or a session/cookie(It is highly recommended).
See HLS examples for more information.

See also HLS options for more information about options.

Progress

You can get realtime information about transcoding and downloading by passing callable methods to the package and from_url methods respectively:

import sys
import ffmpeg_streaming
from ffmpeg_streaming.from_clouds import from_url

def download_progress(percentage, downloaded, total):
    # You can update a field in your database
    # You can also create a socket connection and show a progress bar to users
    sys.stdout.write("\r Downloading... (%s%%)[%s%s]" % (percentage, '#' * percentage, '-' * (100 - percentage)))
    sys.stdout.flush()


def progress(percentage, line, sec):
    # You can update a field in your database
    # You can also create a socket connection and show a progress bar to users
    sys.stdout.write("\r Transcoding... (%s%%)[%s%s]" % (percentage, '#' * percentage, '-' * (100 - percentage)))
    sys.stdout.flush()

url = 'https://github.com/aminyazdanpanah/python-ffmpeg-video-streaming/blob/master/examples/_example.mp4?raw=true'
video = from_url(url, progress=download_progress)

(
    ffmpeg_streaming
        .hls(video)
        .format('libx264')
        .auto_rep()
        .package('/var/www/media/videos/hls/test.m3u8', progress)
)

Output of the progress: progress

Probe

You can extract the metadata of video file using the following code:

from ffmpeg_streaming import FFProbe

ffprobe = FFProbe('/var/www/media/test.mp4')

NOTE: You can save these metadata to your database.

See the example for more information.

Several Open Source Players

You can use these libraries to play your streams.

NOTE: You should pass a manifest of stream(e.g. https://www.aminyazdanpanah.com/videos/dash/lesson-1/test.mpd or /videos/hls/lesson-2/test.m3u8 ) to these players.

Contributing and Reporting Bugs

I'd love your help in improving, correcting, adding to the specification. Please file an issue or submit a pull request.

  • Please see Contributing File for more information.
  • If you have any questions or you want to report a bug, please just file an issue
  • If you discover a security vulnerability within this package, please see SECURITY File for more information to help with that.

NOTE: If you have any questions about this package or FFMpeg, please DO NOT send an email to me or submit the contact form on my website. Emails related to these issues will be ignored.

Credits

License

The MIT License (MIT). Please see License File for more information.

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

python-ffmpeg-video-streaming-0.0.12.tar.gz (15.1 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file python-ffmpeg-video-streaming-0.0.12.tar.gz.

File metadata

  • Download URL: python-ffmpeg-video-streaming-0.0.12.tar.gz
  • Upload date:
  • Size: 15.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.20.0 setuptools/41.0.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.2

File hashes

Hashes for python-ffmpeg-video-streaming-0.0.12.tar.gz
Algorithm Hash digest
SHA256 4b14cc2e48d9b689394d9de885a7874d5587e4d0d589cdfe8c221d37dff42fb9
MD5 46668a11d0d0e6152de57eb86cb9fb74
BLAKE2b-256 1faf66582d76ee7471fe0bdab624d1928b088db402069b5885e296564c06d1ba

See more details on using hashes here.

Provenance

File details

Details for the file python_ffmpeg_video_streaming-0.0.12-py3-none-any.whl.

File metadata

  • Download URL: python_ffmpeg_video_streaming-0.0.12-py3-none-any.whl
  • Upload date:
  • Size: 15.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.20.0 setuptools/41.0.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.2

File hashes

Hashes for python_ffmpeg_video_streaming-0.0.12-py3-none-any.whl
Algorithm Hash digest
SHA256 db7f9b03e930057c57a834abedf24f1c9ddde7e31565d8e16a1c8bab0f4ff7db
MD5 fee07ce7c549d4c7628ec03ac2c351d2
BLAKE2b-256 d2a6d809f52bbc7c5ad2ffdafdd710dccbebc24f107613269bf8fa98830b24ab

See more details on using hashes here.

Provenance

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