Skip to content

Commit

Permalink
Merge branch 'develop'
Browse files Browse the repository at this point in the history
  • Loading branch information
taligentx committed Jul 8, 2018
2 parents 448e8cd + 61b6a4c commit 5c7353b
Show file tree
Hide file tree
Showing 9 changed files with 462 additions and 268 deletions.
662 changes: 426 additions & 236 deletions Contents/Code/__init__.py

Large diffs are not rendered by default.

6 changes: 6 additions & 0 deletions Contents/DefaultPrefs.json
Original file line number Diff line number Diff line change
Expand Up @@ -53,5 +53,11 @@
"label": "prefMetadata",
"type": "bool",
"default": "true"
},
{
"id": "prefDirectStream",
"label": "prefDirectStream",
"type": "bool",
"default": "false"
}
]
Binary file removed Contents/Resources/LiveTVH-thumb.jpg
Binary file not shown.
File renamed without changes
Binary file added Contents/Resources/icon-default.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added Contents/Resources/next.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added Contents/Resources/recordings.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions Contents/Strings/en.json
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
"prefPageCount": "Number of channels to display per page:",
"prefEPGCount": "Number of hours/entries of upcoming shows to display:",
"prefMetadata": "Display artwork and metadata from theTVDB and The Movie DB",
"prefDirectStream": "Enable direct streaming (experimental)",
"next": "Next...",
"recordings": "Recordings"
}
61 changes: 29 additions & 32 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,11 @@
LiveTVH provides live TV streaming for [Plex](https://plex.tv) via [Tvheadend](https://tvheadend.org), including metadata from Tvheadend's EPG, [theTVDB](https://thetvdb.com), and [The Movie DB](https://www.themoviedb.org).

## Release notes
* 2018.07.08 - [LiveTVH 1.3](https://github.com/taligentx/LiveTVH.bundle/releases/tag/v1.3)
This pushes the pre-existing changes in the develop branch to master as a release.
* Updated: Tvheadend channel tags support additional codecs, resolutions, and radio (audio-only) channels
* Updated: Changed image filenames to match Plex channel guidelines.

* 2017.05.22 - [LiveTVH 1.2](https://github.com/taligentx/LiveTVH.bundle/releases/tag/v1.2)
* New: Paginated channel lists with configurable # of items per page - this helps with longer channel lists (a necessity for IPTV providers with thousands of channels).
* New: Tvheadend recordings for playback - located at the end of the first page of the channel list (a display bug with several Plex clients prevents placing it at the beginning of the list).
Expand All @@ -12,28 +17,20 @@ LiveTVH provides live TV streaming for [Plex](https://plex.tv) via [Tvheadend](h
* Updated: Code housekeeping (partially PEP8-conformant)
* Bugfix: transcoding quality options not visible during playback
* Bugfix: episode names from EPG were not set on Plex for Android

* 2017.05.14 - [LiveTVH 1.1](https://github.com/taligentx/LiveTVH.bundle/releases/tag/v1.1)
* EPG is no longer hard set - the number of EPG items requested is now based on the number of channels and hours of EPG data necessary (up to a maximum of 10,000 items or 10MB of data).
* Bugfix: Thumbnails fallback to a channel logo when a show matches theTVDB but does not have a poster.
* Bugfix: 12-hour time displays correctly on non-linux platforms.
* Bugfix: Year displays for movies (when available from TMDb).

* 2017.05.10 - Initial release 1.0

## Features
* EPG displayed as a simple list within each channel description, with a configurable time period to display in 12/24 hour time.
* Metadata and artwork lookup from theTVDB and The Movie DB, with asynchronous searches and loading to minimize channel list load times.

If available through Tvheadend's EPG, searching theTVDB utilizes zap2it ID information for more exact matches and will fall back to searching by name if not available.

If show artwork isn't available, LiveTVH will fallback to using images in the EPG data if available or Tvheadend's channel icons.
* Customized for different clients to display metadata more efficiently - Plex clients vary quite a bit in which fields they choose to display!
* Search results, metadata, and artwork caching - again, to minimize channel list load times.
* Tvheadend recordings accessible for playback, including rich metadata lookup.
* Tvheadend authentication info stored in HTTP headers where possible instead of being sent in the URL - this prevents the Tvheadend username and password from showing up in the Plex log files, for example.
* Tvheadend stream URL checking for availability prior to sending the stream to the client - this prevents long timeouts on the client if Tvheadend does not have an available tuner. This also sends the stream URL as an indirect object to Plex, which prevents the Tvheadend username and password from showing up in the Plex XML file.

However, if the stream is direct played instead of running through the Plex Transcoder, the client will receive the username and password as part of the stream URL and show up in the clear in the client logs as Plex does not seem to support sending headers as part of the stream object.
* Playback of Tvheadend video channels, audio channels, and recordings.
* EPG displayed as a simple list within each channel description.
* Metadata and artwork lookup from theTVDB (using EPG zap2it IDs if available) and The Movie DB.
* Direct streaming (experimental, primarily tested with Plex Web and iOS).

## Screenshots
![Plex Web Posters Screenshot](https://cloud.githubusercontent.com/assets/12835671/26337954/21753de4-3f42-11e7-895d-005c4da6b0a5.jpg)
Expand All @@ -44,41 +41,41 @@ LiveTVH provides live TV streaming for [Plex](https://plex.tv) via [Tvheadend](h
![Plex iOS Screenshot](https://cloud.githubusercontent.com/assets/12835671/25927072/dbecdd3c-35b8-11e7-80d9-056e59088501.jpg)

## Setup
1. [Download LiveTVH.bundle](https://github.com/taligentx/LiveTVH.bundle/releases/) and unzip to the [Plex Media Server/Plug-ins](https://support.plex.tv/hc/en-us/articles/201106098-How-do-I-find-the-Plug-Ins-folder-) directory, and rename (if necessary) to `LiveTVH.bundle`.
1. [Download LiveTVH.bundle](https://github.com/taligentx/LiveTVH.bundle/releases/) and unzip to the [Plex Media Server/Plug-ins](https://support.plex.tv/hc/en-us/articles/201106098-How-do-I-find-the-Plug-Ins-folder-) directory.
2. Set the LiveTVH preferences with the Tvheadend LAN IP address/hostname (or WAN for remote access), username, and password.

![Prefs Screenshot](https://cloud.githubusercontent.com/assets/12835671/26337942/0a4d9724-3f42-11e7-9654-7c8e82e4877a.jpg)
3. Watch!

## Notes
* Codec identification - LiveTVH now uses Tvheadend channel tags to identify a channel's codecs and help Plex clients direct stream (tested with Plex Web and iOS). Create and set one of the following channel tags in Tvheadend as appropriate for each channel (Tvheadend supports editing multiple selections to make this a quick update):
* `H264-AAC` - many DVB and IPTV sources, may permit direct streaming on Plex Web and iOS.
* `MPEG2-AC3` - ATSC and some DVB sources
* `MPEG2` - some IPTV sources
* Setting the channel tag is not required - if a tag is not set, Plex will typically transcode as necessary.

![Tvheadend Channel Tags Screenshot](https://cloud.githubusercontent.com/assets/12835671/26338051/e0cb75dc-3f42-11e7-85a0-7af80e425a21.png)
* Channels will take a bit of time to load initially while metadata is fetched and speed up over time as the cache is built up (up to 30 days). 20-30 channels per page works reasonably well.

* LiveTVH implements channels and playback of Tvheadend recordings. New recordings can be managed within Tvheadend or switching recordings to [Plex DVR](https://www.plex.tv/features/dvr) and [tvhProxy](https://github.com/jkaberg/tvhProxy)).
* While Tvheadend recordings can be played, managing new recordings will need to be handled outside of Plex, or by using [Plex DVR](https://www.plex.tv/features/dvr) and [tvhProxy](https://github.com/jkaberg/tvhProxy)).

* Channels will take a bit of time to load initially while metadata is fetched and speed up over time as images and metadata requests are stored in the cache (up to 30 days cache) - 20-30 channels per page works reasonably well.
* Direct streaming of channels on Plex Web, iOS, and Roku requires identifying the channel's codecs and resolution using Tvheadend channel tags. Create and set channel tags in Tvheadend as appropriate for each channel (Tvheadend supports editing multiple selections to make this a quick update):
* Video tags: `H264`, `MPEG2`, `HEVC`, `VP8`, `VP9`
* Audio tags: `AAC`, `AAC-LATM`, `AC3`, `EAC3`, `MP2`, `MP3`, `VORBIS`
* Video and audio tags may be combined into single tags: `H264-AAC`, `H264-MP2`, etc.
* Video resolution tags: `HDTV`, `720p`, `SDTV`

![Tvheadend Channel Tags Screenshot](https://cloud.githubusercontent.com/assets/12835671/26338051/e0cb75dc-3f42-11e7-85a0-7af80e425a21.png)

* Radio (audio-only) channels are also identified using Tvheadend channel tags - create and set a `Radio` tag in Tvheadend on the appropriate channels for audio-only playback, as well as audio tags (for example, `AAC`) for direct streaming.

* Watching remotely may require Tvheadend to have a public-facing address, as some clients will attempt to directly play the Tvheadend stream instead of running through the Plex transcoder.

In this case, putting Tvheadend behind a [reverse proxy with SSL](https://www.nginx.com/resources/admin-guide/reverse-proxy/) is highly recommended, as the Tvheadend username and password is sent using HTTP Basic Authentication and is not secure over plain HTTP.

* LiveTVH preferentially searches for metadata on theTVDB using a show's zap2it ID if provided through Tvheadend's EPG.

For example, [zap2xml](http://zap2xml.awardspace.info) produces an XMLTV file with a zap2it ID for each show (if available) - Tvheadend includes this information in its EPG, and LiveTVH will use this ID to match the correct show. If a zap2it ID is not available, LiveTVH will fallback to searching by name.

If searching theTVDB fails by zap2it ID but succeeds by name, LiveTVH will display the zap2it ID in the summary as an alert that the show's zap2it entry on theTVDB may be missing/incorrect - consider updating theTVDB.com with the correct information to improve search results. For example, many shows are in the older `SHxxxxxx` format, while the current format is `EPxxxxxxxx`.

![zap2it Screenshot](https://cloud.githubusercontent.com/assets/12835671/25927080/e3b33ec6-35b8-11e7-8eb2-d0f0a3cfabc1.jpg)

If searching theTVDB fails by zap2it ID but succeeds by name, LiveTVH will display the zap2it ID in the summary as an alert that the show's zap2it entry on theTVDB may be missing/incorrect - consider updating theTVDB.com with the correct information to improve search results. For example, many shows are in the older `SHxxxxxx` format, while the current format is `EPxxxxxxxx`.

![zap2it Screenshot](https://cloud.githubusercontent.com/assets/12835671/25927080/e3b33ec6-35b8-11e7-8eb2-d0f0a3cfabc1.jpg)

## Known Issues
* Plex Web currently does not display a detailed pre-play page - this is a bug/side effect of setting up the channels as movies instead of video clips to display posters correctly - channels can be played directly from the channel list.
* Plex Web currently does not display a detailed pre-play page if metadata is enabled - this is a bug/side effect of setting up the channels as movies instead of video clips to display posters correctly. Channels can be played directly from the channel list.
* Plex for Xbox One fails to play channels - this may be due to a [known Plex issue](https://forums.plex.tv/discussion/173008/known-issues-in-1-8-0#latest).
* Metadata searches are not localized.
* Plex does not provide options to flag a stream as interlaced - expect combing artifacts on Plex clients that do not support deinterlacing, unfortunately.
* Plex does not provide options to flag a stream as interlaced in channels - expect combing artifacts on Plex clients that do not support deinterlacing, unfortunately. Plex's native live TV viewing works with [tvhProxy](https://github.com/jkaberg/tvhProxy) and supports deinterlacing.

0 comments on commit 5c7353b

Please sign in to comment.