/headless-video-publisher-linux

Publish video and audio streams in to session using Linux SDK

Primary LanguageC++MIT LicenseMIT

Headless video publisher

This sample uses custom video capturer and custom audio driver to publish a video and audio stream in to the video session.

You will need a valid Vonage Video API account to build this app. (Note that OpenTok is now the Vonage Video API.)

If you are looking for a Puppeteer/NodeJS based headless publisher - https://github.com/nexmo-se/headless-video-tester

Setting up your environment

OpenTok SDK

Building this sample application requires having a local installation of the OpenTok Linux SDK.

On Debian-based Linuxes

The OpenTok Linux SDK for x86_64 is available as a Debian package. For Debian we support Debian 9 (Strech) and 10 (Buster). We maintain our own Debian repository on packagecloud. For Debian 10, follow these steps to install the packages from our repository.

  • Add packagecloud repository:
curl -s https://packagecloud.io/install/repositories/tokbox/debian/script.deb.sh | sudo bash
  • Install the OpenTok Linux SDK packages.
sudo apt install libopentok-dev

On non-Debian-based Linuxes

Download the OpenTok SDK from https://tokbox.com/developer/sdks/linux/ and extract it and set the LIBOPENTOK_PATH environment variable to point to the path where you extracted the SDK. For example:

wget https://tokbox.com/downloads/libopentok_linux_llvm_x86_64-2.19.1
tar xvf libopentok_linux_llvm_x86_64-2.19.1
export LIBOPENTOK_PATH=<path_to_SDK>

Other dependencies

Before building the sample application you will need to install the following dependencies

On Debian-based Linuxes

sudo apt install build-essential cmake clang libc++-dev libc++abi-dev \
    pkg-config libasound2 libpulse-dev libsdl2-dev

On Fedora

sudo dnf groupinstall "Development Tools" "Development Libraries"
sudo dnf install SDL2-devel clang pkg-config libcxx-devel libcxxabi-devel cmake

Next, create the building bits using cmake:

$ mkdir src/build
$ cd src/build
$ CC=clang CXX=clang++ cmake ..

Note we are using clang/clang++ compilers.

Use make to build the code:

$ make

When the headless-video-publisher binary is built, run it: You can either publish only video, only audio or both.

$ ./headless-video-publisher -v video.yuv -a audio.pcm -k apikey -s sessionId -t token

Preparing the audio and video input files.

This sample accepts video as raw YUV420P frames with frame size of 1280x720@30fps and audio as raw 16-bit 16KHz PCM audio. This section explains how you can convert any mp4 file to be used by this sample.

Please note that raw video occupies a lot of space (10 seconds clip can be around 400MB). So first you should cut your mp4 to a 10-15 seconds clip.

Here we use ffmpeg to cut the file to 10 seconds starting from the beginning

ffmpeg -ss 00:00:00 -i input.mp4 -to 00:00:10 -c copy output.mp4

Most videos found on the internet are at 60fps. convert to 30fps

ffmpeg -i output.mp4 -filter:v fps=30 output30fps.mp4

Next, convert this clip to raw YUV frames

ffmpeg -i output30fps.mp4 video.yuv

Now, create a raw PCM audio clip from the same mp4 file

ffmpeg -y  -i output30fps.mp4 -acodec pcm_s16le -f s16le -ac 1 -ar 16000 audio.pcm

You can use the OpenTok Playground to connect to the OpenTok session in a web browser to test this application.