You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Sonarr/src/NzbDrone.Core/Tv/SeriesRepository.cs

124 lines
3.9 KiB

using System.Collections.Generic;
using System.Linq;
using Dapper;
using NzbDrone.Core.Datastore;
using NzbDrone.Core.Messaging.Events;
namespace NzbDrone.Core.Tv
{
public interface ISeriesRepository : IBasicRepository<Series>
{
bool SeriesPathExists(string path);
Series FindByTitle(string cleanTitle);
Series FindByTitle(string cleanTitle, int year);
List<Series> FindByTitleInexact(string cleanTitle);
Series FindByTvdbId(int tvdbId);
Series FindByTvRageId(int tvRageId);
Series FindByPath(string path);
List<int> AllSeriesTvdbIds();
Dictionary<int, string> AllSeriesPaths();
Dictionary<int, List<int>> AllSeriesTags();
}
public class SeriesRepository : BasicRepository<Series>, ISeriesRepository
{
public SeriesRepository(IMainDatabase database, IEventAggregator eventAggregator)
: base(database, eventAggregator)
{
}
public bool SeriesPathExists(string path)
{
return Query(c => c.Path == path).Any();
}
public Series FindByTitle(string cleanTitle)
{
cleanTitle = cleanTitle.ToLowerInvariant();
var series = Query(s => s.CleanTitle == cleanTitle)
.ToList();
return ReturnSingleSeriesOrThrow(series);
}
public Series FindByTitle(string cleanTitle, int year)
{
cleanTitle = cleanTitle.ToLowerInvariant();
var series = Query(s => s.CleanTitle == cleanTitle && s.Year == year).ToList();
return ReturnSingleSeriesOrThrow(series);
}
public List<Series> FindByTitleInexact(string cleanTitle)
{
var builder = Builder().Where($"instr(@cleanTitle, \"Series\".\"CleanTitle\")", new { cleanTitle = cleanTitle });
if (_database.DatabaseType == DatabaseType.PostgreSQL)
{
builder = Builder().Where($"(strpos(@cleanTitle, \"Series\".\"CleanTitle\") > 0)", new { cleanTitle = cleanTitle });
}
return Query(builder).ToList();
}
public Series FindByTvdbId(int tvdbId)
{
return Query(s => s.TvdbId == tvdbId).SingleOrDefault();
}
public Series FindByTvRageId(int tvRageId)
{
return Query(s => s.TvRageId == tvRageId).SingleOrDefault();
}
public Series FindByPath(string path)
{
return Query(s => s.Path == path)
.FirstOrDefault();
}
public List<int> AllSeriesTvdbIds()
{
using (var conn = _database.OpenConnection())
{
return conn.Query<int>("SELECT \"TvdbId\" FROM \"Series\"").ToList();
}
}
public Dictionary<int, string> AllSeriesPaths()
{
using (var conn = _database.OpenConnection())
{
var strSql = "SELECT \"Id\" AS Key, \"Path\" AS Value FROM \"Series\"";
return conn.Query<KeyValuePair<int, string>>(strSql).ToDictionary(x => x.Key, x => x.Value);
}
}
public Dictionary<int, List<int>> AllSeriesTags()
{
using (var conn = _database.OpenConnection())
{
var strSql = "SELECT \"Id\" AS Key, \"Tags\" AS Value FROM \"Series\" WHERE \"Tags\" IS NOT NULL";
return conn.Query<KeyValuePair<int, List<int>>>(strSql).ToDictionary(x => x.Key, x => x.Value);
}
}
private Series ReturnSingleSeriesOrThrow(List<Series> series)
{
if (series.Count == 0)
{
return null;
}
if (series.Count == 1)
{
return series.First();
}
throw new MultipleSeriesFoundException(series, "Expected one series, but found {0}. Matching series: {1}", series.Count, string.Join(", ", series));
}
}
}