Lidarr/NzbDrone.Core/Tv/EpisodeRepository.cs

138 lines
5.7 KiB
C#
Raw Normal View History

2013-05-03 00:25:51 +00:00
using System;
using System.Collections.Generic;
2013-05-02 05:50:34 +00:00
using System.ComponentModel;
2013-03-24 04:16:00 +00:00
using System.Data;
using System.Linq;
2013-05-02 05:50:34 +00:00
using Marr.Data;
2013-04-17 02:46:07 +00:00
using Marr.Data.QGen;
using NzbDrone.Core.Datastore;
using NzbDrone.Core.Model;
2013-03-25 03:51:32 +00:00
namespace NzbDrone.Core.Tv
{
public interface IEpisodeRepository : IBasicRepository<Episode>
{
Episode Get(int seriesId, int season, int episodeNumber);
Episode Get(int seriesId, DateTime date);
List<Episode> GetEpisodes(int seriesId);
List<Episode> GetEpisodes(int seriesId, int seasonNumber);
List<Episode> GetEpisodeByFileId(int fileId);
2013-05-02 05:50:34 +00:00
PagingSpec<Episode> EpisodesWithoutFiles(PagingSpec<Episode> pagingSpec, bool includeSpecials);
Episode GetEpisodeBySceneNumbering(int seriesId, int seasonNumber, int episodeNumber);
List<Episode> EpisodesWithFiles();
List<Episode> EpisodesBetweenDates(DateTime startDate, DateTime endDate);
2013-03-01 07:03:41 +00:00
void SetIgnoreFlat(Episode episode, bool ignoreFlag);
void SetPostDownloadStatus(int episodeId, PostDownloadStatusType status);
void SetFileId(int episodeId, int fileId);
}
public class EpisodeRepository : BasicRepository<Episode>, IEpisodeRepository
{
2013-05-02 05:50:34 +00:00
private readonly IDataMapper _dataMapper;
2013-03-25 03:51:32 +00:00
public EpisodeRepository(IDatabase database)
2013-03-24 04:16:00 +00:00
: base(database)
{
2013-05-02 05:50:34 +00:00
_dataMapper = database.DataMapper;
}
public Episode Get(int seriesId, int season, int episodeNumber)
{
2013-03-27 03:44:52 +00:00
return Query.Single(s => s.SeriesId == seriesId && s.SeasonNumber == season && s.EpisodeNumber == episodeNumber);
}
public Episode Get(int seriesId, DateTime date)
{
2013-03-27 03:44:52 +00:00
return Query.Single(s => s.SeriesId == seriesId && s.AirDate.HasValue && s.AirDate.Value.Date == date.Date);
}
public List<Episode> GetEpisodes(int seriesId)
{
2013-03-27 03:44:52 +00:00
return Query.Where(s => s.SeriesId == seriesId).ToList();
}
public List<Episode> GetEpisodes(int seriesId, int seasonNumber)
{
2013-03-27 03:44:52 +00:00
return Query.Where(s => s.SeriesId == seriesId && s.SeasonNumber == seasonNumber).ToList();
}
public List<Episode> GetEpisodeByFileId(int fileId)
{
2013-03-27 03:44:52 +00:00
return Query.Where(s => s.EpisodeFile != null && s.EpisodeFile.Id == fileId).ToList();
}
2013-05-02 05:50:34 +00:00
public PagingSpec<Episode> EpisodesWithoutFiles(PagingSpec<Episode> pagingSpec, bool includeSpecials)
{
2013-05-02 05:50:34 +00:00
//TODO: Join in the series title so we can do sorting on it
if (!pagingSpec.SortKey.Equals("SeriesTitle", StringComparison.InvariantCultureIgnoreCase) &&
!pagingSpec.SortKey.Equals("AirDate", StringComparison.InvariantCultureIgnoreCase))
{
throw new ArgumentException("Invalid SortKey: " + pagingSpec.SortKey, "pagingSpec");
}
if (includeSpecials)
{
2013-05-02 05:50:34 +00:00
throw new NotImplementedException("Including specials is not available");
}
2013-05-02 05:50:34 +00:00
var orderSql = String.Format("{0} {1}", pagingSpec.SortKey,
pagingSpec.SortDirection == ListSortDirection.Ascending ? "ASC" : "DESC");
2013-05-03 00:25:51 +00:00
var limitSql = String.Format("{0},{1}", (pagingSpec.Page - 1) * pagingSpec.PageSize, pagingSpec.PageSize);
2013-05-02 05:50:34 +00:00
2013-05-03 00:25:51 +00:00
var currentTime = DateTime.UtcNow;
_dataMapper.AddParameter("currentTime", currentTime);
2013-05-02 07:09:35 +00:00
2013-05-02 05:50:34 +00:00
var sql = String.Format(@"SELECT Episodes.*, Series.Title as SeriesTitle
FROM Episodes
INNER JOIN Series
ON Episodes.SeriesId = Series.Id
WHERE EpisodeFileId = 0
AND SeasonNumber > 0
2013-05-03 00:25:51 +00:00
AND AirDate <= @currentTime
2013-05-02 05:50:34 +00:00
ORDER BY {0}
LIMIT {1}",
orderSql, limitSql
);
pagingSpec.Records = _dataMapper.Query<Episode>(sql);
2013-05-03 00:25:51 +00:00
pagingSpec.TotalRecords = Query.Count(e => e.EpisodeFileId == 0 && e.SeasonNumber > 0 && e.AirDate <= currentTime);
2013-05-02 05:50:34 +00:00
return pagingSpec;
}
public Episode GetEpisodeBySceneNumbering(int seriesId, int seasonNumber, int episodeNumber)
{
2013-03-27 03:44:52 +00:00
return Query.Single(s => s.SeriesId == seriesId && s.SeasonNumber == seasonNumber && s.SceneEpisodeNumber == episodeNumber);
}
public List<Episode> EpisodesWithFiles()
{
2013-03-27 03:44:52 +00:00
return Query.Where(s => s.EpisodeFile != null).ToList();
}
public List<Episode> EpisodesBetweenDates(DateTime startDate, DateTime endDate)
{
return Query//.Join<Episode, Series>(JoinType.None, e => e.Series, (e, s) => e.SeriesId == s.Id);
.Where<Episode>(e => e.AirDate >= startDate && e.AirDate <= endDate).ToList();
}
2013-03-01 07:03:41 +00:00
public void SetIgnoreFlat(Episode episode, bool ignoreFlag)
{
episode.Ignored = ignoreFlag;
SetFields(episode, p => p.Ignored);
2013-03-01 07:03:41 +00:00
}
public void SetPostDownloadStatus(int episodeId, PostDownloadStatusType status)
{
SetFields(new Episode { Id = episodeId, PostDownloadStatus = status }, episode => episode.PostDownloadStatus);
}
public void SetFileId(int episodeId, int fileId)
{
SetFields(new Episode { Id = episodeId, EpisodeFileId = fileId }, episode => episode.EpisodeFileId);
}
}
2013-05-03 00:25:51 +00:00
}