sonarr-repo-only/NzbDrone.Core/History/HistoryRepository.cs

62 lines
1.9 KiB
C#
Raw Normal View History

2013-02-23 21:29:22 +00:00
using System;
2013-05-07 02:32:43 +00:00
using System.Collections.Generic;
2013-03-24 04:16:00 +00:00
using System.Data;
2013-02-23 21:29:22 +00:00
using System.Linq;
2013-05-10 22:33:04 +00:00
using Marr.Data.QGen;
2013-05-05 21:24:33 +00:00
using NzbDrone.Common.Messaging;
2013-02-23 21:29:22 +00:00
using NzbDrone.Core.Datastore;
using NzbDrone.Core.Tv;
namespace NzbDrone.Core.History
{
public interface IHistoryRepository : IBasicRepository<History>
{
void Trim();
2013-03-25 01:38:11 +00:00
QualityModel GetBestQualityInHistory(int episodeId);
2013-05-10 22:33:04 +00:00
PagingSpec<History> Paged(PagingSpec<History> pagingSpec);
2013-02-23 21:29:22 +00:00
}
public class HistoryRepository : BasicRepository<History>, IHistoryRepository
{
2013-05-05 21:24:33 +00:00
public HistoryRepository(IDatabase database, IMessageAggregator messageAggregator)
: base(database, messageAggregator)
2013-02-23 21:29:22 +00:00
{
}
public void Trim()
{
2013-03-27 03:44:52 +00:00
var cutoff = DateTime.Now.AddDays(-30).Date;
Delete(c=> c.Date < cutoff);
2013-02-23 21:29:22 +00:00
}
2013-03-25 01:38:11 +00:00
public QualityModel GetBestQualityInHistory(int episodeId)
2013-02-23 21:29:22 +00:00
{
2013-03-27 03:44:52 +00:00
var history = Query.Where(c => c.EpisodeId == episodeId)
2013-03-24 04:16:00 +00:00
.OrderByDescending(c => c.Quality).FirstOrDefault();
2013-02-23 21:29:22 +00:00
if (history != null)
{
return history.Quality;
}
return null;
}
2013-05-07 02:32:43 +00:00
2013-05-10 22:33:04 +00:00
public PagingSpec<History> Paged(PagingSpec<History> pagingSpec)
{
var pagingQuery = 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)
.OrderBy(pagingSpec.OrderByClause(), pagingSpec.ToSortDirection())
.Skip(pagingSpec.PagingOffset())
.Take(pagingSpec.PageSize);
pagingSpec.Records = pagingQuery.ToList();
//TODO: Use the same query for count and records
pagingSpec.TotalRecords = Count();
return pagingSpec;
}
2013-02-23 21:29:22 +00:00
}
}