b67e9cde8c
Log entries will contain additional class context when using this interface
107 lines
3.8 KiB
C#
107 lines
3.8 KiB
C#
using System.Globalization;
|
|
using Emby.Naming.TV;
|
|
using MediaBrowser.Controller.Configuration;
|
|
using MediaBrowser.Controller.Entities.TV;
|
|
using MediaBrowser.Controller.Library;
|
|
using MediaBrowser.Model.Globalization;
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
namespace Emby.Server.Implementations.Library.Resolvers.TV
|
|
{
|
|
/// <summary>
|
|
/// Class SeasonResolver.
|
|
/// </summary>
|
|
public class SeasonResolver : FolderResolver<Season>
|
|
{
|
|
private readonly IServerConfigurationManager _config;
|
|
private readonly ILibraryManager _libraryManager;
|
|
private readonly ILocalizationManager _localization;
|
|
private readonly ILogger _logger;
|
|
|
|
/// <summary>
|
|
/// Initializes a new instance of the <see cref="SeasonResolver"/> class.
|
|
/// </summary>
|
|
/// <param name="config">The config.</param>
|
|
/// <param name="libraryManager">The library manager.</param>
|
|
/// <param name="localization">The localization</param>
|
|
/// <param name="logger">The logger</param>
|
|
public SeasonResolver(
|
|
IServerConfigurationManager config,
|
|
ILibraryManager libraryManager,
|
|
ILocalizationManager localization,
|
|
ILogger<SeasonResolver> logger)
|
|
{
|
|
_config = config;
|
|
_libraryManager = libraryManager;
|
|
_localization = localization;
|
|
_logger = logger;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Resolves the specified args.
|
|
/// </summary>
|
|
/// <param name="args">The args.</param>
|
|
/// <returns>Season.</returns>
|
|
protected override Season Resolve(ItemResolveArgs args)
|
|
{
|
|
if (args.Parent is Series series && args.IsDirectory)
|
|
{
|
|
var namingOptions = ((LibraryManager)_libraryManager).GetNamingOptions();
|
|
|
|
var path = args.Path;
|
|
|
|
var seasonParserResult = SeasonPathParser.Parse(path, true, true);
|
|
|
|
var season = new Season
|
|
{
|
|
IndexNumber = seasonParserResult.SeasonNumber,
|
|
SeriesId = series.Id,
|
|
SeriesName = series.Name
|
|
};
|
|
|
|
if (!season.IndexNumber.HasValue || !seasonParserResult.IsSeasonFolder)
|
|
{
|
|
var resolver = new Naming.TV.EpisodeResolver(namingOptions);
|
|
|
|
var folderName = System.IO.Path.GetFileName(path);
|
|
var testPath = "\\\\test\\" + folderName;
|
|
|
|
var episodeInfo = resolver.Resolve(testPath, true);
|
|
|
|
if (episodeInfo != null)
|
|
{
|
|
if (episodeInfo.EpisodeNumber.HasValue && episodeInfo.SeasonNumber.HasValue)
|
|
{
|
|
_logger.LogDebug(
|
|
"Found folder underneath series with episode number: {0}. Season {1}. Episode {2}",
|
|
path,
|
|
episodeInfo.SeasonNumber.Value,
|
|
episodeInfo.EpisodeNumber.Value);
|
|
|
|
return null;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (season.IndexNumber.HasValue)
|
|
{
|
|
var seasonNumber = season.IndexNumber.Value;
|
|
|
|
season.Name = seasonNumber == 0 ?
|
|
args.LibraryOptions.SeasonZeroDisplayName :
|
|
string.Format(
|
|
CultureInfo.InvariantCulture,
|
|
_localization.GetLocalizedString("NameSeasonNumber"),
|
|
seasonNumber,
|
|
args.GetLibraryOptions().PreferredMetadataLanguage);
|
|
|
|
}
|
|
|
|
return season;
|
|
}
|
|
|
|
return null;
|
|
}
|
|
}
|
|
}
|