From 767de9aa1e8da5a7cecc7f72259559751c317c4f Mon Sep 17 00:00:00 2001 From: Alex Stevens Date: Sun, 5 Jun 2016 21:53:21 +0100 Subject: [PATCH] More updates to the XmlTVListingsProvider --- .../LiveTv/Listings/XmlTvListingsProvider.cs | 46 ++++++++++++------- 1 file changed, 30 insertions(+), 16 deletions(-) diff --git a/MediaBrowser.Server.Implementations/LiveTv/Listings/XmlTvListingsProvider.cs b/MediaBrowser.Server.Implementations/LiveTv/Listings/XmlTvListingsProvider.cs index 2c56b9a99..c5060944d 100644 --- a/MediaBrowser.Server.Implementations/LiveTv/Listings/XmlTvListingsProvider.cs +++ b/MediaBrowser.Server.Implementations/LiveTv/Listings/XmlTvListingsProvider.cs @@ -14,13 +14,20 @@ namespace MediaBrowser.Server.Implementations.LiveTv.Listings { public class XmlTvListingsProvider : IListingsProvider { - private string _filePath = "C:\\Temp\\"; private string _language = null; private Dictionary> _categoryMappings = new Dictionary>(){ { "Movie", new List() { "Movie", "Film" } }, - { "Sports", new List() { "Sports", "Football", "Rugby", "Soccer" } }, - { "Kids", new List() { "Childrens", "Children", "Kids", "Disney" } }, - { "News", new List() { "News", "Journalism", "Documentary", "Current Affairs" } }, + //{ "Sports", new List() { "Sports", "Football", "Rugby", "Soccer" } }, + //{ "Kids", new List() { "Childrens", "Children", "Kids", "Disney" } }, + //{ "News", new List() { "News", "Journalism", "Documentary", "Current Affairs" } }, + }; + + private Dictionary _channelMappings = new Dictionary(){ + { "1", "UK_RT_2667" }, + { "2", "UK_RT_116" }, + { "3", "UK_RT_2118" }, + { "4", "UK_RT_2056" }, + { "5", "UK_RT_134" } }; public string Name @@ -36,12 +43,18 @@ namespace MediaBrowser.Server.Implementations.LiveTv.Listings // TODO: Should this method be async? public Task> GetProgramsAsync(ListingsProviderInfo info, string channelNumber, string channelName, DateTime startDateUtc, DateTime endDateUtc, CancellationToken cancellationToken) { - var reader = new XmlTvReader(_filePath, _language, null); - var results = reader.GetProgrammes(channelNumber, startDateUtc, endDateUtc, cancellationToken); + var reader = new XmlTvReader(info.Path, _language, null); + string mappedChannel = channelNumber; + + if (_channelMappings.ContainsKey(channelNumber)) + { + mappedChannel = _channelMappings[channelNumber]; + } + + var results = reader.GetProgrammes(mappedChannel, startDateUtc, endDateUtc, cancellationToken); return Task.FromResult(results.Select(p => new ProgramInfo() { ChannelId = p.ChannelId, - //CommunityRating = p.Rating., EndDate = p.EndDate, EpisodeNumber = p.Episode == null ? null : p.Episode.Episode, EpisodeTitle = p.Episode == null ? null : p.Episode.Title, @@ -50,26 +63,27 @@ namespace MediaBrowser.Server.Implementations.LiveTv.Listings StartDate = p.StartDate, Name = p.Title, Overview = p.Description, - // OfficialRating = p.OfficialRating, ShortOverview = p.Description, ProductionYear = !p.CopyrightDate.HasValue ? (int?)null : p.CopyrightDate.Value.Year, SeasonNumber = p.Episode == null ? null : p.Episode.Series, IsSeries = p.IsSeries, IsRepeat = p.IsRepeat, - IsPremiere = !p.PreviouslyShown.HasValue, - IsKids = p.Categories.Any(_categoryMappings["Kids"].Contains), + // IsPremiere = !p.PreviouslyShown.HasValue, + IsKids = p.Categories.Any(info.KidsGenres.Contains), IsMovie = p.Categories.Any(_categoryMappings["Movie"].Contains), - IsNews = p.Categories.Any(_categoryMappings["News"].Contains), - IsSports = p.Categories.Any(_categoryMappings["Sports"].Contains), + IsNews = p.Categories.Any(info.NewsGenres.Contains), + IsSports = p.Categories.Any(info.SportsGenres.Contains), ImageUrl = p.Icon != null && !String.IsNullOrEmpty(p.Icon.Source) ? p.Icon.Source : null, HasImage = p.Icon != null && !String.IsNullOrEmpty(p.Icon.Source), + OfficialRating = p.Rating != null && !String.IsNullOrEmpty(p.Rating.Value) ? p.Rating.Value : null, + CommunityRating = p.StarRating.HasValue ? p.StarRating.Value : (float?)null })); } public async Task AddMetadata(ListingsProviderInfo info, List channels, CancellationToken cancellationToken) { // Add the channel image url - var reader = new XmlTvReader(_filePath, _language, null); + var reader = new XmlTvReader(info.Path, _language, null); var results = reader.GetChannels().ToList(); if (channels != null && channels.Count > 0) @@ -87,16 +101,16 @@ namespace MediaBrowser.Server.Implementations.LiveTv.Listings public async Task Validate(ListingsProviderInfo info, bool validateLogin, bool validateListings) { // Check that the path or url is valid. If not, throw a file not found exception - if (!File.Exists(_filePath)) + if (!File.Exists(info.Path)) { - throw new FileNotFoundException("Could not find the XmlTv file specified", _filePath); + throw new FileNotFoundException("Could not find the XmlTv file specified:", info.Path); } } public Task> GetLineups(ListingsProviderInfo info, string country, string location) { // In theory this should never be called because there is always only one lineup - var reader = new XmlTvReader(_filePath, _language, null); + var reader = new XmlTvReader(info.Path, _language, null); var results = reader.GetChannels(); // Should this method be async?