Mixwave is a self hostable platform that aims to simplify the complexities of video delivery. Transcode and package your media for online streaming with simple API calls and sane defaults, or craft dynamic HLS playlists on the fly with bumpers, ads and filters.
- Transcode your video file into separate quality tracks (eg; 1080p, 720p, 480p).
- Write
HLS CMAF
playlists directly to S3, ready to be played by HLS.js. - Scales
ffmpeg
jobs horizontally. - Manually insert HLS interstitials, like the Netflix bumper.
- Parses an Ad Playlist (VMAP), transcodes and packages the ad media files and inserts them as interstitials, on the fly.
- Player included, with a UI written in React.
We're on Discord if you'd like to chat or need support.
Video is quite fragmented, particularly in the way video content is delivered and protected across different platforms and devices. Think MPEG-DASH vs. HLS, CTR vs. CBCS, SSAI vs. CSAI. Besides, there's also a lot of cool things happening behind closed doors, like SGAI with AWS EMT or Disney+. We aim to avoid fragmentation by picking the right tools for the job. If you don't have to do the same thing multiple times, aiming for perfection is a lot easier. We believe HLS CMAF
is the right way forward, and when playlist manipulation is required, we tend to lean towards HLS Interstitials
. There's obviously going to be roadblocks ahead, think of devices not supporting multiple video elements or partially serving encrypted fragments opposed to plain ads. We'll tackle these once we get there.
There's a lot of video tooling out there, think of ffmpeg, bento4, shaka-packager, but not in a unified manner. Mixwave implements the excellent work done by others, and tries to make it approachable in the form of an API with a strong focus on scalability and ease of use. The latter is quiet challenging, you'd only have to look at how complex ffmpeg gets when you get into the details.
Video from source to consumer is a hard task to get right, howvideo.works is a great resource to get you started.
# Clone repository locally.
git clone [email protected]:matvp91/mixwave.git
cd mixwave
cp config.env.example config.env
# Open config.env and change the variables.
docker compose up -d
There's more info in the Getting Started section in the docs.
We built a facade
that simplifies working with HLS.js and React player components.
# make sure hls.js is atleast v1.6.0, with interstitials support.
npm i hls.js
npm i @mixwave/player
For implementation details and API docs, check packages/player.
Player.mp4
Let's take the popular BigBuckBunny MP4 video and package it in two different resolutions: 480p and 720p. Once that's done, we'll use the packageAfter
flag to immediately package the files. In the end, we'll have an HLS playlist ready and stored on our S3.
TranscodeAndPackage.mp4
You know what's even more exciting than just playing videos? Manipulating them in real-time! We'll quickly transcode and package the iconic Netflix bumper, then prepend it to the beginning of our BigBuckBunny video.
InterstitialBumper.mp4
To wrap things up, we'll have the stitcher fetch a few Google IMA video ads and insert them into our playlist. If you need more control, feel free to customize the ad request however you'd like, as long as the final output is a VMAP. Each ad break defined in the VMAP will then be mapped to interstitials.
AdInsertion.mp4
New contributors are welcome! See CONTRIBUTING.md
for contributing to the project.