Giter Club home page Giter Club logo

iptv.bundle's Introduction

Plex Media Server plugin that plays live streams (a.k.a. IPTV) from a M3U playlist

by Valdas Vaitiekaitis, also known as Cigaras, version 1.2.1

  1. Introduction
  2. Installation
  3. Playlist structure and examples
  4. Program guide
  5. Compatible devices and limitations
  6. Supported protocols
  7. Troubleshooting
  8. To do list
  9. Credits and contacts
  10. License

Introduction

Some ISP provide their users IPTV services, that can be watched over VLC on PC or on TV sets, but for TV a Set-top box is usually required that is both expensive and inconvenient because of separate remote. MediaLink, that is pre-installed on most LG TVs, is able to play IPTV streams with the help of Plex Media Server, but it does not has native support for it. One simple solution is to put every single stream url into a separate *.strm file, load them into Plex library as Home Videos and assign logos and descriptions manually. Or, if You are lucky, You might find a Channel with predefined playlist that suits Your needs or even broadcasts IPTV from Your ISP, but as I was not lucky enough, I decided to take matters into my own hands and created this Channel plugin, that allows to watch network streams from a customisable playlist, thus allowing You to watch IPTV without a Set-top box!

Please read further for instructions on how to install and configure this plugin, check compatible devices and supported protocols, and, if You find my work useful, please consider a small donation as a sign of gratitude and support.

Installation

Please refer to ofificial Plex support page How do I manually install a channel?

Playlist structure and examples

Sample playlist is located in IPTV.bundle\Content\Resources\playlist.m3u, you can specify other filename in preferences, but You can not specifify a path outside resources forder because Plex prohibits it. Online playlist is also supported, You just need to specify a direct link to it, with http part included. Playlist should be encoded in UTF-8 without BOM, I recomend using Notepad++ to check and convert if needed.

Included sample playlist is for testing purposes only, some streams might be dead by now, here is a short list of resources to get started, however please keep in mind, I am not associated with them and not responsible for their content, try it at Your own risk:

Playlist supports additional attributes that can be optionally defined inline after #EXTINF:0 and before the name of the media:

  • tvg-id, tvg-name - used to identify channel in XMLTV;
  • tvg-logo, logo - stream logo or icon, can use remote media (url must include http part) or stored images from \IPTV.bundle\Content\Resources folder (filename must include extension);
  • group-title - category name;
  • group-logo - category logo, only usable in first line where specific category is defined, in example if You have two channels with same category name, logo supplied in first line of those two will be used.

A simple example (see included sample playlist for more):

#EXTM3U
#EXTINF:0 tvg-id="Cartoon Network" tvg-logo="icon-default.png" group-title="Cartoons" group-logo="icon-folder.png",Cartoon Network
http://80.87.146.133:1111/udp/230.3.3.112:5678
#EXTINF:-1 tvg-logo="http://www.lyngsat-logo.com/hires/mm/mtv_dance_us.png" group-title="Music",MTV Dance
http://80.87.146.133:1111/udp/230.3.3.115:5678

Read further for more information about supported protocols and required configurations.

Program guide

As of version 1.2 and further this plugin supports program guide in XMLTV format, there is a sample located in IPTV.bundle\Content\Resources\guide.xml, you can specify other filename in preferences, but You can not specifify a path outside resources forder because Plex prohibits it. Online guide is also supported (as long as it matches the XMLTV format), You just need to specify a direct link to it, with http part included.

Plugin will try to match the program guide with playlist streams by the stream title, but to make things easier tvg-id atribute might be used to represent the exact XMLTV channel, for example if XMLTV looks something like this:

<tv>
  ...
  <programme start="20160321031000 +0200" stop="20160321040100 +0200" channel="Cartoon Network RSE">
    ...
  </programme>
  ...
</tv>

then previously mentioned playlist should look like this:

#EXTM3U
#EXTINF:0 tvg-id="Cartoon Network RSE" tvg-logo="icon-default.png" group-title="Cartoons",Cartoon Network
http://80.87.146.133:1111/udp/230.3.3.112:5678
...

