Python script to download Instagram livestreams and replays.

Cammy 95a1b4e082 Bump version to 2.2.4 %!s(int64=8) %!d(string=hai) anos
.github f10e3de361 Create issue_template.md %!s(int64=8) %!d(string=hai) anos
pyinstalive 95a1b4e082 Bump version to 2.2.4 %!s(int64=8) %!d(string=hai) anos
.gitignore 97741eddd4 Improved logging, config validation, gitignore and readme %!s(int64=8) %!d(string=hai) anos
LICENSE 86d3a0107e Create LICENSE %!s(int64=8) %!d(string=hai) anos
README.md 1905e092d1 Update README.md %!s(int64=8) %!d(string=hai) anos
setup.py 95a1b4e082 Bump version to 2.2.4 %!s(int64=8) %!d(string=hai) anos

README.md

PyInstaLive

This script enables you to record Instagram livestreams as well as download any available replays. It is based on another script that has now been discontinued.

Installation

Prerequisites

You need ffmpeg, Git and Python 2.7.x or 3.5>= with pip and setuptools installed before you can install and use this script.

Installing

Run the following command in command line (as administrator in Windows) / terminal:

pip install git+https://github.com/notcammy/PyInstaLive.git@2.2.3 --process-dependency-links

Updating

To update PyInstaLive to the latest version (currently 2.2.3) run the following command:

pip install git+https://github.com/notcammy/PyInstaLive.git@2.2.3 --process-dependency-links --upgrade

Specific versions

If you want to install a specific version of PyInstaLive, you can specify the version tag in the install command:

pip install git+https://github.com/notcammy/PyInstaLive.git@2.1.0 --process-dependency-links

Use the version number you want after the @ symbol (e.g 2.1.0).

Usage

Make sure there is a configuration file called pyinstalive.ini in the directory you want to run PyInstaLive from.

Here is an example of a valid configuration file:

[pyinstalive]
username = johndoe
password = grapefruits
save_path = /
show_cookie_expiry = true

Use the following command to run PyInstaLive:

pyinstalive -u "<username>" -p "<password>" -r "<live-username>"

Where <username> is your account's username, <password> is your password and <live-username> is the username of the user whose livestream or replay you want to record or save.

Notes

The username and password parameters are not required when you have specified these in the configuration file.

If the script is ran and there are available replays as well as an ongoing Instagram livestream, only the livestream will be downloaded. Run the script again after the livestream has ended to download the available replays.

Example

pyinstalive -u "johndoe" -p "grapefruits" -r "janedoe"

Or (see note)

pyinstalive -r "janedoe"

If a livestream is currently ongoing, the terminal output should be something like this:

PYINSTALIVE DOWNLOADER (SCRIPT v1.0)
--------------------------------------------------
[I] Login to "johndoe" OK!
[I] Checking broadcast for "janedoe"...
[I] Starting broadcast recording:
[I] Username    : janedoe
[I] MPD URL     : https://scontent-ams3-1.cdninstagram.com/hvideo-frc1/v/rNAi8avEBU6f0EgB0oLu7/live-dash/dash-abr/17870846050136409.mpd?_nc_rl=AfCS41CMvXPH2xWa&oh=43d66cf045816a1c83310da05fac0949&oe=5992E01E
[I] Viewers     : 1118 watching
[I] Airing time : 37 minutes and 20 seconds
[I] Status      : Active

[I] Recording broadcast... press [CTRL+C] to abort.

[I] Stitching downloaded files into video...
[I] Successfully stitched downloaded files!

Help

If you have a bug to report please open an issue in the appropriate format:

- Expected behavior
- Actual behavior
- Steps to reproduce problem