Skip to content

Helper tool for configuring IPTV on the UniFi Dream Machine (Pro)

License

Notifications You must be signed in to change notification settings

reinierjh/udm-iptv

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

46 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

IPTV on UniFi OS

This document describes how to set up IPTV on UniFi routing devices based on UniFi OS, such as the UniFi Dream Machine (UDM) or the UniFi Dream Router (UDR). These instructions have been tested with the IPTV network from KPN (ISP in the Netherlands). However, the general approach should be applicable for other ISPs as well.

For getting IPTV to work on the legacy UniFi Security Gateway, please refer to the following guide.

Contents

  1. Global Design
  2. Prerequisites
  3. Setting up Internet Connection
  4. Configuring Internal LAN
  5. Configuring Helper Tool
  6. Troubleshooting and Known Issues

Global Design

        Fiber
          |
    +----------+
    | FTTH NTU |
    +----------+
          |
      VLAN4 - IPTV
      VLAN6 - Internet
          |
      +--------+
      | Router |  - Ubiquiti UniFi device
      +--------+
          |
         LAN
          |
      +--------+
      | Switch |  - Ubiquiti UniFi Switch (Optional)
      +--------+
       |  |  |
       |  |  +-----------------------------+
       |  |                                |
       |  +-----------------+              |
       |                    |              |
+--------------+       +---------+      +-----+
| IPTV Decoder |       | WiFi AP |      | ... |
+--------------+       +---------+      +-----+
  - KPN IPTV
  - Netflix

Prerequisites

Make sure you check the following prerequisites before trying the other steps:

  1. The kernel on your UniFi device must support multicast routing in order to support IPTV:
    • UniFi Dream Machine (Pro): Multicast routing is supported natively in the stock kernel since firmware version 1.11. If you for some reason cannot use firmware v1.11+, see udm-kernel for a kernel that supports multicast routing for older firmware versions of the UDM/P.
    • UniFi Dream Machine Pro SE: You need Early Access firmware 2.3.7+ for multicast routing support.
    • UniFi Dream Router: Multicast routing is supported by the default firmware.
  2. The switches in-between the IPTV decoder and the UniFi device should have IGMP snooping enabled. They do not need to be from Ubiquiti necessarily.
  3. The FTTP NTU (or any other type of modem) of your ISP must be connected to one of the WAN ports of your UniFi device.

Setting up Internet Connection

The first step is to set up your internet connection to your ISP with the UniFi device acting as modem, instead of some intermediate device. These steps might differ per ISP, so please check the requirements for your ISP.

Below, we describe the steps for KPN. Feel free to update this document with the steps necessary for your provider.

KPN

If you are a customer of KPN, you can set up the WAN connection as follows:

  1. In your UniFi Dashboard, go to Settings > Internet.
  2. Select the WAN port that is connected to the FTTP NTU.
  3. Enable VLAN ID and set it to 6 for KPN.
  4. Set IPv4 Connection to PPPoE.
  5. For KPN, Username should be set to internet.
  6. For KPN, Password should be set to internet.

Configuring Internal LAN

To operate correctly, the IPTV decoders on the internal LAN possibly require additional DHCP options. You can add these DHCP options as follows:

  1. In your UniFi Dashboard, go to Settings > Networks.

  2. Select the LAN network on which IPTV will be used. We recommend creating a separate LAN network for IPTV traffic if possible in order to reduce interference of other devices on the network.

  3. Enable Advanced > IGMP Snooping, so IPTV traffic is only sent to devices that should receive it.

  4. Go to Advanced > DHCP Option and add the following options:

    Name Code Type Value
    IPTV 60 Text IPTV_RG
    Broadcast 28 IP Address BROADCAST_ADDRESS

    Replace BROADCAST_ADDRESS with the broadcast address of your LAN network. To get this address, you can obtain it by setting all bits outside the subnet mask of your IP range, for instance:

    192.168.X.1/24 => 192.168.X.255
    192.168.0.1/16 => 192.168.255.255
    

    See here for more information.

Configuring Helper Tool

Next, we will use the udm-iptv package to get IPTV working on your LAN. This package uses igmpproxy to route multicast IPTV traffic between WAN and LAN.

Installation

SSH into your machine and execute the commands below in UniFi OS (not in UbiOS). On the UniFi Dream Machine (Pro), use unifi-os shell to enter UniFi OS from within UbiOS.

# Download udm-iptv package
curl -O -L https://github.com/fabianishere/udm-iptv/releases/download/v2.0.4/udm-iptv_2.0.4_all.deb
# Download a recent igmpproxy version
curl -O -L http://ftp.debian.org/debian/pool/main/i/igmpproxy/igmpproxy_0.3-1_arm64.deb
# Install necessary packages
apt install dialog ./igmpproxy_0.3-1_arm64.deb ./udm-iptv_2.0.4_all.deb 

This script will install the udm-iptv package onto your device. The installation process prompts the user with various questions to correctly configure the package. Below is a useful list of configuration values for various IPTV providers:

