2019-01-13 21:03:10 +01:00
|
|
|
using System;
|
2022-08-02 17:46:38 +02:00
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Globalization;
|
2019-01-13 20:26:56 +01:00
|
|
|
using System.Xml;
|
|
|
|
using MediaBrowser.Common.Configuration;
|
2014-06-30 05:04:50 +02:00
|
|
|
using MediaBrowser.Controller.Entities.TV;
|
2013-03-03 07:58:04 +01:00
|
|
|
using MediaBrowser.Controller.Library;
|
2015-06-29 03:10:45 +02:00
|
|
|
using MediaBrowser.Controller.Providers;
|
2013-02-21 02:33:05 +01:00
|
|
|
using MediaBrowser.Model.Entities;
|
2019-01-13 20:26:56 +01:00
|
|
|
using Microsoft.Extensions.Logging;
|
2013-02-21 02:33:05 +01:00
|
|
|
|
2014-06-30 05:04:50 +02:00
|
|
|
namespace MediaBrowser.XbmcMetadata.Parsers
|
2013-02-21 02:33:05 +01:00
|
|
|
{
|
2020-02-23 12:11:43 +01:00
|
|
|
/// <summary>
|
|
|
|
/// Nfo parser for series.
|
|
|
|
/// </summary>
|
2014-06-30 05:04:50 +02:00
|
|
|
public class SeriesNfoParser : BaseNfoParser<Series>
|
2013-02-21 02:33:05 +01:00
|
|
|
{
|
2020-02-23 12:11:43 +01:00
|
|
|
/// <summary>
|
|
|
|
/// Initializes a new instance of the <see cref="SeriesNfoParser"/> class.
|
|
|
|
/// </summary>
|
2021-02-09 12:42:55 +01:00
|
|
|
/// <param name="logger">Instance of the <see cref="ILogger"/> interface.</param>
|
|
|
|
/// <param name="config">Instance of the <see cref="IConfigurationManager"/> interface.</param>
|
|
|
|
/// <param name="providerManager">Instance of the <see cref="IProviderManager"/> interface.</param>
|
|
|
|
/// <param name="userManager">Instance of the <see cref="IUserManager"/> interface.</param>
|
|
|
|
/// <param name="userDataManager">Instance of the <see cref="IUserDataManager"/> interface.</param>
|
2021-02-27 22:46:03 +01:00
|
|
|
/// <param name="directoryService">Instance of the <see cref="IDirectoryService"/> interface.</param>
|
2021-02-09 12:42:55 +01:00
|
|
|
public SeriesNfoParser(
|
|
|
|
ILogger logger,
|
|
|
|
IConfigurationManager config,
|
|
|
|
IProviderManager providerManager,
|
|
|
|
IUserManager userManager,
|
2021-02-27 22:46:03 +01:00
|
|
|
IUserDataManager userDataManager,
|
|
|
|
IDirectoryService directoryService)
|
|
|
|
: base(logger, config, providerManager, userManager, userDataManager, directoryService)
|
2019-08-18 19:54:07 +02:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <inheritdoc />
|
2019-01-13 21:31:14 +01:00
|
|
|
protected override bool SupportsUrlAfterClosingXmlTag => true;
|
2017-05-10 20:02:08 +02:00
|
|
|
|
2019-08-18 19:54:07 +02:00
|
|
|
/// <inheritdoc />
|
2015-08-02 19:31:08 +02:00
|
|
|
protected override void FetchDataFromXmlNode(XmlReader reader, MetadataResult<Series> itemResult)
|
2013-02-21 02:33:05 +01:00
|
|
|
{
|
2015-06-29 03:10:45 +02:00
|
|
|
var item = itemResult.Item;
|
|
|
|
|
2013-02-21 02:33:05 +01:00
|
|
|
switch (reader.Name)
|
|
|
|
{
|
|
|
|
case "id":
|
|
|
|
{
|
2020-12-31 12:09:25 +01:00
|
|
|
string? imdbId = reader.GetAttribute("IMDB");
|
|
|
|
string? tmdbId = reader.GetAttribute("TMDB");
|
|
|
|
string? tvdbId = reader.GetAttribute("TVDB");
|
2013-02-21 02:33:05 +01:00
|
|
|
|
2016-03-18 04:40:38 +01:00
|
|
|
if (string.IsNullOrWhiteSpace(tvdbId))
|
|
|
|
{
|
|
|
|
tvdbId = reader.ReadElementContentAsString();
|
|
|
|
}
|
2020-02-23 12:11:43 +01:00
|
|
|
|
2016-03-18 04:40:38 +01:00
|
|
|
if (!string.IsNullOrWhiteSpace(imdbId))
|
|
|
|
{
|
2020-06-06 21:17:49 +02:00
|
|
|
item.SetProviderId(MetadataProvider.Imdb, imdbId);
|
2016-03-18 04:40:38 +01:00
|
|
|
}
|
2020-02-23 12:11:43 +01:00
|
|
|
|
2016-03-18 04:40:38 +01:00
|
|
|
if (!string.IsNullOrWhiteSpace(tmdbId))
|
|
|
|
{
|
2020-06-06 21:17:49 +02:00
|
|
|
item.SetProviderId(MetadataProvider.Tmdb, tmdbId);
|
2016-03-18 04:40:38 +01:00
|
|
|
}
|
2020-02-23 12:11:43 +01:00
|
|
|
|
2016-03-18 04:40:38 +01:00
|
|
|
if (!string.IsNullOrWhiteSpace(tvdbId))
|
|
|
|
{
|
2020-06-06 21:17:49 +02:00
|
|
|
item.SetProviderId(MetadataProvider.Tvdb, tvdbId);
|
2016-03-18 04:40:38 +01:00
|
|
|
}
|
2020-02-23 12:11:43 +01:00
|
|
|
|
2016-03-18 04:40:38 +01:00
|
|
|
break;
|
|
|
|
}
|
2020-02-23 12:11:43 +01:00
|
|
|
|
2017-08-13 22:15:07 +02:00
|
|
|
case "airs_dayofweek":
|
2019-01-13 20:26:56 +01:00
|
|
|
{
|
|
|
|
item.AirDays = TVUtils.GetAirDays(reader.ReadElementContentAsString());
|
|
|
|
break;
|
|
|
|
}
|
2017-08-13 22:15:07 +02:00
|
|
|
|
|
|
|
case "airs_time":
|
|
|
|
{
|
2019-01-13 20:26:56 +01:00
|
|
|
var val = reader.ReadElementContentAsString();
|
|
|
|
|
|
|
|
if (!string.IsNullOrWhiteSpace(val))
|
|
|
|
{
|
|
|
|
item.AirTime = val;
|
|
|
|
}
|
2020-02-23 12:11:43 +01:00
|
|
|
|
2019-01-13 20:26:56 +01:00
|
|
|
break;
|
2017-08-13 22:15:07 +02:00
|
|
|
}
|
2013-02-21 02:33:05 +01:00
|
|
|
|
2014-06-30 05:04:50 +02:00
|
|
|
case "status":
|
2013-02-21 02:33:05 +01:00
|
|
|
{
|
|
|
|
var status = reader.ReadElementContentAsString();
|
|
|
|
|
|
|
|
if (!string.IsNullOrWhiteSpace(status))
|
|
|
|
{
|
2019-01-13 21:46:33 +01:00
|
|
|
if (Enum.TryParse(status, true, out SeriesStatus seriesStatus))
|
2013-02-21 02:33:05 +01:00
|
|
|
{
|
|
|
|
item.Status = seriesStatus;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2021-11-09 22:29:33 +01:00
|
|
|
Logger.LogInformation("Unrecognized series status: {Status}", status);
|
2013-02-21 02:33:05 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2022-08-02 17:46:38 +02:00
|
|
|
case "namedseason":
|
|
|
|
{
|
|
|
|
var parsed = int.TryParse(reader.GetAttribute("number"), NumberStyles.Integer, CultureInfo.InvariantCulture, out var seasonNumber);
|
|
|
|
var name = reader.ReadElementContentAsString();
|
|
|
|
|
|
|
|
if (!string.IsNullOrWhiteSpace(name) && parsed)
|
|
|
|
{
|
|
|
|
item.SeasonNames[seasonNumber] = name;
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2013-02-21 02:33:05 +01:00
|
|
|
default:
|
2015-06-29 03:10:45 +02:00
|
|
|
base.FetchDataFromXmlNode(reader, itemResult);
|
2013-02-21 02:33:05 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|