Skip to content

coder-with-a-bushido/neralai

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

A simple media server in go with WHIP for ingress and HLS for egress

Go Report Card


Neralai Architecture

How does it work?

  1. A WHIP client sends media to Neralai using the WHIP endpoint /stream.
  2. The media is forwarded to ffmpeg for processing; HLS files are generated.
  3. Once the stream starts, the playlist file can be accessed by any HLS player from the endpoint /stream/{resourceId}/hls/stream.m3u8.
  4. The stream can be stopped with a DELETE call to /stream/{resourceId}, as supported by WHIP clients.

Running

Clone the repo and run the command

go run main.go

The server will run on port 8080 by default. Now, open the client/ directory and run it for demo.


Built with 🫶 and