2013-09-04 08:01:28 +03:00
|
|
|
using NLog;
|
2013-06-19 05:08:29 +03:00
|
|
|
using NzbDrone.Core.Download;
|
2013-09-11 09:33:47 +03:00
|
|
|
using NzbDrone.Core.Instrumentation;
|
2013-09-14 09:36:07 +03:00
|
|
|
using NzbDrone.Core.Messaging.Commands;
|
2013-06-19 05:08:29 +03:00
|
|
|
|
|
|
|
namespace NzbDrone.Core.IndexerSearch
|
|
|
|
{
|
|
|
|
public class SeasonSearchService : IExecute<SeasonSearchCommand>
|
|
|
|
{
|
|
|
|
private readonly ISearchForNzb _nzbSearchService;
|
2013-06-19 08:44:50 +03:00
|
|
|
private readonly IDownloadApprovedReports _downloadApprovedReports;
|
2013-09-04 08:01:28 +03:00
|
|
|
private readonly Logger _logger;
|
2013-06-19 05:08:29 +03:00
|
|
|
|
2013-09-04 08:01:28 +03:00
|
|
|
public SeasonSearchService(ISearchForNzb nzbSearchService,
|
|
|
|
IDownloadApprovedReports downloadApprovedReports,
|
|
|
|
Logger logger)
|
2013-06-19 05:08:29 +03:00
|
|
|
{
|
|
|
|
_nzbSearchService = nzbSearchService;
|
2013-06-19 08:44:50 +03:00
|
|
|
_downloadApprovedReports = downloadApprovedReports;
|
2013-09-04 08:01:28 +03:00
|
|
|
_logger = logger;
|
2013-06-19 05:08:29 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public void Execute(SeasonSearchCommand message)
|
|
|
|
{
|
|
|
|
var decisions = _nzbSearchService.SeasonSearch(message.SeriesId, message.SeasonNumber);
|
2013-09-04 08:01:28 +03:00
|
|
|
var downloaded = _downloadApprovedReports.DownloadApproved(decisions);
|
|
|
|
|
2013-09-11 09:33:47 +03:00
|
|
|
_logger.ProgressInfo("Season search completed. {0} reports downloaded.", downloaded.Count);
|
2013-06-19 05:08:29 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|