Recomended software for XMLTV generation would be WebGrab+Plus, please refer to its documentation on how to set it up.

Please note, program guide is quite demanding on resources and I do not recomend using XMLTV file that has more channels than You actualy need and the shorter the period its generated for the better.

Compatible devices and limitations

It is a known fact that Plex Media Server does not transcode live streams and leaves this job for clients and streaming sources, so streams will play only on clients that are able to handle the stream natively:

Keep in mind that following list is not full because Plex developers are constantly working and updating their software and I do not have the resources to test them all, You can easily test your client by putting stream url into a *.strm file and loading it into Plex as Home Video as mentioned above and below, please contact me if it happens to work on Your device that is listed as not working or unknown.

Also You can try running a dedicated transcoding service and get Your streams in preferable format, VODServer is a good and free example.

One more flaw of this plugin is that it has no control over audio tracks if stream has multiple. Some clients can change the track, some can not, but plugin can not predefine one and I have no solution at the moment.

Read further for specific configuration required for some streaming protocols.

Supported protocols

  1. HTTP should work on most devices natively, no specific configuration required.

  2. RTSP should work on most devices natively, no specific configuration required.

  3. RTMP requires special Framework Flag that makes plugin incompatible with some older devices/clients (like my TV) and is disabled by default. You can enable it in Preferences, but You need to manually uncomment 14th line in Info.plist file for RTMP streams to work: find <!--<string>UseRealRTMP</string>--> and change it to <string>UseRealRTMP</string>.

    As Plex no longer supports webkit players, You can no longer use full RTMP urls like this:

    rtmp://shopnbc.fmsls.entriq.net:443/live/ playpath=live_01@13361 swfurl=http://shopnbc.img.entriq.net/img/ShopNBCLivePlayer/main.swf pageurl=http://www.shopnbc.com/
    

    You can only use single URL address without attributes, for example:

    rtmp://shopnbc.fmsls.entriq.net:443/live/live_01@13361
    

    If Real RTMP option in preferences is disabled, plugin will try to play stream over HTTP protocol, some streams work that way. If Real RTMP option is enabled, but UseRealRTMP flag in Info.plist file is disabled, then Plex will try to use its own hosted SWF player and will fail.

  4. MMS did not work for me on any tested devise, but plugin will try to play MMS videos over HTTP protocol.

Keep in mind that all streams are unique and Plex will not be able to play all of them, but not necessary because of plugins fault (read Compatible devices and limitations). Please try playing stream with VLC and using *.strm file method described above and below before blaming this plugin. If *.strm method works and plugin does not, please contact me.

Troubleshooting

If You encounter errors or some streams do not work please do the following:

  1. Make sure the playlist file is encoded in UTF-8 without BOM;

  2. Try to play the stream in VLC player, if it fails Your stream is invalid and will not play on any device; if it works continue to next step:

  3. Create a new file with notepad, write your desired streams url there and save it with *.strm extension, put it into a folder and load folder into Plex Server as Home Video, try to play it in Plex client (preferably Plex Media Center because Plex Home Theater as of version 1.4.1 does not like *.strm files), if it fails, then usualy Your client is unable to play this stream, try alternative clients; if it works, continue to next step:

  4. Check plugin log file com.plexapp.plugins.iptv.log, refer to official Plex support page Plex Media Server Log Files for log file location.

  5. If You do not have a solution after checking the log file, submit a ticket on GitHub or post on Plex forum with log and playlist files attached and I or other users will try to help You.

To do list

  • Improve the program guide;
  • Possibility to predefine audio track, if ever becomes possible.

Credits and contacts

If You have any questions or suggestions, please feel free to contact me via GitHub or Plex forum, or visit my personal blog at cigaras.blogspot.lt, but please keep in mind that I did this plugin voluntary and I have other priorities to do. However if You find my work useful, please consider a small donation as a sign of gratitude and support.

License

Copyright © 2013-2016 Valdas Vaitiekaitis

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

iptv.bundle's People

Contributors

cigaras avatar funtic avatar mocaico avatar sander1 avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.