Skip to content

A simple web application that can restream and synchonize IPTV streams using HLS & ffmpeg.

Notifications You must be signed in to change notification settings

antebrl/IPTV-Restream

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

IPTV StreamHub

Note

A simple IPTV restream and synchronization (watch2gether) application with web frontend. Share your iptv playlist and watch it together with your friends.

Actively in devlopment and open for your ideas!
TEST HERE (Only for testing, the used channels are free (not reliable) and zhe server's distance may cause longer loading times.)

💡Use Cases

  • IPTV Web player supporting multiple playlists at once.
  • Connect with multiple Devices to 1 IPTV Stream, if your provider limits current streaming devices.
  • Proxy all Requests through one IP.
    • Helps with CORS issues.
  • Synchronize IPTV streaming with multiple devices: Synchronized playback and channel selection for perfect Watch2Gether.
  • Share your iptv access without revealing your actual stream-url (privacy-mode) and watch together with your friends.

✨ Features

IPTV Player - IPTV web player with support for any other iptv players by exposing the playlist. Restream / Proxy - Proxy your iptv streams through the backend.
Synchronization - The selection and playback of the stream is perfectly synchronized for all viewers.
Channels - Add multiple iptv streams and playlists, you can switch between.
Live chat - chat with other viewers with a randomized profile.

🚀 Run

Run with Docker (Preferred)

Clone the repo

git clone https://github.com/antebrl/IPTV-Restream.git

Make sure to have docker up & running. Start with docker compose

docker compose up -d

Open http://localhost

Important

If a channel/playlist won't work, please try with proxy or restream mode. This fixes most of the problems! See also Channel Mode.

There is also documentation for advanced deployment:

  • Deploy from container registry and without cloning and building.
  • Deploy together with nginx proxy manager for automatic ssl handling.

🆓 Free compatible playlists

These are some tested playlists as an example. Use your own iptv playlist for the best quality!

  • Free TV Channels: Huge collection of free tv-channels. One playlist for every country.

  • Streamed SU Sports: Sport live-events
    Just put any matches api url e.g. https://streamed.su/api/matches/football/popular as playlistUrl.

  • Daddylive playlist: Various tv-channels including sport
    Make sure to add following headers:

    • Referer: https://cookiewebplay.xyz/
    • Origin: https://cookiewebplay.xyz
    • User-Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/129.0.0.0 Safari/537.36

🖼️ Preview

Frontend Preview Add channel

⚙️ Settings

Channel Mode

Direct

Directly uses the source stream. Won't work with most of the streams, because of CORS, IP/Device restrictions. Is also incompatible with custom headers and privacy mode.

Proxy (Preffered)

The stream requests are proxied through the backend. Allows to set custom headers and bypass CORS. This mode is preffered. Only switch to restream mode, if proxy mode won't work for your stream or if you have synchronization issues.

Restream

The backend service caches the source stream (with ffmpeg) and restreams it. Can help with hard device restrictions of your provider or synchroization problems (when your iptv channels have no programDateTime). But it can lead to longer initial loading times and performance issues after time.

FAQ & Common Mistakes

Which streaming mode should I choose for the channel?

Generally: You should try with direct mode first, switch to proxy mode if it doesn't work and switch to restream mode if this also doesn't work.

Proxy mode is most likely the mode, you will use! You will need restream mode especially when your iptv playlist has no programDateTime set and you want to have playback synchronization.


How can I use the channels on any other iptv player (e.g. on TV)?

Please click on the 📺 (TV-button) in the top-right in the frontend. There you'll find the playlist you have to use in any other iptv player. This playlist contains all your channels and one CURRENT_CHANNEL, which forwards the content of the currently played channel. If this playlist does not work, please check if the base-url of the channels in the playlist is correct and set the BACKEND_URL in the docker-compose.yml if not.


My playlist only supports xtream codes api!

IPTV playlist browser allows you to export a m3u playlist from your xtream codes account, and let's you select single channels or the whole playlist. Official xstreams-code integration is planned!


Error: Bind for 0.0.0.0:80 failed: port is already allocated

To fix this, change the port mapping in the docker-compose to X:80 e.g. 8080:80. Make also sure that port X is open in the firewall configuration if you want to expose the application.


Is it possible to run components seperately, if I only need the frontend OR backend?

If you only need the restream functionality and want to use another iptv player (e.g. VLC), you may only run the backend.
If you only need the synchronization functionality, you may only run the frontend.

Be aware, that this'll require additional configuration/adaption and won't be officially supported. It is recommended to run the whole project as once.

Contribute & Contact

Feel free to open discussions and issues for any type of requests. Don't hesitate to contact me, if you have any problems with the setup.

If you like the project and want to support future development, please leave a ⭐. Stargazers repo roster for @antebrl/IPTV-Restream