2014-12-19 00:26:42 +00:00
|
|
|
|
using System.Collections.Generic;
|
2013-02-23 21:29:22 +00:00
|
|
|
|
using System.Linq;
|
2013-05-10 22:33:04 +00:00
|
|
|
|
using Marr.Data.QGen;
|
2013-02-23 21:29:22 +00:00
|
|
|
|
using NzbDrone.Core.Datastore;
|
2013-09-14 06:36:07 +00:00
|
|
|
|
using NzbDrone.Core.Messaging.Events;
|
2014-01-18 11:44:36 +00:00
|
|
|
|
using NzbDrone.Core.Qualities;
|
2013-02-23 21:29:22 +00:00
|
|
|
|
using NzbDrone.Core.Tv;
|
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.History
|
|
|
|
|
{
|
|
|
|
|
public interface IHistoryRepository : IBasicRepository<History>
|
|
|
|
|
{
|
2013-10-06 18:06:39 +00:00
|
|
|
|
List<QualityModel> GetBestQualityInHistory(int episodeId);
|
2013-10-24 05:13:04 +00:00
|
|
|
|
History MostRecentForEpisode(int episodeId);
|
2014-12-19 00:26:42 +00:00
|
|
|
|
History MostRecentForDownloadId(string downloadId);
|
|
|
|
|
List<History> FindByDownloadId(string downloadId);
|
|
|
|
|
List<History> FindDownloadHistory(int idSeriesId, QualityModel quality);
|
2013-02-23 21:29:22 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public class HistoryRepository : BasicRepository<History>, IHistoryRepository
|
|
|
|
|
{
|
2013-09-18 05:28:05 +00:00
|
|
|
|
|
2015-05-03 19:46:21 +00:00
|
|
|
|
public HistoryRepository(IMainDatabase database, IEventAggregator eventAggregator)
|
2013-09-14 06:36:07 +00:00
|
|
|
|
: base(database, eventAggregator)
|
2013-02-23 21:29:22 +00:00
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2013-10-06 18:06:39 +00:00
|
|
|
|
public List<QualityModel> GetBestQualityInHistory(int episodeId)
|
2013-02-23 21:29:22 +00:00
|
|
|
|
{
|
2013-05-14 05:40:06 +00:00
|
|
|
|
var history = Query.Where(c => c.EpisodeId == episodeId);
|
2013-02-23 21:29:22 +00:00
|
|
|
|
|
2013-05-14 05:40:06 +00:00
|
|
|
|
return history.Select(h => h.Quality).ToList();
|
2013-02-23 21:29:22 +00:00
|
|
|
|
}
|
2013-05-07 02:32:43 +00:00
|
|
|
|
|
2013-10-24 05:13:04 +00:00
|
|
|
|
public History MostRecentForEpisode(int episodeId)
|
|
|
|
|
{
|
|
|
|
|
return Query.Where(h => h.EpisodeId == episodeId)
|
|
|
|
|
.OrderByDescending(h => h.Date)
|
|
|
|
|
.FirstOrDefault();
|
|
|
|
|
}
|
|
|
|
|
|
2014-12-19 00:26:42 +00:00
|
|
|
|
public History MostRecentForDownloadId(string downloadId)
|
|
|
|
|
{
|
|
|
|
|
return Query.Where(h => h.DownloadId == downloadId)
|
|
|
|
|
.OrderByDescending(h => h.Date)
|
|
|
|
|
.FirstOrDefault();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public List<History> FindByDownloadId(string downloadId)
|
2014-04-01 20:07:41 +00:00
|
|
|
|
{
|
2014-12-19 00:26:42 +00:00
|
|
|
|
return Query.Where(h => h.DownloadId == downloadId);
|
2014-04-01 20:07:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
2014-12-19 00:26:42 +00:00
|
|
|
|
public List<History> FindDownloadHistory(int idSeriesId, QualityModel quality)
|
2014-04-01 20:07:41 +00:00
|
|
|
|
{
|
2014-12-19 00:26:42 +00:00
|
|
|
|
return Query.Where(h =>
|
|
|
|
|
h.SeriesId == idSeriesId &&
|
|
|
|
|
h.Quality == quality &&
|
|
|
|
|
(h.EventType == HistoryEventType.Grabbed ||
|
|
|
|
|
h.EventType == HistoryEventType.DownloadFailed ||
|
|
|
|
|
h.EventType == HistoryEventType.DownloadFolderImported)
|
|
|
|
|
).ToList();
|
2014-04-01 20:07:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
2014-02-01 22:09:22 +00:00
|
|
|
|
protected override SortBuilder<History> GetPagedQuery(QueryBuilder<History> query, PagingSpec<History> pagingSpec)
|
2013-10-04 06:01:02 +00:00
|
|
|
|
{
|
2014-02-01 22:09:22 +00:00
|
|
|
|
var baseQuery = query.Join<History, Series>(JoinType.Inner, h => h.Series, (h, s) => h.SeriesId == s.Id)
|
|
|
|
|
.Join<History, Episode>(JoinType.Inner, h => h.Episode, (h, e) => h.EpisodeId == e.Id);
|
2013-10-06 18:06:39 +00:00
|
|
|
|
|
2014-02-01 22:09:22 +00:00
|
|
|
|
return base.GetPagedQuery(baseQuery, pagingSpec);
|
2013-05-10 22:33:04 +00:00
|
|
|
|
}
|
2013-02-23 21:29:22 +00:00
|
|
|
|
}
|
|
|
|
|
}
|