2013-04-15 04:41:39 +03:00
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
2013-03-25 06:51:32 +03:00
|
|
|
using System.Linq;
|
2013-02-19 09:56:02 +03:00
|
|
|
using NzbDrone.Core.Datastore;
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.Tv
|
|
|
|
{
|
2013-03-24 07:16:00 +03:00
|
|
|
public interface ISeriesRepository : IBasicRepository<Series>
|
2013-02-19 09:56:02 +03:00
|
|
|
{
|
|
|
|
bool SeriesPathExists(string path);
|
|
|
|
List<Series> Search(string title);
|
2013-04-15 04:41:39 +03:00
|
|
|
Series FindByTitle(string cleanTitle);
|
2013-03-02 21:25:39 +03:00
|
|
|
Series FindByTvdbId(int tvdbId);
|
2013-03-04 08:53:02 +03:00
|
|
|
void SetSeriesType(int seriesId, SeriesTypes seriesTypes);
|
2013-03-31 23:25:39 +03:00
|
|
|
void SetTvRageId(int seriesId, int tvRageId);
|
2013-04-20 23:09:12 +03:00
|
|
|
List<SeriesStatistics> SeriesStatistics();
|
2013-02-19 09:56:02 +03:00
|
|
|
}
|
|
|
|
|
2013-03-24 07:16:00 +03:00
|
|
|
public class SeriesRepository : BasicRepository<Series>, ISeriesRepository
|
2013-02-19 09:56:02 +03:00
|
|
|
{
|
2013-04-20 23:09:12 +03:00
|
|
|
private readonly IDatabase _database;
|
|
|
|
|
2013-03-25 06:51:32 +03:00
|
|
|
public SeriesRepository(IDatabase database)
|
2013-03-24 03:08:23 +03:00
|
|
|
: base(database)
|
2013-02-19 09:56:02 +03:00
|
|
|
{
|
2013-04-20 23:09:12 +03:00
|
|
|
_database = database;
|
2013-02-19 09:56:02 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public bool SeriesPathExists(string path)
|
|
|
|
{
|
2013-03-27 06:44:52 +03:00
|
|
|
return Query.Any(c => c.Path == path);
|
2013-02-19 09:56:02 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public List<Series> Search(string title)
|
|
|
|
{
|
2013-03-27 06:44:52 +03:00
|
|
|
return Query.Where(s => s.Title.Contains(title));
|
2013-02-19 09:56:02 +03:00
|
|
|
}
|
|
|
|
|
2013-04-15 04:41:39 +03:00
|
|
|
public Series FindByTitle(string cleanTitle)
|
2013-02-19 09:56:02 +03:00
|
|
|
{
|
2013-04-15 04:41:39 +03:00
|
|
|
return Query.SingleOrDefault(s => s.CleanTitle.Equals(cleanTitle, StringComparison.InvariantCultureIgnoreCase));
|
2013-02-19 09:56:02 +03:00
|
|
|
}
|
2013-03-02 21:25:39 +03:00
|
|
|
|
|
|
|
public Series FindByTvdbId(int tvdbId)
|
|
|
|
{
|
2013-04-17 09:55:39 +03:00
|
|
|
return Query.SingleOrDefault(s => s.TvdbId.Equals(tvdbId));
|
2013-03-02 21:25:39 +03:00
|
|
|
}
|
|
|
|
|
2013-03-24 03:08:23 +03:00
|
|
|
public void SetSeriesType(int seriesId, SeriesTypes seriesType)
|
2013-03-02 21:25:39 +03:00
|
|
|
{
|
2013-03-27 09:16:55 +03:00
|
|
|
SetFields(new Series { Id = seriesId, SeriesType = seriesType }, s => s.SeriesType);
|
2013-03-02 21:25:39 +03:00
|
|
|
}
|
2013-03-31 23:25:39 +03:00
|
|
|
|
|
|
|
public void SetTvRageId(int seriesId, int tvRageId)
|
|
|
|
{
|
|
|
|
SetFields(new Series { Id = seriesId, TvRageId = tvRageId }, s => s.TvRageId);
|
|
|
|
}
|
2013-04-20 23:09:12 +03:00
|
|
|
|
|
|
|
public List<SeriesStatistics> SeriesStatistics()
|
|
|
|
{
|
|
|
|
_database.DataMapper.AddParameter("currentDate", DateTime.UtcNow);
|
|
|
|
|
|
|
|
var queryText = @"SELECT
|
|
|
|
SeriesId,
|
|
|
|
SUM(CASE WHEN Airdate <= @currentDate THEN 1 ELSE 0 END) AS EpisodeCount,
|
|
|
|
SUM(CASE WHEN EpisodeFileId > 0 AND AirDate <= @currentDate THEN 1 ELSE 0 END) as EpisodeFileCount,
|
|
|
|
MAX(SeasonNumber) as NumberOfSeasons,
|
2013-04-21 00:23:17 +03:00
|
|
|
MIN(CASE WHEN AirDate < @currentDate THEN NULL ELSE AirDate END) as NextAiringString
|
2013-04-20 23:09:12 +03:00
|
|
|
FROM Episodes
|
|
|
|
WHERE Ignored = 0
|
|
|
|
GROUP BY SeriesId";
|
|
|
|
|
|
|
|
return _database.DataMapper.Query<SeriesStatistics>(queryText);
|
|
|
|
}
|
2013-02-19 09:56:02 +03:00
|
|
|
}
|
|
|
|
}
|