|
|
@ -7,13 +7,13 @@ using NzbDrone.Core.Indexers;
|
|
|
|
using NzbDrone.Core.Messaging.Commands;
|
|
|
|
using NzbDrone.Core.Messaging.Commands;
|
|
|
|
using NzbDrone.Core.Messaging.Events;
|
|
|
|
using NzbDrone.Core.Messaging.Events;
|
|
|
|
using NzbDrone.Core.Parser.Model;
|
|
|
|
using NzbDrone.Core.Parser.Model;
|
|
|
|
using NzbDrone.Core.Tv.Events;
|
|
|
|
using NzbDrone.Core.Music.Events;
|
|
|
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.Blacklisting
|
|
|
|
namespace NzbDrone.Core.Blacklisting
|
|
|
|
{
|
|
|
|
{
|
|
|
|
public interface IBlacklistService
|
|
|
|
public interface IBlacklistService
|
|
|
|
{
|
|
|
|
{
|
|
|
|
bool Blacklisted(int seriesId, ReleaseInfo release);
|
|
|
|
bool Blacklisted(int artistId, ReleaseInfo release);
|
|
|
|
PagingSpec<Blacklist> Paged(PagingSpec<Blacklist> pagingSpec);
|
|
|
|
PagingSpec<Blacklist> Paged(PagingSpec<Blacklist> pagingSpec);
|
|
|
|
void Delete(int id);
|
|
|
|
void Delete(int id);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -21,7 +21,7 @@ namespace NzbDrone.Core.Blacklisting
|
|
|
|
|
|
|
|
|
|
|
|
IExecute<ClearBlacklistCommand>,
|
|
|
|
IExecute<ClearBlacklistCommand>,
|
|
|
|
IHandle<DownloadFailedEvent>,
|
|
|
|
IHandle<DownloadFailedEvent>,
|
|
|
|
IHandleAsync<SeriesDeletedEvent>
|
|
|
|
IHandleAsync<ArtistDeletedEvent>
|
|
|
|
{
|
|
|
|
{
|
|
|
|
private readonly IBlacklistRepository _blacklistRepository;
|
|
|
|
private readonly IBlacklistRepository _blacklistRepository;
|
|
|
|
|
|
|
|
|
|
|
@ -30,9 +30,9 @@ namespace NzbDrone.Core.Blacklisting
|
|
|
|
_blacklistRepository = blacklistRepository;
|
|
|
|
_blacklistRepository = blacklistRepository;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public bool Blacklisted(int seriesId, ReleaseInfo release)
|
|
|
|
public bool Blacklisted(int artistId, ReleaseInfo release)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var blacklistedByTitle = _blacklistRepository.BlacklistedByTitle(seriesId, release.Title);
|
|
|
|
var blacklistedByTitle = _blacklistRepository.BlacklistedByTitle(artistId, release.Title);
|
|
|
|
|
|
|
|
|
|
|
|
if (release.DownloadProtocol == DownloadProtocol.Torrent)
|
|
|
|
if (release.DownloadProtocol == DownloadProtocol.Torrent)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -46,7 +46,7 @@ namespace NzbDrone.Core.Blacklisting
|
|
|
|
.Any(b => SameTorrent(b, torrentInfo));
|
|
|
|
.Any(b => SameTorrent(b, torrentInfo));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
var blacklistedByTorrentInfohash = _blacklistRepository.BlacklistedByTorrentInfoHash(seriesId, torrentInfo.InfoHash);
|
|
|
|
var blacklistedByTorrentInfohash = _blacklistRepository.BlacklistedByTorrentInfoHash(artistId, torrentInfo.InfoHash);
|
|
|
|
|
|
|
|
|
|
|
|
return blacklistedByTorrentInfohash.Any(b => SameTorrent(b, torrentInfo));
|
|
|
|
return blacklistedByTorrentInfohash.Any(b => SameTorrent(b, torrentInfo));
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -128,8 +128,8 @@ namespace NzbDrone.Core.Blacklisting
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var blacklist = new Blacklist
|
|
|
|
var blacklist = new Blacklist
|
|
|
|
{
|
|
|
|
{
|
|
|
|
SeriesId = message.SeriesId,
|
|
|
|
ArtistId = message.ArtistId,
|
|
|
|
EpisodeIds = message.EpisodeIds,
|
|
|
|
AlbumIds = message.AlbumIds,
|
|
|
|
SourceTitle = message.SourceTitle,
|
|
|
|
SourceTitle = message.SourceTitle,
|
|
|
|
Quality = message.Quality,
|
|
|
|
Quality = message.Quality,
|
|
|
|
Date = DateTime.UtcNow,
|
|
|
|
Date = DateTime.UtcNow,
|
|
|
@ -144,9 +144,9 @@ namespace NzbDrone.Core.Blacklisting
|
|
|
|
_blacklistRepository.Insert(blacklist);
|
|
|
|
_blacklistRepository.Insert(blacklist);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public void HandleAsync(SeriesDeletedEvent message)
|
|
|
|
public void HandleAsync(ArtistDeletedEvent message)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var blacklisted = _blacklistRepository.BlacklistedBySeries(message.Series.Id);
|
|
|
|
var blacklisted = _blacklistRepository.BlacklistedByArtist(message.Artist.Id);
|
|
|
|
|
|
|
|
|
|
|
|
_blacklistRepository.DeleteMany(blacklisted);
|
|
|
|
_blacklistRepository.DeleteMany(blacklisted);
|
|
|
|
}
|
|
|
|
}
|
|
|
|