2010-09-28 19:32:19 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.IO;
|
2010-09-23 03:19:47 +00:00
|
|
|
|
using System.Linq;
|
2010-10-02 19:01:43 +00:00
|
|
|
|
using NLog;
|
2011-04-04 03:50:12 +00:00
|
|
|
|
using NzbDrone.Core.Providers.Core;
|
2010-10-21 01:49:23 +00:00
|
|
|
|
using NzbDrone.Core.Repository;
|
2011-01-29 06:10:22 +00:00
|
|
|
|
using NzbDrone.Core.Repository.Quality;
|
2010-09-23 03:19:47 +00:00
|
|
|
|
using SubSonic.Repository;
|
|
|
|
|
using TvdbLib.Data;
|
|
|
|
|
|
2010-09-28 04:25:41 +00:00
|
|
|
|
namespace NzbDrone.Core.Providers
|
2010-09-23 03:19:47 +00:00
|
|
|
|
{
|
2011-04-08 23:55:23 +00:00
|
|
|
|
public class SeriesProvider
|
2010-09-23 03:19:47 +00:00
|
|
|
|
{
|
2010-09-28 19:32:19 +00:00
|
|
|
|
//TODO: Remove parsing of rest of tv show info we just need the show name
|
2010-10-02 19:01:43 +00:00
|
|
|
|
|
2010-10-04 01:00:50 +00:00
|
|
|
|
//Trims all white spaces and separators from the end of the title.
|
2010-10-17 17:22:48 +00:00
|
|
|
|
|
2011-04-10 02:44:01 +00:00
|
|
|
|
private static readonly Logger Logger = LogManager.GetCurrentClassLogger();
|
2011-04-10 01:34:36 +00:00
|
|
|
|
private readonly ConfigProvider _config;
|
2011-04-10 02:44:01 +00:00
|
|
|
|
private readonly QualityProvider _quality;
|
2010-09-23 03:19:47 +00:00
|
|
|
|
private readonly IRepository _sonioRepo;
|
2011-04-07 03:34:48 +00:00
|
|
|
|
private readonly TvDbProvider _tvDb;
|
2010-09-23 03:19:47 +00:00
|
|
|
|
|
2011-04-10 01:34:36 +00:00
|
|
|
|
public SeriesProvider(ConfigProvider configProvider,
|
2011-04-10 02:44:01 +00:00
|
|
|
|
IRepository dataRepository, TvDbProvider tvDbProvider, QualityProvider quality)
|
2010-09-23 03:19:47 +00:00
|
|
|
|
{
|
2010-09-28 04:25:41 +00:00
|
|
|
|
_config = configProvider;
|
2010-09-23 03:19:47 +00:00
|
|
|
|
_sonioRepo = dataRepository;
|
2010-09-28 04:25:41 +00:00
|
|
|
|
_tvDb = tvDbProvider;
|
2011-02-15 03:48:39 +00:00
|
|
|
|
_quality = quality;
|
2010-09-23 03:19:47 +00:00
|
|
|
|
}
|
|
|
|
|
|
2011-04-10 00:14:51 +00:00
|
|
|
|
public SeriesProvider()
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2011-04-07 02:25:52 +00:00
|
|
|
|
public virtual IQueryable<Series> GetAllSeries()
|
2010-09-23 03:19:47 +00:00
|
|
|
|
{
|
|
|
|
|
return _sonioRepo.All<Series>();
|
|
|
|
|
}
|
|
|
|
|
|
2011-04-07 02:25:52 +00:00
|
|
|
|
public virtual Series GetSeries(int seriesId)
|
2010-09-24 07:14:42 +00:00
|
|
|
|
{
|
2010-10-05 06:21:18 +00:00
|
|
|
|
return _sonioRepo.Single<Series>(s => s.SeriesId == seriesId);
|
2010-09-24 07:14:42 +00:00
|
|
|
|
}
|
|
|
|
|
|
2010-10-02 19:01:43 +00:00
|
|
|
|
/// <summary>
|
2011-04-10 02:44:01 +00:00
|
|
|
|
/// Determines if a series is being actively watched.
|
2010-10-02 19:01:43 +00:00
|
|
|
|
/// </summary>
|
2011-04-10 02:44:01 +00:00
|
|
|
|
/// <param name = "id">The TVDB ID of the series</param>
|
2010-10-02 19:01:43 +00:00
|
|
|
|
/// <returns>Whether or not the show is monitored</returns>
|
2011-04-07 02:25:52 +00:00
|
|
|
|
public virtual bool IsMonitored(long id)
|
2010-09-28 20:44:33 +00:00
|
|
|
|
{
|
2010-10-05 06:21:18 +00:00
|
|
|
|
return _sonioRepo.Exists<Series>(c => c.SeriesId == id && c.Monitored);
|
2010-09-28 20:44:33 +00:00
|
|
|
|
}
|
|
|
|
|
|
2011-04-07 02:25:52 +00:00
|
|
|
|
public virtual bool QualityWanted(int seriesId, QualityTypes quality)
|
2011-01-29 06:10:22 +00:00
|
|
|
|
{
|
2011-02-15 03:48:39 +00:00
|
|
|
|
var series = _sonioRepo.Single<Series>(seriesId);
|
2011-04-25 18:21:53 +00:00
|
|
|
|
Logger.Trace("Series {0} is using quality profile {1}", seriesId, series.QualityProfile.Name);
|
|
|
|
|
return series.QualityProfile.Allowed.Contains(quality);
|
2011-01-29 06:10:22 +00:00
|
|
|
|
}
|
|
|
|
|
|
2011-04-07 02:25:52 +00:00
|
|
|
|
public virtual TvdbSeries MapPathToSeries(string path)
|
2010-09-23 03:19:47 +00:00
|
|
|
|
{
|
2010-10-02 19:01:43 +00:00
|
|
|
|
var seriesPath = new DirectoryInfo(path);
|
2010-10-04 01:00:50 +00:00
|
|
|
|
var searchResults = _tvDb.GetSeries(seriesPath.Name);
|
2010-10-02 19:01:43 +00:00
|
|
|
|
|
2010-10-04 01:00:50 +00:00
|
|
|
|
if (searchResults == null)
|
|
|
|
|
return null;
|
2010-10-02 19:01:43 +00:00
|
|
|
|
|
2010-10-05 06:21:18 +00:00
|
|
|
|
return _tvDb.GetSeries(searchResults.Id, false);
|
2010-09-23 03:19:47 +00:00
|
|
|
|
}
|
|
|
|
|
|
2011-04-07 02:25:52 +00:00
|
|
|
|
public virtual Series UpdateSeriesInfo(int seriesId)
|
2011-03-10 07:49:59 +00:00
|
|
|
|
{
|
2011-04-01 06:36:34 +00:00
|
|
|
|
var tvDbSeries = _tvDb.GetSeries(seriesId, true);
|
|
|
|
|
var series = GetSeries(seriesId);
|
|
|
|
|
|
|
|
|
|
series.SeriesId = tvDbSeries.Id;
|
|
|
|
|
series.Title = tvDbSeries.SeriesName;
|
|
|
|
|
series.AirTimes = tvDbSeries.AirsTime;
|
|
|
|
|
series.AirsDayOfWeek = tvDbSeries.AirsDayOfWeek;
|
|
|
|
|
series.Overview = tvDbSeries.Overview;
|
|
|
|
|
series.Status = tvDbSeries.Status;
|
|
|
|
|
series.Language = tvDbSeries.Language != null ? tvDbSeries.Language.Abbriviation : string.Empty;
|
|
|
|
|
series.CleanTitle = Parser.NormalizeTitle(tvDbSeries.SeriesName);
|
|
|
|
|
series.LastInfoSync = DateTime.Now;
|
|
|
|
|
|
|
|
|
|
UpdateSeries(series);
|
|
|
|
|
return series;
|
2011-03-10 07:49:59 +00:00
|
|
|
|
}
|
|
|
|
|
|
2011-04-07 02:25:52 +00:00
|
|
|
|
public virtual void AddSeries(string path, int tvDbSeriesId, int qualityProfileId)
|
2010-09-23 03:19:47 +00:00
|
|
|
|
{
|
2011-04-01 06:36:34 +00:00
|
|
|
|
Logger.Info("Adding Series [{0}] Path: [{1}]", tvDbSeriesId, path);
|
|
|
|
|
|
2010-09-28 03:04:39 +00:00
|
|
|
|
var repoSeries = new Series();
|
2011-04-01 06:36:34 +00:00
|
|
|
|
repoSeries.SeriesId = tvDbSeriesId;
|
2010-09-28 03:04:39 +00:00
|
|
|
|
repoSeries.Path = path;
|
2011-02-15 03:48:39 +00:00
|
|
|
|
repoSeries.Monitored = true; //New shows should be monitored
|
2011-03-28 20:22:12 +00:00
|
|
|
|
repoSeries.QualityProfileId = qualityProfileId;
|
|
|
|
|
if (qualityProfileId == 0)
|
|
|
|
|
repoSeries.QualityProfileId = Convert.ToInt32(_config.GetValue("DefaultQualityProfile", "1", true));
|
2011-02-25 07:20:24 +00:00
|
|
|
|
|
2011-04-01 06:36:34 +00:00
|
|
|
|
repoSeries.SeasonFolder = _config.UseSeasonFolder;
|
2011-02-25 07:20:24 +00:00
|
|
|
|
|
2010-09-28 03:04:39 +00:00
|
|
|
|
_sonioRepo.Add(repoSeries);
|
2010-09-23 03:19:47 +00:00
|
|
|
|
}
|
2010-09-28 19:32:19 +00:00
|
|
|
|
|
2011-04-07 02:25:52 +00:00
|
|
|
|
public virtual Series FindSeries(string title)
|
2011-01-29 06:10:22 +00:00
|
|
|
|
{
|
2011-04-22 19:16:52 +00:00
|
|
|
|
var normalizeTitle = Parser.NormalizeTitle(title);
|
|
|
|
|
return _sonioRepo.Single<Series>(s => s.CleanTitle == normalizeTitle);
|
2011-01-29 06:10:22 +00:00
|
|
|
|
}
|
|
|
|
|
|
2011-04-07 02:25:52 +00:00
|
|
|
|
public virtual void UpdateSeries(Series series)
|
2011-02-18 02:50:40 +00:00
|
|
|
|
{
|
|
|
|
|
_sonioRepo.Update(series);
|
|
|
|
|
}
|
|
|
|
|
|
2011-04-07 02:25:52 +00:00
|
|
|
|
public virtual void DeleteSeries(int seriesId)
|
2011-02-18 06:49:23 +00:00
|
|
|
|
{
|
2011-04-01 06:36:34 +00:00
|
|
|
|
Logger.Warn("Deleting Series [{0}]", seriesId);
|
|
|
|
|
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
var series = _sonioRepo.Single<Series>(seriesId);
|
|
|
|
|
|
|
|
|
|
//Delete Files, Episdes, Seasons then the Series
|
|
|
|
|
//Can't use providers because episode provider needs series provider - Cyclic Dependency Injection, this will work
|
|
|
|
|
|
|
|
|
|
Logger.Debug("Deleting EpisodeFiles from DB for Series: {0}", series.SeriesId);
|
|
|
|
|
_sonioRepo.DeleteMany(series.EpisodeFiles);
|
2011-02-18 06:49:23 +00:00
|
|
|
|
|
2011-04-01 06:36:34 +00:00
|
|
|
|
Logger.Debug("Deleting Episodes from DB for Series: {0}", series.SeriesId);
|
|
|
|
|
_sonioRepo.DeleteMany(series.Episodes);
|
2011-02-18 06:49:23 +00:00
|
|
|
|
|
2011-04-01 06:36:34 +00:00
|
|
|
|
Logger.Debug("Deleting Seasons from DB for Series: {0}", series.SeriesId);
|
|
|
|
|
_sonioRepo.DeleteMany(series.Seasons);
|
2011-02-18 06:49:23 +00:00
|
|
|
|
|
2011-04-01 06:36:34 +00:00
|
|
|
|
Logger.Debug("Deleting Series from DB {0}", series.Title);
|
|
|
|
|
_sonioRepo.Delete<Series>(seriesId);
|
2011-02-18 06:49:23 +00:00
|
|
|
|
|
2011-04-01 06:36:34 +00:00
|
|
|
|
Logger.Info("Successfully deleted Series [{0}]", seriesId);
|
|
|
|
|
}
|
|
|
|
|
catch (Exception e)
|
|
|
|
|
{
|
2011-04-20 07:44:13 +00:00
|
|
|
|
Logger.ErrorException("An error has occurred while deleting series.", e);
|
2011-04-01 06:36:34 +00:00
|
|
|
|
throw;
|
|
|
|
|
}
|
2011-02-18 06:49:23 +00:00
|
|
|
|
}
|
|
|
|
|
|
2011-04-07 02:25:52 +00:00
|
|
|
|
public virtual bool SeriesPathExists(string cleanPath)
|
2011-03-09 07:40:48 +00:00
|
|
|
|
{
|
|
|
|
|
if (_sonioRepo.Exists<Series>(s => s.Path == cleanPath))
|
|
|
|
|
return true;
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
2010-09-23 03:19:47 +00:00
|
|
|
|
}
|
|
|
|
|
}
|