USTVGO Free IPTV
Project description
USTVGO-IPTV is an app that allows you to watch free IPTV.
It extracts stream URLs from ustvgo.tv website, generates master playlist with available TV channels for IPTV players and proxies the traffic between your IPTV players and streaming backends.
Note: See also a port of this app for 123TV service
✨ Features
- 🔑 Auto auth-key rotation
As server proxies the traffic it can detect if your auth key is expired and refresh it on the fly.
- 📺 Available TV Guide
TV Guide repo generates EPG XML for upcoming programs of all the channels twice an hour.
-
Two iconsets for IPTV players with light and dark backgrounds
There are 2 channel iconsets adapted for apps with light and dark UI themes.
- 🗔 Cross-platform GUI
GUI is available for Windows, Linux and MacOS for people who are not that much into CLI.
🚀 Installation
-
CLI
pip install ustvgo-iptv
-
GUI
You can download GUI app from Releases for your OS.
-
Docker
docker run -d --name=ustvgo-iptv -p 6363:6363 --restart unless-stopped ghcr.io/interlark/ustvgo-iptv:latest
For dark icons append following argument:
--icons-for-light-bg
⚙️ Usage - CLI
You can run the app without any arguments.
ustvgo-iptv
Optional argument | Description |
---|---|
--icons-for-light-bg | Switch to dark iconset for players with light UI. |
--access-logs | Enable access logs for tracking requests activity. |
--port 6363 | Server port. By default, the port is 6363. |
--parallel 10 | Number of parallel parsing requests. Default is 10. |
--use-uncompressed-tvguide | By default, master playlist has a link to compressed version of TV Guide:url-tvg="http://127.0.0.1:6363/tvguide.xml.gz" With this argument you can switch it to uncompressed: url-tvg="http://127.0.0.1:6363/tvguide.xml" |
--password <PASSWORD> | Set password prefix for the URL. Could be used to prevent public playlists scraping. |
Linux users can install systemd service that automatically runs ustvgo-iptv on start-ups ⏰.
# Install "ustvgo-iptv" service
sudo -E env "PATH=$PATH" ustvgo-iptv install-service
# You can specify any optional arguments you want
sudo -E env "PATH=$PATH" ustvgo-iptv --port 1234 --access-logs install-service
# Uninstall "ustvgo-iptv" service
sudo -E env "PATH=$PATH" ustvgo-iptv uninstall-service
⚙️ Usage - GUI
If you don't like command line stuff, you can run GUI app and click "Start", simple as that.
GUI uses config file on following path:
- Linux: ~/.config/ustvgo-iptv/settings.cfg
- Mac: ~/Library/Application Support/ustvgo-iptv/settings.cfg
- Windows: C:\Users\%USERPROFILE%\AppData\Local\ustvgo-iptv\settings.cfg
🔗 URLs
To play and enjoy your free IPTV you need 2 URLs that this app provides:
- Your generated master playlist: 🔗 http://127.0.0.1:6363/ustvgo.m3u8
- TV Guide (content updates twice an hour): 🔗 http://127.0.0.1:6363/tvguide.xml
▶️ Players
Here is a list of popular IPTV players.
USTVGO's channels have EIA-608 embedded subtitles. In case if you're not a native speaker and use TV, Cartoons, Movies and Shows to learn English and Spanish languages I would recommend you following free open-source cross-platform IPTV players that can handle EIA-608 subtitles:
-
This old beast could play any subtitles. Unfortunately it doesn't support TV Guide.
- Play
vlc http://127.0.0.1:6363/ustvgo.m3u8
- Play
-
Fast and extensible player. It supports subtitles, but not that good as VLC, sometimes you could encounter troubles playing roll-up subtitles. Unfortunately it doesn't suppport TV Guide.
- Play
mpv http://127.0.0.1:6363/ustvgo.m3u8
- Play
-
Comfortable, handy, extensible with smooth UI player. Supports TV Guide, has mpv as a backend.
Supports subtitles, but there is no option to enable them via user interface. If you want to enable IPTV subtitles you have to use following "Mute" hack.
-
Enable IPTV subtitles
I found a quick hack to force play embedded IPTV subtitles, all you need is to create one file:
Linux:
~/.local/share/jellyfinmediaplayer/scripts/subtitles.lua
Linux(Flatpak):
~/.var/app/com.github.iwalton3.jellyfin-media-player/data/jellyfinmediaplayer/scripts/subtitles.lua
MacOS:
~/Library/Application Support/Jellyfin Media Player/scripts/subtitles.lua
Windows:
%LOCALAPPDATA%\JellyfinMediaPlayer\scripts\subtitles.lua
And paste following text in there:
-- File: subtitles.lua function on_mute_change(name, value) if value then local subs_id = mp.get_property("sid") if subs_id == "1" then mp.osd_message("Subtitles off") mp.set_property("sid", "0") else mp.osd_message("Subtitles on") mp.set_property("sid", "1") end end end mp.observe_property("mute", "bool", on_mute_change)
After that every time you mute a video (🅼 key pressed), you toggle subtitles on/off as a side effect.
-
Play
1) Settings -> Dashboard -> Live TV -> Tuner Devices -> Add -> M3U Tuner -> URL -> http://127.0.0.1:6363/ustvgo.m3u8 2) Settings -> Dashboard -> Live TV -> TV Guide Data Providers -> Add -> XMLTV -> URL -> http://127.0.0.1:6363/tvguide.xml 3) Settings -> Dashboard -> Scheduled Tasks -> Live TV -> Refresh Guide -> Task Triggers -> "Every 30 minutes"
-
Note
Some versions does not support compressed (*.xml.gz) TV Guides.
-
-
Player built with Electron so you can run it even in browser, has light and dark themes.
Support subtitles and TV Guide.
- Play
1) Add via URL -> http://127.0.0.1:6363/ustvgo.m3u8 2) Settings -> EPG Url -> http://127.0.0.1:6363/tvguide.xml.gz
- Play
👍 Support
-
ustvgo.tv is wonderful project which can offer you a free IPTV, please support these guys buying VPN with their referral link. With VPN you can watch even more of their channels, like extra 25 or so.
-
Also I would highly appreciate your support on this project ⠀
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file ustvgo-iptv-0.1.12.tar.gz
.
File metadata
- Download URL: ustvgo-iptv-0.1.12.tar.gz
- Upload date:
- Size: 18.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a239b49a37f1d9d4ac48f1849a9bf47a2e714310aba4d57f6bdece7711611c38 |
|
MD5 | 9c7adf97c3e9873fcb291fb2ca38ebb1 |
|
BLAKE2b-256 | 00c7a399274442e3a985d3c9db08d036be508ef832b53424dbf4acf8371c5268 |
File details
Details for the file ustvgo_iptv-0.1.12-py3-none-any.whl
.
File metadata
- Download URL: ustvgo_iptv-0.1.12-py3-none-any.whl
- Upload date:
- Size: 14.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 75fb3ff00c5d7f38079faafa6fb0d076ba85bd86f815b24ee9ee89822b4530f7 |
|
MD5 | 8df295d1ee1611ee2b8369277bb4ffa0 |
|
BLAKE2b-256 | 5f590abdcc42ca58afea4938596fc198ffc4cf74c905fba05e504d82c9a9344f |