1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2024-12-16 11:37:58 +02:00
Sonarr/NzbDrone.Core/IndexerSearch/SeriesSearchService.cs

47 lines
1.7 KiB
C#
Raw Normal View History

2013-07-22 05:52:53 +03:00
using System.Linq;
using NLog;
2013-07-22 05:52:53 +03:00
using NzbDrone.Core.Download;
2013-09-11 09:33:47 +03:00
using NzbDrone.Core.Instrumentation;
using NzbDrone.Core.Messaging;
2013-07-22 05:52:53 +03:00
using NzbDrone.Core.Tv;
namespace NzbDrone.Core.IndexerSearch
{
public class SeriesSearchService : IExecute<SeriesSearchCommand>
{
private readonly ISeasonService _seasonService;
private readonly ISearchForNzb _nzbSearchService;
private readonly IDownloadApprovedReports _downloadApprovedReports;
private readonly Logger _logger;
2013-07-22 05:52:53 +03:00
public SeriesSearchService(ISeasonService seasonService,
ISearchForNzb nzbSearchService,
IDownloadApprovedReports downloadApprovedReports,
Logger logger)
2013-07-22 05:52:53 +03:00
{
_seasonService = seasonService;
_nzbSearchService = nzbSearchService;
_downloadApprovedReports = downloadApprovedReports;
_logger = logger;
2013-07-22 05:52:53 +03:00
}
public void Execute(SeriesSearchCommand message)
{
var seasons = _seasonService.GetSeasonsBySeries(message.SeriesId)
.Where(s => s.SeasonNumber > 0)
.OrderBy(s => s.SeasonNumber)
.ToList();
var downloadedCount = 0;
2013-07-22 05:52:53 +03:00
foreach (var season in seasons)
{
var decisions = _nzbSearchService.SeasonSearch(message.SeriesId, season.SeasonNumber);
downloadedCount += _downloadApprovedReports.DownloadApproved(decisions).Count;
2013-07-22 05:52:53 +03:00
}
2013-09-11 09:33:47 +03:00
_logger.ProgressInfo("Series search completed. {0} reports downloaded.", downloadedCount);
2013-07-22 05:52:53 +03:00
}
}
}