2020-03-29 17:48:34 +00:00
|
|
|
using NLog;
|
|
|
|
using NzbDrone.Core.Download.TrackedDownloads;
|
|
|
|
using NzbDrone.Core.Messaging.Events;
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.Download
|
|
|
|
{
|
|
|
|
public interface IIgnoredDownloadService
|
|
|
|
{
|
|
|
|
bool IgnoreDownload(TrackedDownload trackedDownload);
|
|
|
|
}
|
|
|
|
|
|
|
|
public class IgnoredDownloadService : IIgnoredDownloadService
|
|
|
|
{
|
|
|
|
private readonly IEventAggregator _eventAggregator;
|
|
|
|
private readonly Logger _logger;
|
|
|
|
|
|
|
|
public IgnoredDownloadService(IEventAggregator eventAggregator,
|
|
|
|
Logger logger)
|
|
|
|
{
|
|
|
|
_eventAggregator = eventAggregator;
|
|
|
|
_logger = logger;
|
|
|
|
}
|
|
|
|
|
|
|
|
public bool IgnoreDownload(TrackedDownload trackedDownload)
|
|
|
|
{
|
|
|
|
var movie = trackedDownload.RemoteMovie.Movie;
|
|
|
|
|
|
|
|
if (movie == null)
|
|
|
|
{
|
|
|
|
_logger.Warn("Unable to ignore download for unknown movie");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
var downloadIgnoredEvent = new DownloadIgnoredEvent
|
|
|
|
{
|
|
|
|
MovieId = movie.Id,
|
|
|
|
Languages = trackedDownload.RemoteMovie.ParsedMovieInfo.Languages,
|
|
|
|
Quality = trackedDownload.RemoteMovie.ParsedMovieInfo.Quality,
|
|
|
|
SourceTitle = trackedDownload.DownloadItem.Title,
|
2020-03-29 20:05:48 +00:00
|
|
|
DownloadClientInfo = trackedDownload.DownloadItem.DownloadClientInfo,
|
2020-03-29 17:48:34 +00:00
|
|
|
DownloadId = trackedDownload.DownloadItem.DownloadId,
|
2022-03-06 23:27:25 +00:00
|
|
|
TrackedDownload = trackedDownload,
|
2020-03-29 17:48:34 +00:00
|
|
|
Message = "Manually ignored"
|
|
|
|
};
|
|
|
|
|
|
|
|
_eventAggregator.PublishEvent(downloadIgnoredEvent);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|