Provider WAN VLAN WAN Ranges Notes
KPN (NL) 4 213.75.0.0/16 217.166.0.0/16 Use default DHCP options (-O staticroutes -V IPTV_RG)
Tweak (NL) 4 0.0.0.0/0 DHCP options: -O staticroutes. Use different MAC address for VLAN interface (IPTV_WAN_VLAN_MAC="xx:xx:xx:xx:xx:xx")
Solcon (NL) 4/24/188 10.0.0.0/8 10.252.0.0/16 10.253.0.0/16 217.166.0.0/16 Use default DHCP options
Telekom (DE) 0 232.0.0.0/16 87.141.0.0/16 Telekom uses VLAN 7 for both internet and IPTV
MagentaTV (DE) 0 224.0.0.0/4 87.141.0.0/16 193.158.0.0/15 Custom configuration required
Swisscom (CH) 0 195.186.0.0/16 213.3.72.0/24 224.0.0.0/4
Init7 (CH) 0 224.0.0.0/8 239.0.0.0/8
MEO (PT) 0 10.159.0.0/16 10.173.0.0/16 194.65.46.0/23 213.13.16.0/20 224.0.0.0/4
BT (GB) 0 224.0.0.0/4 109.159.247.0/24 Custom configuration required
Vivo SP (BR) 20 172.28.0.0/14 201.0.52.0/23 200.161.71.0/24 177.16.0.0/16 Set DNS servers to 177.16.30.67 and 177.16.30.7 for internal IPTV network

Feel free to update this list with the configuration of your provider.

The package installs a service that is started during the boot process of your UniFi device and that will set up the applications necessary to route IPTV traffic. After installation, the service is automatically started.

Ensuring Installation across Firmware Updates

On certain UniFi devices, such as the UniFi Dream Machine SE, you may need to update the device configuration to have the installation of the udm-iptv package persist across firmware updates. Update /etc/default/ubnt-dpkg-cache as follows:

- DPKG_CACHE_UBNT_PKGS="unifi unifi-protect unifi-access unifi-led unifi-talk unifi-connect uid-agent"
+ DPKG_CACHE_UBNT_PKGS="unifi unifi-protect unifi-access unifi-led unifi-talk unifi-connect uid-agent dialog igmpproxy udm-iptv" 

If you do not perform this step, you will need to re-install the package after a firmware update.

Configuration

You can modify the configuration of the service interactively using dpkg-reconfigure -p medium udm-iptv. See below for a reference of the available options to configure:

Environmental Variable Description Default
IPTV_WAN_INTERFACE Interface on which IPTV traffic enters the router eth8 (on UDM Pro) or eth4 (on UDM)
IPTV_WAN_RANGES IP ranges from which the IPTV traffic originates (separated by spaces) 213.75.0.0/16 217.166.0.0/16
IPTV_WAN_VLAN ID of VLAN which carries IPTV traffic (use 0 if no VLAN is used) 4
IPTV_WAN_DHCP_OPTIONS DHCP options to send when requesting an IP address -O staticroutes -V IPTV_RG
IPTV_LAN_INTERFACES Interfaces on which IPTV should be made available br0
IPTV_IGMPPROXY_DEBUG Enable debugging for igmpproxy false

The configuration is written to /etc/udm-iptv.conf (within UniFi OS). Note that the contents of this file are updated according to the values specified in the debconf database (as a result of the configuration dialog), causing manual changes to this file to not be persisted across updates.

Upgrading

Upgrading the installation of udm-iptv is achieved by downloading a new version of the package and installing it via apt. The service should automatically restart after upgrading.

curl -O -L https://github.com/fabianishere/udm-iptv/releases/download/v2.0.4/udm-iptv_2.0.4_all.deb
apt install ./udm-iptv_2.0.4_all.deb 

Removal

To fully remove an udm-iptv installation from your UniFi device, run the follow command:

apt remove dialog igmpproxy udm-iptv

In order to remove all configuration files as well, run the following command:

apt purge dialog igmpproxy udm-iptv

Troubleshooting and Known Issues

Below is a non-exhaustive list of issues that might occur while getting IPTV to run on your UniFi device, as well as troubleshooting steps. Please check these instructions before reporting an issue on issue tracker.

Debugging DHCP

Use the following steps to verify whether the IPTV container is obtaining an IP address from the IPTV network via DHCP:

  1. Verify that the VLAN interface has obtained an IP address:
    $ ip -4 addr show dev iptv
    43: iptv@eth8: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default
       inet XX.XX.XX.XX/22 brd XX.XX.XX.XX scope global iptv
         valid_lft forever preferred_lft forever
  2. Verify that you have obtained the routes from the DHCP server:
    $ ip route list
    ...
    XX.XX.XX.X/21 via XX.XX.XX.X dev iptv

Debugging IGMP Proxy

Use the following steps to debug igmpproxy if it is behaving strangely. Make sure you are running inside UniFi OS.

  1. Enabling debug logs
    You can enable igmpproxy to report debug messages by setting IPTV_IGMPPROXY_DEBUG to true in the configuration at /etc/udm-iptv.conf (within UniFi OS). Then, restart the service as follows:
    systemctl restart udm-iptv
  2. Viewing debug logs
    You may now view the debug logs of igmpproxy as follows:
    journalctl -u udm-iptv

Reporting an Issue

Please share the diagnostics reported by the service when reporting an issue:

udm-iptv-diag

Contributing

Questions, suggestions and contributions are welcome and appreciated! You can contribute in various meaningful ways:

  • Report a bug through GitHub issues.
  • Contribute improvements to the documentation (e.g., configuration for other ISPs).
  • Help answer questions on our Discussions page.

License

The code is released under the GPLv2 license. See COPYING.txt.

About

Helper tool for configuring IPTV on the UniFi Dream Machine (Pro)

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Shell 100.0%