This project is a simple iptv restreamer. For now it supports only HLS (m3u8) streams. Some iptv providers allow to connect only one device per url and this is not really comfortable when you have 3+ tv. Iptv-proxy allocates such 'urls' dynamically. I.e. your iptv provider have two urls (playlists) and allows only one connection per url, but you have 4 tv in your house and you never watch more then 2 tv at the same time. In this case you can setup two playlists in iptv proxy and they will be dynamically allocated to active tv.
Also iptvproxy can combine different iptv providers. It will combine both - playlist and xmltv data (if available).
host: 127.0.0.1
port: 8080
base_url: http://127.0.0.1:8080
forwarded_pass: password
token_salt: 6r8bt67ta5e87tg7afn
channels_timeout_sec: 5
channels_total_timeout_sec: 60
channels_retry_delay_ms: 1000
xmltv_timeout_sec: 30
xmltv_total_timeout_sec: 120
xmltv_retry_delay_ms: 1000
use_http2: false
servers:
- name: someiptv-1
connections:
- url: https://someiptv.com/playlist.m3u
max_connections: 1
- name: someiptv-2
connections:
- url: https://iptv-proxy.example.com/playlist.m3u
max_connections: 4
- url: https://iptv-proxy.example.com/playlist2.m3u
max_connections: 2
login: mylogin
password: mypassword
xmltv_url: https://epg.example.com/epg.xml.gz
xmltv_before: p5d
xmltv_after: p1d
send_user: true
proxy_stream: true
channel_failed_ms: 1000
info_timeout_ms: 1000
info_total_timeout_ms: 2000
info_retry_delay_ms: 100
catchup_timeout_ms: 1000
catchup_total_timeout_ms: 2000
catchup_retry_delay_ms: 100
stream_start_timeout_ms: 1000
stream_read_timeout_ms: 1000
group_filters:
- 'movies'
- 'vid.*'
allow_anonymous: false
users:
- 65182_login1
- 97897_login2
base_url
- url of your service, you may omit this (see forwarded_pass)forwarded_pass
- password for Forwarded header in case iptvproxy is behind proxytoken_salt
- just random chars, they are used to create encrypted tokenschannels_timeout_sec
- timeout for single request (default is 5 sec)channels_total_timeout_sec
- total timeout for channels loading (default is 60 sec)channels_retry_delay_ms
- delay between requests (default is 1000 ms)xmltv_timeout_sec
- timeout for single xmltv data request (default is 30 sec)xmltv_total_timeout_sec
- total timeout for loading xmltv data (default is 120 sec)xmltv_retry_delay_ms
- delat between retries (default is 1000 ms)use_http2
- use http2 when available, default is false - where are some strange problems with recent nginx and we really don't need http2max_connections
- max active connections allowed for this playlistlogin
- login for basic authentication (useful for tvheadend iptv playlists)password
- password for basic authentication (useful for tvheadend iptv playlists)xmltv_url
- url for xmltv data, epg for different servers will be reprocessed and combined to one file for all channelsxmltv_after
- filter programmes after specified time (to reduce xmltv size), java duration format (p1d - one day), default - unlimitedxmltv_before
- filter programmes before specified time (to reduce xmltv size), java duration format (p5d - five days), default - unlimitedsend_user
- this is useful only when you're using cascade config - iptv-proxy behind iptv-proxy. If 'true' then iptv-proxy will send current user name in special http header. We need this to identify device (endpoint) - this will help us to handle max connections and channel switching properly.proxy_stream
- true (default) means proxy all data through own server, false means using direct urls for datachannel_failed_ms
- on channel failure (error on downloading current m3u8 info) it will be marked as 'failed' for some time and will be not used for any subsequent requests. This feature should be enabled for last iptvproxy in chain (the one which connects to your iptv service) and should be disabled in other situationinfo_timeout_ms
- timeout for single request (default is 2000ms)info_total_timeout_ms
- some providers may return 404 http error on m3u8 request. This setting will trigger automatic request retry. We'll be trying to make additional requests for this period. (default is 2000ms).info_retry_delay_ms
- delay in milliseconds between retries (default is 100ms).catchup_timeout_sec
- same asinfo_timeout_ms
but used only with catchup (channel archive, timeshift, default is 1000ms).catchup_total_timeout_ms
- same asinfo_total_timeout_ms
but used only with catchup (default is 2000ms).catchup_retry_delay_ms
- same asinfo_retry_delay_ms
but used only with catchup (default is 100ms).stream_start_timeout_ms
- timeout for starting actually streaming data (default is 1000ms)stream_read_timeout_ms
- read timeout during streaming - time between any data packets (default is 1000ms)group_filters
- list of regex channel filtersallow_anonymous
- allow to connect any device without specific user name. It is not good idea to use such setup. You really should add name for each device you're using.
iptv proxy will embed full urls in it's lists - it means we should know url from which service is accessed by user. Url is calculated in following way:
- if forwarded_pass is enabled url is taken from Forwarded header
(nginx setup:
proxy_set_header Forwarded "pass=PASS;baseUrl=https://$host";
). Password must match setting in iptvproxy config - base_url is used in case it defined
- schema host and port from request is used (will not work in case iptvproxy is behind proxy)
On device you should use next url as dynamic playlist:
<base_url>/m3u/<user_name>
or
<base_url>/m3u
for anonymous access.
For xmltv you should use <base_url>/epg.xml.gz