| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221 | using System;using System.Collections.Generic;using System.Globalization;using System.IO;using System.Text;using System.Threading;using System.Xml;using MediaBrowser.Common.Configuration;using MediaBrowser.Controller.Entities.TV;using MediaBrowser.Controller.Providers;using Microsoft.Extensions.Logging;namespace MediaBrowser.XbmcMetadata.Parsers{    public class EpisodeNfoParser : BaseNfoParser<Episode>    {        public void Fetch(MetadataResult<Episode> item,            List<LocalImageInfo> images,            string metadataFile,            CancellationToken cancellationToken)        {            Fetch(item, metadataFile, cancellationToken);        }        private readonly CultureInfo UsCulture = new CultureInfo("en-US");        protected override void Fetch(MetadataResult<Episode> item, string metadataFile, XmlReaderSettings settings, CancellationToken cancellationToken)        {            using (var fileStream = File.OpenRead(metadataFile))            using (var streamReader = new StreamReader(fileStream, Encoding.UTF8))            {                item.ResetPeople();                var xml = streamReader.ReadToEnd();                var srch = "</episodedetails>";                var index = xml.IndexOf(srch, StringComparison.OrdinalIgnoreCase);                if (index != -1)                {                    xml = xml.Substring(0, index + srch.Length);                }                // These are not going to be valid xml so no sense in causing the provider to fail and spamming the log with exceptions                try                {                    using (var stringReader = new StringReader(xml))                    using (var reader = XmlReader.Create(stringReader, settings))                    {                        reader.MoveToContent();                        reader.Read();                        // Loop through each element                        while (!reader.EOF && reader.ReadState == ReadState.Interactive)                        {                            cancellationToken.ThrowIfCancellationRequested();                            if (reader.NodeType == XmlNodeType.Element)                            {                                FetchDataFromXmlNode(reader, item);                            }                            else                            {                                reader.Read();                            }                        }                    }                }                catch (XmlException)                {                }            }        }        /// <summary>        /// Fetches the data from XML node.        /// </summary>        /// <param name="reader">The reader.</param>        /// <param name="itemResult">The item result.</param>        protected override void FetchDataFromXmlNode(XmlReader reader, MetadataResult<Episode> itemResult)        {            var item = itemResult.Item;            switch (reader.Name)            {                case "season":                    {                        var number = reader.ReadElementContentAsString();                        if (!string.IsNullOrWhiteSpace(number))                        {                            if (int.TryParse(number, out var num))                            {                                item.ParentIndexNumber = num;                            }                        }                        break;                    }                case "episode":                    {                        var number = reader.ReadElementContentAsString();                        if (!string.IsNullOrWhiteSpace(number))                        {                            if (int.TryParse(number, out var num))                            {                                item.IndexNumber = num;                            }                        }                        break;                    }                case "episodenumberend":                    {                        var number = reader.ReadElementContentAsString();                        if (!string.IsNullOrWhiteSpace(number))                        {                            if (int.TryParse(number, out var num))                            {                                item.IndexNumberEnd = num;                            }                        }                        break;                    }                case "airsbefore_episode":                    {                        var val = reader.ReadElementContentAsString();                        if (!string.IsNullOrWhiteSpace(val))                        {                            // int.TryParse is local aware, so it can be probamatic, force us culture                            if (int.TryParse(val, NumberStyles.Integer, UsCulture, out var rval))                            {                                item.AirsBeforeEpisodeNumber = rval;                            }                        }                        break;                    }                case "airsafter_season":                    {                        var val = reader.ReadElementContentAsString();                        if (!string.IsNullOrWhiteSpace(val))                        {                            // int.TryParse is local aware, so it can be probamatic, force us culture                            if (int.TryParse(val, NumberStyles.Integer, UsCulture, out var rval))                            {                                item.AirsAfterSeasonNumber = rval;                            }                        }                        break;                    }                case "airsbefore_season":                    {                        var val = reader.ReadElementContentAsString();                        if (!string.IsNullOrWhiteSpace(val))                        {                            // int.TryParse is local aware, so it can be probamatic, force us culture                            if (int.TryParse(val, NumberStyles.Integer, UsCulture, out var rval))                            {                                item.AirsBeforeSeasonNumber = rval;                            }                        }                        break;                    }                case "displayseason":                    {                        var val = reader.ReadElementContentAsString();                        if (!string.IsNullOrWhiteSpace(val))                        {                            // int.TryParse is local aware, so it can be probamatic, force us culture                            if (int.TryParse(val, NumberStyles.Integer, UsCulture, out var rval))                            {                                item.AirsBeforeSeasonNumber = rval;                            }                        }                        break;                    }                case "displayepisode":                    {                        var val = reader.ReadElementContentAsString();                        if (!string.IsNullOrWhiteSpace(val))                        {                            // int.TryParse is local aware, so it can be probamatic, force us culture                            if (int.TryParse(val, NumberStyles.Integer, UsCulture, out var rval))                            {                                item.AirsBeforeEpisodeNumber = rval;                            }                        }                        break;                    }                default:                    base.FetchDataFromXmlNode(reader, itemResult);                    break;            }        }        public EpisodeNfoParser(ILogger logger, IConfigurationManager config, IProviderManager providerManager)            : base(logger, config, providerManager)        {        }    }}
 |