mirror of
https://github.com/lidarr/lidarr.git
synced 2025-08-23 06:45:19 -07:00
Update blacklist to work with movies (#1089)
* Update BlacklistService * Update HistoryService, HistoryRepo and History * Update UI in Blacklists to movies * set the movie model so the movie title prints in blacklist * Would be working if I implemented the Event Handler for MovieFileDeleted
This commit is contained in:
parent
ae0fc019e5
commit
1a4fb6e7bb
12 changed files with 212 additions and 142 deletions
|
@ -1,8 +1,6 @@
|
||||||
using System;
|
using System;
|
||||||
using Nancy;
|
using Nancy;
|
||||||
using NzbDrone.Api.Episodes;
|
|
||||||
using NzbDrone.Api.Extensions;
|
using NzbDrone.Api.Extensions;
|
||||||
using NzbDrone.Api.Series;
|
|
||||||
using NzbDrone.Api.Movie;
|
using NzbDrone.Api.Movie;
|
||||||
using NzbDrone.Core.Datastore;
|
using NzbDrone.Core.Datastore;
|
||||||
using NzbDrone.Core.DecisionEngine;
|
using NzbDrone.Core.DecisionEngine;
|
||||||
|
@ -32,16 +30,8 @@ namespace NzbDrone.Api.History
|
||||||
protected HistoryResource MapToResource(Core.History.History model)
|
protected HistoryResource MapToResource(Core.History.History model)
|
||||||
{
|
{
|
||||||
var resource = model.ToResource();
|
var resource = model.ToResource();
|
||||||
|
|
||||||
resource.Series = model.Series.ToResource();
|
|
||||||
resource.Episode = model.Episode.ToResource();
|
|
||||||
resource.Movie = model.Movie.ToResource();
|
resource.Movie = model.Movie.ToResource();
|
||||||
|
|
||||||
if (model.Series != null)
|
|
||||||
{
|
|
||||||
resource.QualityCutoffNotMet = _qualityUpgradableSpecification.CutoffNotMet(model.Series.Profile.Value, model.Quality);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (model.Movie != null)
|
if (model.Movie != null)
|
||||||
{
|
{
|
||||||
resource.QualityCutoffNotMet = _qualityUpgradableSpecification.CutoffNotMet(model.Movie.Profile.Value, model.Quality);
|
resource.QualityCutoffNotMet = _qualityUpgradableSpecification.CutoffNotMet(model.Movie.Profile.Value, model.Quality);
|
||||||
|
@ -52,8 +42,6 @@ namespace NzbDrone.Api.History
|
||||||
|
|
||||||
private PagingResource<HistoryResource> GetHistory(PagingResource<HistoryResource> pagingResource)
|
private PagingResource<HistoryResource> GetHistory(PagingResource<HistoryResource> pagingResource)
|
||||||
{
|
{
|
||||||
var episodeId = Request.Query.EpisodeId;
|
|
||||||
|
|
||||||
var movieId = Request.Query.MovieId;
|
var movieId = Request.Query.MovieId;
|
||||||
|
|
||||||
var pagingSpec = pagingResource.MapToPagingSpec<HistoryResource, Core.History.History>("date", SortDirection.Descending);
|
var pagingSpec = pagingResource.MapToPagingSpec<HistoryResource, Core.History.History>("date", SortDirection.Descending);
|
||||||
|
@ -64,12 +52,6 @@ namespace NzbDrone.Api.History
|
||||||
pagingSpec.FilterExpression = v => v.EventType == filterValue;
|
pagingSpec.FilterExpression = v => v.EventType == filterValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (episodeId.HasValue)
|
|
||||||
{
|
|
||||||
int i = (int)episodeId;
|
|
||||||
pagingSpec.FilterExpression = h => h.EpisodeId == i;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (movieId.HasValue)
|
if (movieId.HasValue)
|
||||||
{
|
{
|
||||||
int i = (int)movieId;
|
int i = (int)movieId;
|
||||||
|
|
|
@ -19,8 +19,9 @@ namespace NzbDrone.Core.Test.Blacklisting
|
||||||
{
|
{
|
||||||
_event = new DownloadFailedEvent
|
_event = new DownloadFailedEvent
|
||||||
{
|
{
|
||||||
SeriesId = 12345,
|
SeriesId = 0,
|
||||||
EpisodeIds = new List<int> {1},
|
MovieId = 69,
|
||||||
|
EpisodeIds = null,
|
||||||
Quality = new QualityModel(Quality.Bluray720p),
|
Quality = new QualityModel(Quality.Bluray720p),
|
||||||
SourceTitle = "series.title.s01e01",
|
SourceTitle = "series.title.s01e01",
|
||||||
DownloadClient = "SabnzbdClient",
|
DownloadClient = "SabnzbdClient",
|
||||||
|
@ -40,7 +41,7 @@ namespace NzbDrone.Core.Test.Blacklisting
|
||||||
Subject.Handle(_event);
|
Subject.Handle(_event);
|
||||||
|
|
||||||
Mocker.GetMock<IBlacklistRepository>()
|
Mocker.GetMock<IBlacklistRepository>()
|
||||||
.Verify(v => v.Insert(It.Is<Blacklist>(b => b.EpisodeIds == _event.EpisodeIds)), Times.Once());
|
.Verify(v => v.Insert(It.Is<Blacklist>(b => b.MovieId == _event.MovieId)), Times.Once());
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
|
@ -52,7 +53,7 @@ namespace NzbDrone.Core.Test.Blacklisting
|
||||||
_event.Data.Remove("protocol");
|
_event.Data.Remove("protocol");
|
||||||
|
|
||||||
Mocker.GetMock<IBlacklistRepository>()
|
Mocker.GetMock<IBlacklistRepository>()
|
||||||
.Verify(v => v.Insert(It.Is<Blacklist>(b => b.EpisodeIds == _event.EpisodeIds)), Times.Once());
|
.Verify(v => v.Insert(It.Is<Blacklist>(b => b.MovieId == _event.MovieId)), Times.Once());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -129,7 +129,7 @@ namespace NzbDrone.Core.Blacklisting
|
||||||
var blacklist = new Blacklist
|
var blacklist = new Blacklist
|
||||||
{
|
{
|
||||||
SeriesId = 0,
|
SeriesId = 0,
|
||||||
EpisodeIds = message.EpisodeIds,
|
EpisodeIds = null,
|
||||||
MovieId = message.MovieId,
|
MovieId = message.MovieId,
|
||||||
SourceTitle = message.SourceTitle,
|
SourceTitle = message.SourceTitle,
|
||||||
Quality = message.Quality,
|
Quality = message.Quality,
|
||||||
|
|
|
@ -35,9 +35,11 @@ namespace NzbDrone.Core.History
|
||||||
{
|
{
|
||||||
Unknown = 0,
|
Unknown = 0,
|
||||||
Grabbed = 1,
|
Grabbed = 1,
|
||||||
SeriesFolderImported = 2,
|
SeriesFolderImported = 2, // to be deprecate
|
||||||
DownloadFolderImported = 3,
|
DownloadFolderImported = 3,
|
||||||
DownloadFailed = 4,
|
DownloadFailed = 4,
|
||||||
EpisodeFileDeleted = 5
|
EpisodeFileDeleted = 5, // deprecated
|
||||||
|
MovieFileDeleted = 6,
|
||||||
|
MovieFolderImported = 7, // not used yet
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -17,6 +17,7 @@ namespace NzbDrone.Core.History
|
||||||
List<History> FindByDownloadId(string downloadId);
|
List<History> FindByDownloadId(string downloadId);
|
||||||
List<History> FindDownloadHistory(int idSeriesId, QualityModel quality);
|
List<History> FindDownloadHistory(int idSeriesId, QualityModel quality);
|
||||||
void DeleteForSeries(int seriesId);
|
void DeleteForSeries(int seriesId);
|
||||||
|
void DeleteForMovie(int movieId);
|
||||||
History MostRecentForMovie(int movieId);
|
History MostRecentForMovie(int movieId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -71,6 +72,11 @@ namespace NzbDrone.Core.History
|
||||||
Delete(c => c.SeriesId == seriesId);
|
Delete(c => c.SeriesId == seriesId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void DeleteForMovie(int movieId)
|
||||||
|
{
|
||||||
|
Delete(c => c.MovieId == movieId);
|
||||||
|
}
|
||||||
|
|
||||||
protected override SortBuilder<History> GetPagedQuery(QueryBuilder<History> query, PagingSpec<History> pagingSpec)
|
protected override SortBuilder<History> GetPagedQuery(QueryBuilder<History> query, PagingSpec<History> pagingSpec)
|
||||||
{
|
{
|
||||||
var baseQuery = query/*.Join<History, Series>(JoinType.Inner, h => h.Series, (h, s) => h.SeriesId == s.Id)
|
var baseQuery = query/*.Join<History, Series>(JoinType.Inner, h => h.Series, (h, s) => h.SeriesId == s.Id)
|
||||||
|
|
|
@ -35,6 +35,7 @@ namespace NzbDrone.Core.History
|
||||||
IHandle<EpisodeImportedEvent>,
|
IHandle<EpisodeImportedEvent>,
|
||||||
IHandle<DownloadFailedEvent>,
|
IHandle<DownloadFailedEvent>,
|
||||||
IHandle<EpisodeFileDeletedEvent>,
|
IHandle<EpisodeFileDeletedEvent>,
|
||||||
|
IHandle<MovieFileDeletedEvent>,
|
||||||
IHandle<SeriesDeletedEvent>
|
IHandle<SeriesDeletedEvent>
|
||||||
{
|
{
|
||||||
private readonly IHistoryRepository _historyRepository;
|
private readonly IHistoryRepository _historyRepository;
|
||||||
|
@ -89,6 +90,160 @@ namespace NzbDrone.Core.History
|
||||||
.FirstOrDefault();
|
.FirstOrDefault();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void Handle(MovieGrabbedEvent message)
|
||||||
|
{
|
||||||
|
var history = new History
|
||||||
|
{
|
||||||
|
EventType = HistoryEventType.Grabbed,
|
||||||
|
Date = DateTime.UtcNow,
|
||||||
|
Quality = message.Movie.ParsedMovieInfo.Quality,
|
||||||
|
SourceTitle = message.Movie.Release.Title,
|
||||||
|
SeriesId = 0,
|
||||||
|
EpisodeId = 0,
|
||||||
|
DownloadId = message.DownloadId,
|
||||||
|
MovieId = message.Movie.Movie.Id
|
||||||
|
};
|
||||||
|
|
||||||
|
history.Data.Add("Indexer", message.Movie.Release.Indexer);
|
||||||
|
history.Data.Add("NzbInfoUrl", message.Movie.Release.InfoUrl);
|
||||||
|
history.Data.Add("ReleaseGroup", message.Movie.ParsedMovieInfo.ReleaseGroup);
|
||||||
|
history.Data.Add("Age", message.Movie.Release.Age.ToString());
|
||||||
|
history.Data.Add("AgeHours", message.Movie.Release.AgeHours.ToString());
|
||||||
|
history.Data.Add("AgeMinutes", message.Movie.Release.AgeMinutes.ToString());
|
||||||
|
history.Data.Add("PublishedDate", message.Movie.Release.PublishDate.ToString("s") + "Z");
|
||||||
|
history.Data.Add("DownloadClient", message.DownloadClient);
|
||||||
|
history.Data.Add("Size", message.Movie.Release.Size.ToString());
|
||||||
|
history.Data.Add("DownloadUrl", message.Movie.Release.DownloadUrl);
|
||||||
|
history.Data.Add("Guid", message.Movie.Release.Guid);
|
||||||
|
history.Data.Add("TvdbId", message.Movie.Release.TvdbId.ToString());
|
||||||
|
history.Data.Add("TvRageId", message.Movie.Release.TvRageId.ToString());
|
||||||
|
history.Data.Add("Protocol", ((int)message.Movie.Release.DownloadProtocol).ToString());
|
||||||
|
|
||||||
|
if (!message.Movie.ParsedMovieInfo.ReleaseHash.IsNullOrWhiteSpace())
|
||||||
|
{
|
||||||
|
history.Data.Add("ReleaseHash", message.Movie.ParsedMovieInfo.ReleaseHash);
|
||||||
|
}
|
||||||
|
|
||||||
|
var torrentRelease = message.Movie.Release as TorrentInfo;
|
||||||
|
|
||||||
|
if (torrentRelease != null)
|
||||||
|
{
|
||||||
|
history.Data.Add("TorrentInfoHash", torrentRelease.InfoHash);
|
||||||
|
}
|
||||||
|
|
||||||
|
_historyRepository.Insert(history);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Handle(MovieImportedEvent message)
|
||||||
|
{
|
||||||
|
if (!message.NewDownload)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var downloadId = message.DownloadId;
|
||||||
|
|
||||||
|
if (downloadId.IsNullOrWhiteSpace())
|
||||||
|
{
|
||||||
|
downloadId = FindDownloadId(message); //For now fuck off.
|
||||||
|
}
|
||||||
|
|
||||||
|
var movie = message.MovieInfo.Movie;
|
||||||
|
var history = new History
|
||||||
|
{
|
||||||
|
EventType = HistoryEventType.DownloadFolderImported,
|
||||||
|
Date = DateTime.UtcNow,
|
||||||
|
Quality = message.MovieInfo.Quality,
|
||||||
|
SourceTitle = movie.Title,
|
||||||
|
SeriesId = 0,
|
||||||
|
EpisodeId = 0,
|
||||||
|
DownloadId = downloadId,
|
||||||
|
MovieId = movie.Id,
|
||||||
|
};
|
||||||
|
|
||||||
|
//Won't have a value since we publish this event before saving to DB.
|
||||||
|
//history.Data.Add("FileId", message.ImportedEpisode.Id.ToString());
|
||||||
|
history.Data.Add("DroppedPath", message.MovieInfo.Path);
|
||||||
|
history.Data.Add("ImportedPath", Path.Combine(movie.Path, message.ImportedMovie.RelativePath));
|
||||||
|
history.Data.Add("DownloadClient", message.DownloadClient);
|
||||||
|
|
||||||
|
_historyRepository.Insert(history);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Handle(MovieFileDeletedEvent message)
|
||||||
|
{
|
||||||
|
if (message.Reason == DeleteMediaFileReason.NoLinkedEpisodes)
|
||||||
|
{
|
||||||
|
_logger.Debug("Removing movie file from DB as part of cleanup routine, not creating history event.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var history = new History
|
||||||
|
{
|
||||||
|
EventType = HistoryEventType.MovieFileDeleted,
|
||||||
|
Date = DateTime.UtcNow,
|
||||||
|
Quality = message.MovieFile.Quality,
|
||||||
|
SourceTitle = message.MovieFile.Path,
|
||||||
|
SeriesId = 0,
|
||||||
|
EpisodeId = 0,
|
||||||
|
MovieId = message.MovieFile.MovieId
|
||||||
|
};
|
||||||
|
|
||||||
|
history.Data.Add("Reason", message.Reason.ToString());
|
||||||
|
|
||||||
|
_historyRepository.Insert(history);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Handle(MovieDeletedEvent message)
|
||||||
|
{
|
||||||
|
_historyRepository.DeleteForMovie(message.Movie.Id);
|
||||||
|
}
|
||||||
|
|
||||||
|
private string FindDownloadId(MovieImportedEvent trackedDownload)
|
||||||
|
{
|
||||||
|
_logger.Debug("Trying to find downloadId for {0} from history", trackedDownload.ImportedMovie.Path);
|
||||||
|
|
||||||
|
var movieId = trackedDownload.MovieInfo.Movie.Id;
|
||||||
|
|
||||||
|
var allHistory = _historyRepository.FindDownloadHistory(movieId, trackedDownload.ImportedMovie.Quality);
|
||||||
|
|
||||||
|
//Find download related items for this movie
|
||||||
|
var movieHistory = allHistory.Where(h => movieId == h.MovieId).ToList();
|
||||||
|
|
||||||
|
var processedDownloadId = movieHistory
|
||||||
|
.Where(c => c.EventType != HistoryEventType.Grabbed && c.DownloadId != null)
|
||||||
|
.Select(c => c.DownloadId);
|
||||||
|
|
||||||
|
var stillDownloading = movieHistory.Where(c => c.EventType == HistoryEventType.Grabbed && !processedDownloadId.Contains(c.DownloadId)).ToList();
|
||||||
|
|
||||||
|
string downloadId = null;
|
||||||
|
|
||||||
|
if (stillDownloading.Any())
|
||||||
|
{
|
||||||
|
//foreach (var matchingHistory in trackedDownload.EpisodeInfo.Episodes.Select(e => stillDownloading.Where(c => c.MovieId == e.Id).ToList()))
|
||||||
|
//foreach (var matchingHistory in stillDownloading.Where(c => c.MovieId == e.Id).ToList())
|
||||||
|
//{
|
||||||
|
if (stillDownloading.Count != 1)
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
var newDownloadId = stillDownloading.Single().DownloadId;
|
||||||
|
|
||||||
|
if (downloadId == null || downloadId == newDownloadId)
|
||||||
|
{
|
||||||
|
downloadId = newDownloadId;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
}
|
||||||
|
|
||||||
|
return downloadId;
|
||||||
|
}
|
||||||
|
|
||||||
private string FindDownloadId(EpisodeImportedEvent trackedDownload)
|
private string FindDownloadId(EpisodeImportedEvent trackedDownload)
|
||||||
{
|
{
|
||||||
_logger.Debug("Trying to find downloadId for {0} from history", trackedDownload.ImportedEpisode.Path);
|
_logger.Debug("Trying to find downloadId for {0} from history", trackedDownload.ImportedEpisode.Path);
|
||||||
|
@ -181,50 +336,6 @@ namespace NzbDrone.Core.History
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Handle(MovieGrabbedEvent message)
|
|
||||||
{
|
|
||||||
var history = new History
|
|
||||||
{
|
|
||||||
EventType = HistoryEventType.Grabbed,
|
|
||||||
Date = DateTime.UtcNow,
|
|
||||||
Quality = message.Movie.ParsedMovieInfo.Quality,
|
|
||||||
SourceTitle = message.Movie.Release.Title,
|
|
||||||
SeriesId = 0,
|
|
||||||
EpisodeId = 0,
|
|
||||||
DownloadId = message.DownloadId,
|
|
||||||
MovieId = message.Movie.Movie.Id
|
|
||||||
};
|
|
||||||
|
|
||||||
history.Data.Add("Indexer", message.Movie.Release.Indexer);
|
|
||||||
history.Data.Add("NzbInfoUrl", message.Movie.Release.InfoUrl);
|
|
||||||
history.Data.Add("ReleaseGroup", message.Movie.ParsedMovieInfo.ReleaseGroup);
|
|
||||||
history.Data.Add("Age", message.Movie.Release.Age.ToString());
|
|
||||||
history.Data.Add("AgeHours", message.Movie.Release.AgeHours.ToString());
|
|
||||||
history.Data.Add("AgeMinutes", message.Movie.Release.AgeMinutes.ToString());
|
|
||||||
history.Data.Add("PublishedDate", message.Movie.Release.PublishDate.ToString("s") + "Z");
|
|
||||||
history.Data.Add("DownloadClient", message.DownloadClient);
|
|
||||||
history.Data.Add("Size", message.Movie.Release.Size.ToString());
|
|
||||||
history.Data.Add("DownloadUrl", message.Movie.Release.DownloadUrl);
|
|
||||||
history.Data.Add("Guid", message.Movie.Release.Guid);
|
|
||||||
history.Data.Add("TvdbId", message.Movie.Release.TvdbId.ToString());
|
|
||||||
history.Data.Add("TvRageId", message.Movie.Release.TvRageId.ToString());
|
|
||||||
history.Data.Add("Protocol", ((int)message.Movie.Release.DownloadProtocol).ToString());
|
|
||||||
|
|
||||||
if (!message.Movie.ParsedMovieInfo.ReleaseHash.IsNullOrWhiteSpace())
|
|
||||||
{
|
|
||||||
history.Data.Add("ReleaseHash", message.Movie.ParsedMovieInfo.ReleaseHash);
|
|
||||||
}
|
|
||||||
|
|
||||||
var torrentRelease = message.Movie.Release as TorrentInfo;
|
|
||||||
|
|
||||||
if (torrentRelease != null)
|
|
||||||
{
|
|
||||||
history.Data.Add("TorrentInfoHash", torrentRelease.InfoHash);
|
|
||||||
}
|
|
||||||
|
|
||||||
_historyRepository.Insert(history);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void Handle(EpisodeImportedEvent message)
|
public void Handle(EpisodeImportedEvent message)
|
||||||
{
|
{
|
||||||
if (!message.NewDownload)
|
if (!message.NewDownload)
|
||||||
|
@ -251,8 +362,6 @@ namespace NzbDrone.Core.History
|
||||||
EpisodeId = episode.Id,
|
EpisodeId = episode.Id,
|
||||||
DownloadId = downloadId,
|
DownloadId = downloadId,
|
||||||
MovieId = 0,
|
MovieId = 0,
|
||||||
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
//Won't have a value since we publish this event before saving to DB.
|
//Won't have a value since we publish this event before saving to DB.
|
||||||
|
@ -265,65 +374,24 @@ namespace NzbDrone.Core.History
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Handle(MovieImportedEvent message)
|
|
||||||
{
|
|
||||||
if (!message.NewDownload)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var downloadId = message.DownloadId;
|
|
||||||
|
|
||||||
if (downloadId.IsNullOrWhiteSpace())
|
|
||||||
{
|
|
||||||
//downloadId = FindDownloadId(message); For now fuck off.
|
|
||||||
}
|
|
||||||
|
|
||||||
var movie = message.MovieInfo.Movie;
|
|
||||||
var history = new History
|
|
||||||
{
|
|
||||||
EventType = HistoryEventType.DownloadFolderImported,
|
|
||||||
Date = DateTime.UtcNow,
|
|
||||||
Quality = message.MovieInfo.Quality,
|
|
||||||
SourceTitle = movie.Title,
|
|
||||||
SeriesId = 0,
|
|
||||||
EpisodeId = 0,
|
|
||||||
DownloadId = downloadId,
|
|
||||||
MovieId = movie.Id,
|
|
||||||
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
//Won't have a value since we publish this event before saving to DB.
|
|
||||||
//history.Data.Add("FileId", message.ImportedEpisode.Id.ToString());
|
|
||||||
history.Data.Add("DroppedPath", message.MovieInfo.Path);
|
|
||||||
history.Data.Add("ImportedPath", Path.Combine(movie.Path, message.ImportedMovie.RelativePath));
|
|
||||||
history.Data.Add("DownloadClient", message.DownloadClient);
|
|
||||||
|
|
||||||
_historyRepository.Insert(history);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public void Handle(DownloadFailedEvent message)
|
public void Handle(DownloadFailedEvent message)
|
||||||
{
|
{
|
||||||
foreach (var episodeId in message.EpisodeIds)
|
var history = new History
|
||||||
{
|
{
|
||||||
var history = new History
|
EventType = HistoryEventType.DownloadFailed,
|
||||||
{
|
Date = DateTime.UtcNow,
|
||||||
EventType = HistoryEventType.DownloadFailed,
|
Quality = message.Quality,
|
||||||
Date = DateTime.UtcNow,
|
SourceTitle = message.SourceTitle,
|
||||||
Quality = message.Quality,
|
SeriesId = 0,
|
||||||
SourceTitle = message.SourceTitle,
|
EpisodeId = 0,
|
||||||
SeriesId = message.SeriesId,
|
MovieId = message.MovieId,
|
||||||
EpisodeId = episodeId,
|
DownloadId = message.DownloadId
|
||||||
DownloadId = message.DownloadId
|
};
|
||||||
};
|
|
||||||
|
|
||||||
history.Data.Add("DownloadClient", message.DownloadClient);
|
history.Data.Add("DownloadClient", message.DownloadClient);
|
||||||
history.Data.Add("Message", message.Message);
|
history.Data.Add("Message", message.Message);
|
||||||
|
|
||||||
_historyRepository.Insert(history);
|
_historyRepository.Insert(history);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Handle(EpisodeFileDeletedEvent message)
|
public void Handle(EpisodeFileDeletedEvent message)
|
||||||
|
|
|
@ -26,7 +26,7 @@ var Collection = PageableCollection.extend({
|
||||||
},
|
},
|
||||||
|
|
||||||
sortMappings : {
|
sortMappings : {
|
||||||
'series' : { sortKey : 'series.sortTitle' }
|
'movie' : { sortKey : 'movie.title' }
|
||||||
},
|
},
|
||||||
|
|
||||||
parseState : function(resp) {
|
parseState : function(resp) {
|
||||||
|
|
|
@ -2,7 +2,7 @@ var vent = require('vent');
|
||||||
var Marionette = require('marionette');
|
var Marionette = require('marionette');
|
||||||
var Backgrid = require('backgrid');
|
var Backgrid = require('backgrid');
|
||||||
var BlacklistCollection = require('./BlacklistCollection');
|
var BlacklistCollection = require('./BlacklistCollection');
|
||||||
var SeriesTitleCell = require('../../Cells/SeriesTitleCell');
|
var MovieTitleCell = require('../../Cells/MovieTitleCell');
|
||||||
var QualityCell = require('../../Cells/QualityCell');
|
var QualityCell = require('../../Cells/QualityCell');
|
||||||
var RelativeDateCell = require('../../Cells/RelativeDateCell');
|
var RelativeDateCell = require('../../Cells/RelativeDateCell');
|
||||||
var BlacklistActionsCell = require('./BlacklistActionsCell');
|
var BlacklistActionsCell = require('./BlacklistActionsCell');
|
||||||
|
@ -21,9 +21,9 @@ module.exports = Marionette.Layout.extend({
|
||||||
|
|
||||||
columns : [
|
columns : [
|
||||||
{
|
{
|
||||||
name : 'series',
|
name : 'movie',
|
||||||
label : 'Series',
|
label : 'Movie Title',
|
||||||
cell : SeriesTitleCell
|
cell : MovieTitleCell
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name : 'sourceTitle',
|
name : 'sourceTitle',
|
||||||
|
|
|
@ -1,17 +1,23 @@
|
||||||
var Backbone = require('backbone');
|
var Backbone = require('backbone');
|
||||||
var SeriesCollection = require('../../Series/SeriesCollection');
|
var SeriesModel = require('../../Series/SeriesModel');
|
||||||
|
var EpisodeModel = require('../../Series/EpisodeModel');
|
||||||
|
var MovieModel = require('../../Movies/MovieModel');
|
||||||
|
var MoviesCollection = require('../../Movies/FullMovieCollection');
|
||||||
|
|
||||||
module.exports = Backbone.Model.extend({
|
module.exports = Backbone.Model.extend({
|
||||||
|
|
||||||
//Hack to deal with Backbone 1.0's bug
|
|
||||||
initialize : function() {
|
|
||||||
this.url = function() {
|
|
||||||
return this.collection.url + '/' + this.get('id');
|
|
||||||
};
|
|
||||||
},
|
|
||||||
|
|
||||||
parse : function(model) {
|
parse : function(model) {
|
||||||
model.series = SeriesCollection.get(model.seriesId);
|
if (model.series) {
|
||||||
|
model.series = new SeriesModel(model.series);
|
||||||
|
model.episode = new EpisodeModel(model.episode);
|
||||||
|
model.episode.set('series', model.series);
|
||||||
|
}
|
||||||
|
|
||||||
|
//if (model.movie) {
|
||||||
|
// model.movie = new MovieModel(model.movie);
|
||||||
|
//}
|
||||||
|
|
||||||
|
model.movie = MoviesCollection.get(model.movieId);
|
||||||
|
|
||||||
return model;
|
return model;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -45,7 +45,7 @@ var Collection = PageableCollection.extend({
|
||||||
],
|
],
|
||||||
'deleted' : [
|
'deleted' : [
|
||||||
'eventType',
|
'eventType',
|
||||||
'5'
|
'6'
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
@ -31,6 +31,10 @@ module.exports = NzbDroneCell.extend({
|
||||||
icon = 'icon-sonarr-deleted';
|
icon = 'icon-sonarr-deleted';
|
||||||
toolTip = 'Movie file deleted';
|
toolTip = 'Movie file deleted';
|
||||||
break;
|
break;
|
||||||
|
case 'movieFileDeleted':
|
||||||
|
icon = 'icon-sonarr-deleted';
|
||||||
|
toolTip = 'Movie file deleted';
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
icon = 'icon-sonarr-unknown';
|
icon = 'icon-sonarr-unknown';
|
||||||
toolTip = 'unknown event';
|
toolTip = 'unknown event';
|
||||||
|
|
|
@ -21,6 +21,7 @@ module.exports = Backbone.Model.extend({
|
||||||
//var timeSince = new Date().getTime() - date.getTime();
|
//var timeSince = new Date().getTime() - date.getTime();
|
||||||
//var numOfMonths = timeSince / 1000 / 60 / 60 / 24 / 30;
|
//var numOfMonths = timeSince / 1000 / 60 / 60 / 24 / 30;
|
||||||
|
|
||||||
|
// lol could return status
|
||||||
if (status === "announced") {
|
if (status === "announced") {
|
||||||
return "announced";
|
return "announced";
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue