2010-10-04 01:00:50 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
2011-06-18 01:46:22 +00:00
|
|
|
|
using System.Linq;
|
2010-10-04 01:00:50 +00:00
|
|
|
|
using System.Text.RegularExpressions;
|
|
|
|
|
using NLog;
|
2011-10-21 05:04:26 +00:00
|
|
|
|
using Ninject;
|
2011-10-29 04:54:33 +00:00
|
|
|
|
using NzbDrone.Common;
|
2012-10-17 00:08:47 +00:00
|
|
|
|
using TvdbLib;
|
|
|
|
|
using TvdbLib.Cache;
|
|
|
|
|
using TvdbLib.Data;
|
2010-09-23 03:19:47 +00:00
|
|
|
|
|
2010-09-28 04:25:41 +00:00
|
|
|
|
namespace NzbDrone.Core.Providers
|
2010-09-23 03:19:47 +00:00
|
|
|
|
{
|
2011-04-07 03:34:48 +00:00
|
|
|
|
public class TvDbProvider
|
2010-09-23 03:19:47 +00:00
|
|
|
|
{
|
2012-03-07 02:59:43 +00:00
|
|
|
|
private readonly EnvironmentProvider _environmentProvider;
|
2012-07-10 04:37:24 +00:00
|
|
|
|
public const string TVDB_APIKEY = "5D2D188E86E07F4F";
|
2011-01-29 06:10:22 +00:00
|
|
|
|
private static readonly Logger Logger = LogManager.GetCurrentClassLogger();
|
2010-10-04 01:00:50 +00:00
|
|
|
|
|
2012-10-17 00:08:47 +00:00
|
|
|
|
private readonly TvdbHandler _handler;
|
2010-09-23 03:19:47 +00:00
|
|
|
|
|
2011-10-21 05:04:26 +00:00
|
|
|
|
[Inject]
|
2012-03-07 02:59:43 +00:00
|
|
|
|
public TvDbProvider(EnvironmentProvider environmentProvider)
|
2011-10-21 05:04:26 +00:00
|
|
|
|
{
|
2012-03-07 02:59:43 +00:00
|
|
|
|
_environmentProvider = environmentProvider;
|
2012-10-17 00:08:47 +00:00
|
|
|
|
_handler = new TvdbHandler(new XmlCacheProvider(_environmentProvider.GetCacheFolder()), TVDB_APIKEY);
|
2011-10-21 05:04:26 +00:00
|
|
|
|
}
|
|
|
|
|
|
2010-09-28 04:25:41 +00:00
|
|
|
|
public TvDbProvider()
|
2010-09-23 03:19:47 +00:00
|
|
|
|
{
|
2011-11-03 05:04:14 +00:00
|
|
|
|
|
2010-09-23 03:19:47 +00:00
|
|
|
|
}
|
|
|
|
|
|
2011-04-07 03:34:48 +00:00
|
|
|
|
public virtual IList<TvdbSearchResult> SearchSeries(string title)
|
2010-10-04 01:00:50 +00:00
|
|
|
|
{
|
2012-10-17 00:08:47 +00:00
|
|
|
|
lock (_handler)
|
|
|
|
|
{
|
|
|
|
|
Logger.Debug("Searching TVDB for '{0}'", title);
|
2011-04-20 07:44:13 +00:00
|
|
|
|
|
2012-12-20 21:27:54 +00:00
|
|
|
|
if(title.Contains(" & "))
|
|
|
|
|
{
|
|
|
|
|
Logger.Debug("Removing ampersand before searching");
|
|
|
|
|
title = title.Replace(" & ", " ");
|
|
|
|
|
}
|
|
|
|
|
|
2012-10-17 00:08:47 +00:00
|
|
|
|
var result = _handler.SearchSeries(title);
|
2010-10-04 01:00:50 +00:00
|
|
|
|
|
2012-10-17 00:08:47 +00:00
|
|
|
|
Logger.Debug("Search for '{0}' returned {1} possible results", title, result.Count);
|
|
|
|
|
return result;
|
|
|
|
|
}
|
2010-10-04 01:00:50 +00:00
|
|
|
|
}
|
|
|
|
|
|
2012-10-17 00:08:47 +00:00
|
|
|
|
public virtual TvdbSeries GetSeries(int id, bool loadEpisodes, bool loadActors = false)
|
2010-09-23 03:19:47 +00:00
|
|
|
|
{
|
2012-10-17 00:08:47 +00:00
|
|
|
|
lock (_handler)
|
|
|
|
|
{
|
|
|
|
|
Logger.Debug("Fetching SeriesId'{0}' from tvdb", id);
|
|
|
|
|
var result = _handler.GetSeries(id, TvdbLanguage.DefaultLanguage, loadEpisodes, loadActors, true, true);
|
2011-05-29 01:58:35 +00:00
|
|
|
|
|
2012-10-17 00:08:47 +00:00
|
|
|
|
//Remove duplicated episodes
|
|
|
|
|
var episodes = result.Episodes.OrderByDescending(e => e.FirstAired).ThenByDescending(e => e.EpisodeName)
|
|
|
|
|
.GroupBy(e => e.SeriesId.ToString("000000") + e.SeasonNumber.ToString("000") + e.EpisodeNumber.ToString("000"))
|
|
|
|
|
.Select(e => e.First());
|
|
|
|
|
|
|
|
|
|
result.Episodes = episodes.ToList();
|
|
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
}
|
2010-09-23 03:19:47 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|