|
|
@ -20,7 +20,7 @@ namespace NzbDrone.Core.MetadataSource
|
|
|
|
{
|
|
|
|
{
|
|
|
|
private readonly Logger _logger;
|
|
|
|
private readonly Logger _logger;
|
|
|
|
private static readonly Regex CollapseSpaceRegex = new Regex(@"\s+", RegexOptions.Compiled);
|
|
|
|
private static readonly Regex CollapseSpaceRegex = new Regex(@"\s+", RegexOptions.Compiled);
|
|
|
|
private static readonly Regex InvalidSearchCharRegex = new Regex(@"(?:\*|\(|\)|'|!|@)", RegexOptions.Compiled);
|
|
|
|
private static readonly Regex InvalidSearchCharRegex = new Regex(@"(?:\*|\(|\)|'|!|@|\+)", RegexOptions.Compiled);
|
|
|
|
|
|
|
|
|
|
|
|
public TraktProxy(Logger logger)
|
|
|
|
public TraktProxy(Logger logger)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -31,13 +31,43 @@ namespace NzbDrone.Core.MetadataSource
|
|
|
|
{
|
|
|
|
{
|
|
|
|
try
|
|
|
|
try
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var client = BuildClient("search", "shows");
|
|
|
|
if (title.StartsWith("tvdb:") || title.StartsWith("tvdbid:") || title.StartsWith("slug:"))
|
|
|
|
var restRequest = new RestRequest(GetSearchTerm(title) + "/30/seasons");
|
|
|
|
{
|
|
|
|
var response = client.ExecuteAndValidate<List<Show>>(restRequest);
|
|
|
|
try
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
var slug = title.Split(':')[1];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (slug.IsNullOrWhiteSpace() || slug.Any(char.IsWhiteSpace))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return new List<Series>();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var client = BuildClient("show", "summary");
|
|
|
|
|
|
|
|
var restRequest = new RestRequest(GetSearchTerm(slug) + "/extended");
|
|
|
|
|
|
|
|
var response = client.ExecuteAndValidate<Show>(restRequest);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return new List<Series> { MapSeries(response) };
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
catch (RestException ex)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (ex.Response.StatusCode == HttpStatusCode.NotFound)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return new List<Series>();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
throw;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
var client = BuildClient("search", "shows");
|
|
|
|
|
|
|
|
var restRequest = new RestRequest(GetSearchTerm(title) + "/30/seasons");
|
|
|
|
|
|
|
|
var response = client.ExecuteAndValidate<List<Show>>(restRequest);
|
|
|
|
|
|
|
|
|
|
|
|
return response.Select(MapSeries)
|
|
|
|
return response.Select(MapSeries)
|
|
|
|
.OrderBy(v => title.LevenshteinDistanceClean(v.Title))
|
|
|
|
.OrderBy(v => title.LevenshteinDistanceClean(v.Title))
|
|
|
|
.ToList();
|
|
|
|
.ToList();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (WebException ex)
|
|
|
|
catch (WebException ex)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -172,7 +202,6 @@ namespace NzbDrone.Core.MetadataSource
|
|
|
|
phrase = CollapseSpaceRegex.Replace(phrase, " ").Trim().ToLower();
|
|
|
|
phrase = CollapseSpaceRegex.Replace(phrase, " ").Trim().ToLower();
|
|
|
|
phrase = phrase.Trim('-');
|
|
|
|
phrase = phrase.Trim('-');
|
|
|
|
phrase = HttpUtility.UrlEncode(phrase);
|
|
|
|
phrase = HttpUtility.UrlEncode(phrase);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return phrase;
|
|
|
|
return phrase;
|
|
|
|
}
|
|
|
|
}
|
|
|
|