Skip to content
This repository was archived by the owner on Dec 21, 2025. It is now read-only.
/ horepg Public archive
forked from beralt/horepg

A simple translator between the Horizion JSON format and the XMLTV format

License

Notifications You must be signed in to change notification settings

codezorz/horepg

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

82 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

HorEPG

Contents

Introduction

This simple script parses EPG data from the service at horizon.tv (which is used by a product sold by a digital cable provider in the Netherlands). The original data is formatted JSON. This script translated that to the XMLTV format and passes that to TVHeadend using the 'external grabber' interface. This interface is a Unix socket which is read by TVHeadend.

The script fetches a channel list from TVHeadend, and tries to match channels found in the Horizon data to channels found in TVHeadend. As long as you keep the channel names as provided on the DVB-C network a match is very likely, and no configuration is required.

EPG data for radio channels is added using oorboekje.nl as source. This is disabled by default, and enabled by passing the -R option on the command line.

Configuration

  • The script attempts to fetch a list of channels from TVHeadend using the JSON API, credentials can be passed on the commandline.
  • The script attempts to switch to the 'hts' user, with its group set to 'video'. This is what is default on my system, so you might want to changes this to reflect your own setup.
  • The script daemonizes by default, and waits 24 hours before fetching a new batch of data.

Dependencies

The only dependency is the Requests package, required for Basic Authentication for authentication in TVHeadend.

Installation

Use setuptools to install HorEPG:

python setup.py install

Usage

horepgd.py [-h] \
           [-s [PATH]] \
           [-p [PATH]] \
           [-u [USER]] \
           [-g [GROUP]] \
           [-d] \
           [-tvh [HOST]] \
           [-tvh_username [USERNAME]] \
           [-tvh_password [PASSWORD]] \
           [-R] \
           [-o [PATH]] \
           [-i [INT]]

Fetches EPG data from the Horizon service and passes it to TVHeadend.

Optional arguments

Argument Type Description
-h, --help Show this help message and exit
-s [PATH] Path to TVHeadend XMLTV socket
-p [PATH] Path to PID file
-u [USER] Run as USER
-g [GROUP] Run as GROUP
-d [BOOL] Daemonize
-1 [BOOL] Run once, then exit
-nr [DAYS] Number of days to fetch
-tvh [HOST] Hostname of TVHeadend to fetch channels from
-tvh_username [USERNAME] Username used to login into TVHeadend
-tvh_password [PASSWORD] Password used to login into TVHeadend
-R [BOOL] Fetch EPG data for radio channels
-o [PATH] Path to output XML data instead of pushing to TVHeadend
-i [INT] Fetch interval in hours when not running in run-once mode

This would require some privileges to switch to the user and group if daemonizing. The script daemonizes by default, and logging is using syslog().

Docker

Containerized version of HorEPG sources.

docker create \
     --name=horepg \
     -e TVH_HOST=localhost:9981 \
     -e TVH_USERNAME=xmltv \
     -e TVH_PASSWORD=password \
     -e NUM_DAYS=5 \ # Optional
     -e INTERVAL=24 \ # Optional
     -v path to epggrab:/epggrab:ro \
     --restart unless-stopped \
     codezorz/horepg

Parameters

Container images are configured using parameters passed at runtime (such as those above). These parameters are separated by a colon and indicate external:internal respectively.

Parameter Default Description
-e TVH_HOST Hostname of TVHeadend to fetch channels from
-e TVH_USERNAME Username used to login into TVHeadend
-e TVH_PASSWORD The password used to login into TVHeadend
-e NUM_DAYS 5 Number of days to fetch
-e INTERVAL 24 Fetch interval in hours
-v /epggrab Path to TVHeadend XMLTV socket

Improvements

  • It would be nice to stop the whole reconnecting for each channel thingy.
  • Maybe this should be a proper xmltv parser.

References

HorEPG

About

A simple translator between the Horizion JSON format and the XMLTV format

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 97.6%
  • Dockerfile 1.6%
  • Shell 0.8%