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.
136 lines
5.5 KiB
136 lines
5.5 KiB
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Net;
|
|
using System.Text.RegularExpressions;
|
|
using NzbDrone.Common.Extensions;
|
|
using NzbDrone.Common.Http;
|
|
using NzbDrone.Core.Indexers.Exceptions;
|
|
using NzbDrone.Core.Parser.Model;
|
|
|
|
namespace NzbDrone.Core.Indexers.BroadcastheNet
|
|
{
|
|
public class BroadcastheNetParser : IParseIndexerResponse
|
|
{
|
|
private static readonly Regex RegexProtocol = new Regex("^https?:", RegexOptions.Compiled);
|
|
|
|
public Action<IDictionary<string, string>, DateTime?> CookiesUpdater { get; set; }
|
|
|
|
private readonly IndexerCapabilitiesCategories _categories;
|
|
|
|
public BroadcastheNetParser(IndexerCapabilitiesCategories categories)
|
|
{
|
|
_categories = categories;
|
|
}
|
|
|
|
public IList<ReleaseInfo> ParseResponse(IndexerResponse indexerResponse)
|
|
{
|
|
var results = new List<ReleaseInfo>();
|
|
var indexerHttpResponse = indexerResponse.HttpResponse;
|
|
|
|
switch (indexerHttpResponse.StatusCode)
|
|
{
|
|
case HttpStatusCode.Unauthorized:
|
|
throw new IndexerAuthException("API Key invalid or not authorized");
|
|
case HttpStatusCode.NotFound:
|
|
throw new IndexerException(indexerResponse, "Indexer API call returned NotFound, the Indexer API may have changed.");
|
|
case HttpStatusCode.ServiceUnavailable:
|
|
throw new RequestLimitReachedException(indexerResponse, "Cannot do more than 150 API requests per hour.");
|
|
default:
|
|
if (indexerHttpResponse.StatusCode != HttpStatusCode.OK)
|
|
{
|
|
throw new IndexerException(indexerResponse, "Indexer API call returned an unexpected StatusCode [{0}]", indexerHttpResponse.StatusCode);
|
|
}
|
|
|
|
break;
|
|
}
|
|
|
|
if (indexerHttpResponse.Headers.ContentType != null && indexerHttpResponse.Headers.ContentType.Contains("text/html"))
|
|
{
|
|
throw new IndexerException(indexerResponse, "Indexer responded with html content. Site is likely blocked or unavailable.");
|
|
}
|
|
|
|
if (indexerResponse.Content.ContainsIgnoreCase("Call Limit Exceeded"))
|
|
{
|
|
throw new RequestLimitReachedException(indexerResponse, "Cannot do more than 150 API requests per hour.");
|
|
}
|
|
|
|
if (indexerResponse.Content == "Query execution was interrupted")
|
|
{
|
|
throw new IndexerException(indexerResponse, "Indexer API returned an internal server error");
|
|
}
|
|
|
|
var jsonResponse = new HttpResponse<JsonRpcResponse<BroadcastheNetTorrents>>(indexerHttpResponse).Resource;
|
|
|
|
if (jsonResponse.Error != null || jsonResponse.Result == null)
|
|
{
|
|
throw new IndexerException(indexerResponse, "Indexer API call returned an error [{0}]", jsonResponse.Error);
|
|
}
|
|
|
|
if (jsonResponse.Result.Results == 0)
|
|
{
|
|
return results;
|
|
}
|
|
|
|
var protocol = indexerResponse.HttpRequest.Url.Scheme + ":";
|
|
|
|
foreach (var torrent in jsonResponse.Result.Torrents.Values)
|
|
{
|
|
var torrentInfo = new TorrentInfo();
|
|
|
|
torrentInfo.Guid = string.Format("BTN-{0}", torrent.TorrentID);
|
|
torrentInfo.Title = CleanReleaseName(torrent.ReleaseName);
|
|
torrentInfo.Size = torrent.Size;
|
|
torrentInfo.DownloadUrl = RegexProtocol.Replace(torrent.DownloadURL, protocol);
|
|
torrentInfo.InfoUrl = string.Format("{0}//broadcasthe.net/torrents.php?id={1}&torrentid={2}", protocol, torrent.GroupID, torrent.TorrentID);
|
|
|
|
//torrentInfo.CommentUrl =
|
|
if (torrent.TvdbID.HasValue)
|
|
{
|
|
torrentInfo.TvdbId = torrent.TvdbID.Value;
|
|
}
|
|
|
|
if (torrent.TvrageID.HasValue)
|
|
{
|
|
torrentInfo.TvRageId = torrent.TvrageID.Value;
|
|
}
|
|
|
|
torrentInfo.PublishDate = new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc).ToUniversalTime().AddSeconds(torrent.Time);
|
|
|
|
//torrentInfo.MagnetUrl =
|
|
torrentInfo.InfoHash = torrent.InfoHash;
|
|
torrentInfo.Seeders = torrent.Seeders;
|
|
torrentInfo.Peers = torrent.Leechers + torrent.Seeders;
|
|
|
|
torrentInfo.Origin = torrent.Origin;
|
|
torrentInfo.Source = torrent.Source;
|
|
torrentInfo.Container = torrent.Container;
|
|
torrentInfo.Codec = torrent.Codec;
|
|
torrentInfo.Resolution = torrent.Resolution;
|
|
torrentInfo.UploadVolumeFactor = 1;
|
|
torrentInfo.DownloadVolumeFactor = 0;
|
|
torrentInfo.MinimumRatio = 1;
|
|
|
|
torrentInfo.Categories = _categories.MapTrackerCatToNewznab(torrent.Resolution);
|
|
|
|
// Default to TV if category could not be mapped
|
|
if (torrentInfo.Categories == null || !torrentInfo.Categories.Any())
|
|
{
|
|
torrentInfo.Categories = new List<IndexerCategory> { NewznabStandardCategory.TV };
|
|
}
|
|
|
|
results.Add(torrentInfo);
|
|
}
|
|
|
|
return results;
|
|
}
|
|
|
|
private string CleanReleaseName(string releaseName)
|
|
{
|
|
releaseName = releaseName.Replace("\\", "");
|
|
|
|
return releaseName;
|
|
}
|
|
}
|
|
}
|