2013-05-02 17:25:51 -07:00
|
|
|
using System;
|
2012-02-20 19:25:19 -08:00
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Linq;
|
2013-04-16 19:46:07 -07:00
|
|
|
using Marr.Data.QGen;
|
2013-05-05 14:24:33 -07:00
|
|
|
using NzbDrone.Common.Messaging;
|
2013-02-19 18:05:15 -08:00
|
|
|
using NzbDrone.Core.Datastore;
|
2013-03-24 20:51:32 -07:00
|
|
|
|
2012-02-20 19:25:19 -08:00
|
|
|
|
2013-02-18 22:01:03 -08:00
|
|
|
namespace NzbDrone.Core.Tv
|
2012-02-20 19:25:19 -08:00
|
|
|
{
|
2013-02-19 18:05:15 -08:00
|
|
|
public interface IEpisodeRepository : IBasicRepository<Episode>
|
2012-02-20 19:25:19 -08:00
|
|
|
{
|
2013-02-19 18:05:15 -08:00
|
|
|
Episode Get(int seriesId, int season, int episodeNumber);
|
2013-05-28 18:28:47 -07:00
|
|
|
Episode Find(int seriesId, int season, int episodeNumber);
|
2013-02-19 18:05:15 -08:00
|
|
|
Episode Get(int seriesId, DateTime date);
|
2013-05-28 18:28:47 -07:00
|
|
|
Episode Find(int seriesId, DateTime date);
|
2013-03-03 15:18:43 -08:00
|
|
|
List<Episode> GetEpisodes(int seriesId);
|
|
|
|
List<Episode> GetEpisodes(int seriesId, int seasonNumber);
|
|
|
|
List<Episode> GetEpisodeByFileId(int fileId);
|
2013-05-01 22:50:34 -07:00
|
|
|
PagingSpec<Episode> EpisodesWithoutFiles(PagingSpec<Episode> pagingSpec, bool includeSpecials);
|
2013-02-19 18:05:15 -08:00
|
|
|
Episode GetEpisodeBySceneNumbering(int seriesId, int seasonNumber, int episodeNumber);
|
2013-05-28 18:28:47 -07:00
|
|
|
Episode FindEpisodeBySceneNumbering(int seriesId, int seasonNumber, int episodeNumber);
|
2013-03-03 15:18:43 -08:00
|
|
|
List<Episode> EpisodesWithFiles();
|
2013-02-23 15:08:22 -08:00
|
|
|
List<Episode> EpisodesBetweenDates(DateTime startDate, DateTime endDate);
|
2013-07-08 18:22:02 -07:00
|
|
|
void SetMonitoredFlat(Episode episode, bool monitored);
|
2013-07-09 19:11:00 -07:00
|
|
|
void SetMonitoredBySeason(int seriesId, int seasonNumber, bool monitored);
|
2013-04-14 18:41:39 -07:00
|
|
|
void SetFileId(int episodeId, int fileId);
|
2013-02-19 18:05:15 -08:00
|
|
|
}
|
2012-02-20 19:25:19 -08:00
|
|
|
|
2013-02-19 18:05:15 -08:00
|
|
|
public class EpisodeRepository : BasicRepository<Episode>, IEpisodeRepository
|
|
|
|
{
|
2013-07-15 17:45:49 -07:00
|
|
|
private readonly IDatabase _database;
|
2013-05-01 22:50:34 -07:00
|
|
|
|
2013-05-05 14:24:33 -07:00
|
|
|
public EpisodeRepository(IDatabase database, IMessageAggregator messageAggregator)
|
|
|
|
: base(database, messageAggregator)
|
2012-02-20 19:25:19 -08:00
|
|
|
{
|
2013-07-15 17:45:49 -07:00
|
|
|
_database = database;
|
2012-02-20 19:25:19 -08:00
|
|
|
}
|
|
|
|
|
2013-02-19 18:05:15 -08:00
|
|
|
public Episode Get(int seriesId, int season, int episodeNumber)
|
2012-02-20 19:25:19 -08:00
|
|
|
{
|
2013-03-26 20:44:52 -07:00
|
|
|
return Query.Single(s => s.SeriesId == seriesId && s.SeasonNumber == season && s.EpisodeNumber == episodeNumber);
|
2012-02-20 19:25:19 -08:00
|
|
|
}
|
|
|
|
|
2013-05-28 18:28:47 -07:00
|
|
|
public Episode Find(int seriesId, int season, int episodeNumber)
|
|
|
|
{
|
|
|
|
return Query.SingleOrDefault(s => s.SeriesId == seriesId && s.SeasonNumber == season && s.EpisodeNumber == episodeNumber);
|
|
|
|
}
|
|
|
|
|
2013-02-19 18:05:15 -08:00
|
|
|
public Episode Get(int seriesId, DateTime date)
|
2012-02-20 19:25:19 -08:00
|
|
|
{
|
2013-07-25 20:25:24 -07:00
|
|
|
return Query.Single(s => s.SeriesId == seriesId && s.AirDate == date.ToString(Episode.AIR_DATE_FORMAT));
|
2012-02-20 19:25:19 -08:00
|
|
|
}
|
|
|
|
|
2013-05-28 18:28:47 -07:00
|
|
|
public Episode Find(int seriesId, DateTime date)
|
|
|
|
{
|
2013-07-25 20:25:24 -07:00
|
|
|
return Query.SingleOrDefault(s => s.SeriesId == seriesId && s.AirDate == date.ToString(Episode.AIR_DATE_FORMAT));
|
2013-05-28 18:28:47 -07:00
|
|
|
}
|
|
|
|
|
2013-03-03 15:18:43 -08:00
|
|
|
public List<Episode> GetEpisodes(int seriesId)
|
2012-02-20 19:25:19 -08:00
|
|
|
{
|
2013-03-26 20:44:52 -07:00
|
|
|
return Query.Where(s => s.SeriesId == seriesId).ToList();
|
2012-02-20 19:25:19 -08:00
|
|
|
}
|
|
|
|
|
2013-03-03 15:18:43 -08:00
|
|
|
public List<Episode> GetEpisodes(int seriesId, int seasonNumber)
|
2012-02-20 19:25:19 -08:00
|
|
|
{
|
2013-03-26 20:44:52 -07:00
|
|
|
return Query.Where(s => s.SeriesId == seriesId && s.SeasonNumber == seasonNumber).ToList();
|
2012-02-20 19:25:19 -08:00
|
|
|
}
|
2012-02-20 22:50:38 -08:00
|
|
|
|
2013-03-03 15:18:43 -08:00
|
|
|
public List<Episode> GetEpisodeByFileId(int fileId)
|
2012-02-20 22:50:38 -08:00
|
|
|
{
|
2013-05-12 17:36:23 -07:00
|
|
|
return Query.Where(e => e.EpisodeFileId == fileId).ToList();
|
2012-02-20 22:50:38 -08:00
|
|
|
}
|
2012-02-27 21:50:56 -08:00
|
|
|
|
2013-05-01 22:50:34 -07:00
|
|
|
public PagingSpec<Episode> EpisodesWithoutFiles(PagingSpec<Episode> pagingSpec, bool includeSpecials)
|
2012-02-27 21:50:56 -08:00
|
|
|
{
|
2013-05-07 00:22:19 -07:00
|
|
|
var currentTime = DateTime.UtcNow;
|
|
|
|
var startingSeasonNumber = 1;
|
|
|
|
|
2013-05-01 22:50:34 -07:00
|
|
|
if (includeSpecials)
|
2012-02-27 21:50:56 -08:00
|
|
|
{
|
2013-05-07 00:22:19 -07:00
|
|
|
startingSeasonNumber = 0;
|
2012-02-27 21:50:56 -08:00
|
|
|
}
|
2013-05-12 17:36:23 -07:00
|
|
|
|
2013-07-21 21:39:26 -07:00
|
|
|
pagingSpec.Records = GetEpisodesWithoutFilesQuery(pagingSpec, currentTime, startingSeasonNumber).ToList();
|
|
|
|
pagingSpec.TotalRecords = GetEpisodesWithoutFilesQuery(pagingSpec, currentTime, startingSeasonNumber).GetRowCount();
|
2013-05-01 22:50:34 -07:00
|
|
|
|
|
|
|
return pagingSpec;
|
2013-02-19 18:05:15 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
public Episode GetEpisodeBySceneNumbering(int seriesId, int seasonNumber, int episodeNumber)
|
|
|
|
{
|
2013-03-26 20:44:52 -07:00
|
|
|
return Query.Single(s => s.SeriesId == seriesId && s.SeasonNumber == seasonNumber && s.SceneEpisodeNumber == episodeNumber);
|
2013-02-19 18:05:15 -08:00
|
|
|
}
|
|
|
|
|
2013-05-28 18:28:47 -07:00
|
|
|
public Episode FindEpisodeBySceneNumbering(int seriesId, int seasonNumber, int episodeNumber)
|
|
|
|
{
|
|
|
|
return Query.SingleOrDefault(s => s.SeriesId == seriesId && s.SeasonNumber == seasonNumber && s.SceneEpisodeNumber == episodeNumber);
|
|
|
|
}
|
|
|
|
|
2013-03-03 15:18:43 -08:00
|
|
|
public List<Episode> EpisodesWithFiles()
|
2013-02-19 18:05:15 -08:00
|
|
|
{
|
2013-05-12 17:36:23 -07:00
|
|
|
return Query.Where(s => s.EpisodeFileId != 0).ToList();
|
2012-02-27 21:50:56 -08:00
|
|
|
}
|
2013-02-23 15:08:22 -08:00
|
|
|
|
|
|
|
public List<Episode> EpisodesBetweenDates(DateTime startDate, DateTime endDate)
|
|
|
|
{
|
2013-07-15 15:52:00 -07:00
|
|
|
return Query.Join<Episode, Series>(JoinType.Inner, e => e.Series, (e, s) => e.SeriesId == s.Id)
|
2013-07-23 22:28:06 -07:00
|
|
|
.Where<Episode>(e => e.AirDateUtc >= startDate)
|
|
|
|
.AndWhere(e => e.AirDateUtc <= endDate)
|
2013-07-15 15:52:00 -07:00
|
|
|
.AndWhere(e => e.Monitored)
|
|
|
|
.AndWhere(e => e.Series.Monitored)
|
|
|
|
.ToList();
|
2013-02-23 15:08:22 -08:00
|
|
|
}
|
2013-02-28 23:03:41 -08:00
|
|
|
|
2013-07-08 18:22:02 -07:00
|
|
|
public void SetMonitoredFlat(Episode episode, bool monitored)
|
2013-02-28 23:03:41 -08:00
|
|
|
{
|
2013-07-08 18:22:02 -07:00
|
|
|
episode.Monitored = monitored;
|
|
|
|
SetFields(episode, p => p.Monitored);
|
2013-02-28 23:03:41 -08:00
|
|
|
}
|
2013-04-14 18:41:39 -07:00
|
|
|
|
2013-07-09 19:11:00 -07:00
|
|
|
public void SetMonitoredBySeason(int seriesId, int seasonNumber, bool monitored)
|
|
|
|
{
|
2013-07-15 17:45:49 -07:00
|
|
|
var mapper = _database.GetDataMapper();
|
2013-07-09 19:11:00 -07:00
|
|
|
|
2013-07-15 17:45:49 -07:00
|
|
|
mapper.AddParameter("seriesId", seriesId);
|
|
|
|
mapper.AddParameter("seasonNumber", seasonNumber);
|
|
|
|
mapper.AddParameter("monitored", monitored);
|
2013-07-09 19:11:00 -07:00
|
|
|
|
2013-07-15 17:45:49 -07:00
|
|
|
const string sql = "UPDATE Episodes " +
|
|
|
|
"SET Monitored = @monitored " +
|
|
|
|
"WHERE SeriesId = @seriesId " +
|
|
|
|
"AND SeasonNumber = @seasonNumber";
|
|
|
|
|
|
|
|
mapper.ExecuteNonQuery(sql);
|
2013-07-09 19:11:00 -07:00
|
|
|
}
|
|
|
|
|
2013-04-14 18:41:39 -07:00
|
|
|
public void SetFileId(int episodeId, int fileId)
|
|
|
|
{
|
|
|
|
SetFields(new Episode { Id = episodeId, EpisodeFileId = fileId }, episode => episode.EpisodeFileId);
|
|
|
|
}
|
2013-07-21 21:39:26 -07:00
|
|
|
|
|
|
|
private SortBuilder<Episode> GetEpisodesWithoutFilesQuery(PagingSpec<Episode> pagingSpec, DateTime currentTime, int startingSeasonNumber)
|
|
|
|
{
|
|
|
|
return Query.Join<Episode, Series>(JoinType.Inner, e => e.Series, (e, s) => e.SeriesId == s.Id)
|
|
|
|
.Where(e => e.EpisodeFileId == 0)
|
|
|
|
.AndWhere(e => e.SeasonNumber >= startingSeasonNumber)
|
2013-07-23 22:28:06 -07:00
|
|
|
.AndWhere(e => e.AirDateUtc <= currentTime)
|
2013-07-21 21:39:26 -07:00
|
|
|
.AndWhere(e => e.Monitored)
|
|
|
|
.AndWhere(e => e.Series.Monitored)
|
|
|
|
.OrderBy(pagingSpec.OrderByClause(), pagingSpec.ToSortDirection())
|
|
|
|
.Skip(pagingSpec.PagingOffset())
|
|
|
|
.Take(pagingSpec.PageSize);
|
|
|
|
}
|
2012-02-20 19:25:19 -08:00
|
|
|
}
|
2013-05-02 17:25:51 -07:00
|
|
|
}
|