1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2025-01-21 11:02:01 +02:00

109 lines
3.9 KiB
C#
Raw Normal View History

2013-03-07 12:45:36 +09:00
using System;
2013-01-10 16:35:33 -08:00
using System.Collections.Generic;
2013-03-07 12:45:36 +09:00
using System.Linq;
2013-01-10 16:35:33 -08:00
using System.Threading.Tasks;
using NLog;
2013-03-07 12:45:36 +09:00
using NzbDrone.Core.DecisionEngine;
using NzbDrone.Core.Download;
2013-02-20 23:07:34 -08:00
using NzbDrone.Core.Indexers;
2013-01-10 16:35:33 -08:00
using NzbDrone.Core.Model;
2013-01-13 00:24:48 -08:00
using NzbDrone.Core.Model.Notification;
2013-03-07 12:45:36 +09:00
using NzbDrone.Core.ReferenceData;
using NzbDrone.Core.Tv;
2013-01-10 16:35:33 -08:00
2013-03-07 12:45:36 +09:00
namespace NzbDrone.Core.IndexerSearch
2013-01-10 16:35:33 -08:00
{
public class EpisodeSearch : IndexerSearchBase
2013-01-10 16:35:33 -08:00
{
private static readonly Logger logger = LogManager.GetCurrentClassLogger();
2013-03-05 11:58:53 -08:00
public EpisodeSearch(IEpisodeService episodeService, DownloadProvider downloadProvider, IIndexerService indexerService,
2013-03-07 12:45:36 +09:00
ISceneMappingService sceneMappingService, IDownloadDirector downloadDirector,
2013-02-25 18:20:42 -08:00
ISeriesRepository seriesRepository)
2013-03-06 17:51:47 -08:00
: base(seriesRepository, episodeService, downloadProvider, indexerService, sceneMappingService,
downloadDirector)
{
2013-01-10 16:35:33 -08:00
}
2013-01-13 10:29:53 -08:00
public EpisodeSearch()
{
}
2013-03-07 12:45:36 +09:00
public override List<EpisodeParseResult> PerformSearch(Series series, List<Episode> episodes, ProgressNotification notification)
2013-01-10 16:35:33 -08:00
{
2013-01-13 00:24:48 -08:00
//Todo: Daily and Anime or separate them out?
//Todo: Epsiodes that use scene numbering
2013-01-10 16:35:33 -08:00
2013-03-07 12:45:36 +09:00
var episode = episodes.Single();
2013-01-10 16:35:33 -08:00
var reports = new List<EpisodeParseResult>();
2013-01-13 00:24:48 -08:00
var title = GetSearchTitle(series);
2013-03-07 12:45:36 +09:00
var seasonNumber = episode.SeasonNumber;
var episodeNumber = episode.EpisodeNumber;
2013-01-13 00:24:48 -08:00
if (series.UseSceneNumbering)
{
2013-03-07 12:45:36 +09:00
if (episode.SceneSeasonNumber > 0 && episode.SceneEpisodeNumber > 0)
2013-01-13 00:24:48 -08:00
{
2013-03-07 12:45:36 +09:00
logger.Trace("Using Scene Numbering for: {0}", episode);
seasonNumber = episode.SceneSeasonNumber;
episodeNumber = episode.SceneEpisodeNumber;
2013-01-13 00:24:48 -08:00
}
}
2013-01-10 16:35:33 -08:00
2013-02-20 23:07:34 -08:00
Parallel.ForEach(_indexerService.GetEnabledIndexers(), indexer =>
2013-01-10 16:35:33 -08:00
{
try
{
2013-01-13 00:24:48 -08:00
reports.AddRange(indexer.FetchEpisode(title, seasonNumber, episodeNumber));
2013-01-10 16:35:33 -08:00
}
catch (Exception e)
{
logger.ErrorException(String.Format("An error has occurred while searching for {0}-S{1:00}E{2:00} from: {3}",
2013-03-07 12:45:36 +09:00
series.Title, episode.SeasonNumber, episode.EpisodeNumber, indexer.Name), e);
2013-01-10 16:35:33 -08:00
}
});
return reports;
}
2013-03-06 17:51:47 -08:00
public override bool IsEpisodeMatch(Series series, dynamic options, EpisodeParseResult episodeParseResult)
2013-01-10 16:35:33 -08:00
{
2013-03-06 17:51:47 -08:00
if (series.UseSceneNumbering && options.Episode.SeasonNumber > 0 && options.Episode.EpisodeNumber > 0)
2013-01-13 00:24:48 -08:00
{
if (options.Episode.SceneSeasonNumber != episodeParseResult.SeasonNumber)
{
logger.Trace("Season number does not match searched season number, skipping.");
2013-03-06 17:51:47 -08:00
return false;
2013-01-13 00:24:48 -08:00
}
if (!episodeParseResult.EpisodeNumbers.Contains(options.Episode.SceneEpisodeNumber))
{
logger.Trace("Episode number does not match searched episode number, skipping.");
2013-03-06 17:51:47 -08:00
return false;
2013-01-13 00:24:48 -08:00
}
2013-03-06 17:51:47 -08:00
return true;
2013-01-13 00:24:48 -08:00
}
2013-03-06 17:51:47 -08:00
if (options.Episode.SeasonNumber != episodeParseResult.SeasonNumber)
2013-01-13 00:24:48 -08:00
{
logger.Trace("Season number does not match searched season number, skipping.");
2013-03-06 17:51:47 -08:00
return false;
2013-01-13 00:24:48 -08:00
}
if (!episodeParseResult.EpisodeNumbers.Contains(options.Episode.EpisodeNumber))
{
logger.Trace("Episode number does not match searched episode number, skipping.");
2013-03-06 17:51:47 -08:00
return false;
2013-01-13 00:24:48 -08:00
}
2013-03-06 17:51:47 -08:00
return true;
2013-01-13 00:24:48 -08:00
}
2013-01-10 16:35:33 -08:00
}
}