77 lines
3.3 KiB
C#
77 lines
3.3 KiB
C#
using System;
|
|
using System.Linq;
|
|
using NLog;
|
|
using NzbDrone.Common;
|
|
using NzbDrone.Core.Datastore;
|
|
using NzbDrone.Core.Download;
|
|
using NzbDrone.Core.Instrumentation.Extensions;
|
|
using NzbDrone.Core.Messaging.Commands;
|
|
using NzbDrone.Core.Tv;
|
|
|
|
namespace NzbDrone.Core.IndexerSearch
|
|
{
|
|
public class MissingEpisodeSearchService : IExecute<EpisodeSearchCommand>, IExecute<MissingEpisodeSearchCommand>
|
|
{
|
|
private readonly ISearchForNzb _nzbSearchService;
|
|
private readonly IDownloadApprovedReports _downloadApprovedReports;
|
|
private readonly IEpisodeService _episodeService;
|
|
private readonly Logger _logger;
|
|
|
|
public MissingEpisodeSearchService(ISearchForNzb nzbSearchService,
|
|
IDownloadApprovedReports downloadApprovedReports,
|
|
IEpisodeService episodeService,
|
|
Logger logger)
|
|
{
|
|
_nzbSearchService = nzbSearchService;
|
|
_downloadApprovedReports = downloadApprovedReports;
|
|
_episodeService = episodeService;
|
|
_logger = logger;
|
|
}
|
|
|
|
public void Execute(EpisodeSearchCommand message)
|
|
{
|
|
foreach (var episodeId in message.EpisodeIds)
|
|
{
|
|
var decisions = _nzbSearchService.EpisodeSearch(episodeId);
|
|
var downloaded = _downloadApprovedReports.DownloadApproved(decisions);
|
|
|
|
_logger.ProgressInfo("Episode search completed. {0} reports downloaded.", downloaded.Count);
|
|
}
|
|
}
|
|
|
|
public void Execute(MissingEpisodeSearchCommand message)
|
|
{
|
|
//TODO: Look at ways to make this more efficient (grouping by series/season)
|
|
|
|
var episodes =
|
|
_episodeService.EpisodesWithoutFiles(new PagingSpec<Episode>
|
|
{
|
|
Page = 1,
|
|
PageSize = 100000,
|
|
SortDirection = SortDirection.Ascending,
|
|
SortKey = "Id",
|
|
FilterExpression = v => v.Monitored == true && v.Series.Monitored == true
|
|
}).Records.ToList();
|
|
|
|
_logger.ProgressInfo("Performing missing search for {0} episodes", episodes.Count);
|
|
var downloadedCount = 0;
|
|
|
|
//Limit requests to indexers at 100 per minute
|
|
using (var rateGate = new RateGate(100, TimeSpan.FromSeconds(60)))
|
|
{
|
|
foreach (var episode in episodes)
|
|
{
|
|
rateGate.WaitToProceed();
|
|
var decisions = _nzbSearchService.EpisodeSearch(episode);
|
|
var downloaded = _downloadApprovedReports.DownloadApproved(decisions);
|
|
downloadedCount += downloaded.Count;
|
|
|
|
_logger.ProgressInfo("Episode search completed. {0} reports downloaded.", downloaded.Count);
|
|
}
|
|
}
|
|
|
|
_logger.ProgressInfo("Completed missing search for {0} episodes. {1} reports downloaded.", episodes.Count, downloadedCount);
|
|
}
|
|
}
|
|
}
|