mirror of
https://github.com/Jackett/Jackett.git
synced 2025-09-17 17:34:09 +02:00
Convert myAmity to AngleSharp (#7377)
This commit is contained in:
@@ -4,7 +4,8 @@ using System.Collections.Specialized;
|
|||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using CsQuery;
|
using AngleSharp.Dom;
|
||||||
|
using AngleSharp.Html.Parser;
|
||||||
using Jackett.Common.Models;
|
using Jackett.Common.Models;
|
||||||
using Jackett.Common.Models.IndexerConfig;
|
using Jackett.Common.Models.IndexerConfig;
|
||||||
using Jackett.Common.Services.Interfaces;
|
using Jackett.Common.Services.Interfaces;
|
||||||
@@ -78,8 +79,9 @@ namespace Jackett.Common.Indexers
|
|||||||
|
|
||||||
await ConfigureIfOK(result.Cookies, result.Content != null && result.Cookies.Contains("pass=") && !result.Cookies.Contains("deleted"), () =>
|
await ConfigureIfOK(result.Cookies, result.Content != null && result.Cookies.Contains("pass=") && !result.Cookies.Contains("deleted"), () =>
|
||||||
{
|
{
|
||||||
CQ dom = result.Content;
|
var parser = new HtmlParser();
|
||||||
var errorMessage = dom["div.myFrame-content"].Html();
|
var dom = parser.ParseDocument(result.Content);
|
||||||
|
var errorMessage = dom.QuerySelector("div.myFrame-content").InnerHtml;
|
||||||
throw new ExceptionWithConfigData(errorMessage, configData);
|
throw new ExceptionWithConfigData(errorMessage, configData);
|
||||||
});
|
});
|
||||||
return IndexerConfigurationStatus.RequiresTesting;
|
return IndexerConfigurationStatus.RequiresTesting;
|
||||||
@@ -126,8 +128,9 @@ namespace Jackett.Common.Indexers
|
|||||||
var results = response.Content;
|
var results = response.Content;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
CQ dom = results;
|
var parser = new HtmlParser();
|
||||||
var rows = dom["table.ttable_headinner > tbody > tr.t-row"];
|
var dom = parser.ParseDocument(results);
|
||||||
|
var rows = dom.QuerySelectorAll("table.ttable_headinner > tbody > tr.t-row");
|
||||||
|
|
||||||
foreach (var row in rows)
|
foreach (var row in rows)
|
||||||
{
|
{
|
||||||
@@ -135,45 +138,43 @@ namespace Jackett.Common.Indexers
|
|||||||
release.MinimumRatio = 1;
|
release.MinimumRatio = 1;
|
||||||
release.MinimumSeedTime = 90 * 60;
|
release.MinimumSeedTime = 90 * 60;
|
||||||
|
|
||||||
var qRow = row.Cq();
|
var qDetailsLink = row.QuerySelector("a[href^=torrents-details.php?id=]");
|
||||||
|
var qDetailsTitle = row.QuerySelector("td:has(a[href^=\"torrents-details.php?id=\"]) b"); // #7100
|
||||||
var qDetailsLink = qRow.Find("a[href^=torrents-details.php?id=]").First();
|
release.Title = qDetailsTitle.TextContent;
|
||||||
var qDetailsTitle = qRow.Find("td:has(a[href^=\"torrents-details.php?id=\"]) b"); // #7100
|
|
||||||
release.Title = qDetailsTitle.Text();
|
|
||||||
|
|
||||||
if (!query.MatchQueryStringAND(release.Title))
|
if (!query.MatchQueryStringAND(release.Title))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
var qCatLink = qRow.Find("a[href^=torrents.php?cat=]").First();
|
var qCatLink = row.QuerySelector("a[href^=torrents.php?cat=]");
|
||||||
var qDLLink = qRow.Find("a[href^=download.php]").First();
|
var qDLLink = row.QuerySelector("a[href^=download.php]");
|
||||||
var qSeeders = qRow.Find("td:eq(6)");
|
var qSeeders = row.QuerySelector("td:nth-of-type(7)");
|
||||||
var qLeechers = qRow.Find("td:eq(7)");
|
var qLeechers = row.QuerySelector("td:nth-of-type(8)");
|
||||||
var qDateStr = qRow.Find("td:eq(9)").First();
|
var qDateStr = row.QuerySelector("td:nth-of-type(10)");
|
||||||
var qSize = qRow.Find("td:eq(4)").First();
|
var qSize = row.QuerySelector("td:nth-of-type(5)");
|
||||||
|
|
||||||
var catStr = qCatLink.Attr("href").Split('=')[1];
|
var catStr = qCatLink.GetAttribute("href").Split('=')[1];
|
||||||
release.Category = MapTrackerCatToNewznab(catStr);
|
release.Category = MapTrackerCatToNewznab(catStr);
|
||||||
|
|
||||||
release.Link = new Uri(SiteLink + qDLLink.Attr("href"));
|
release.Link = new Uri(SiteLink + qDLLink.GetAttribute("href"));
|
||||||
release.Comments = new Uri(SiteLink + qDetailsLink.Attr("href"));
|
release.Comments = new Uri(SiteLink + qDetailsLink.GetAttribute("href"));
|
||||||
release.Guid = release.Link;
|
release.Guid = release.Link;
|
||||||
|
|
||||||
var sizeStr = qSize.Text();
|
var sizeStr = qSize.TextContent;
|
||||||
release.Size = ReleaseInfo.GetBytes(sizeStr);
|
release.Size = ReleaseInfo.GetBytes(sizeStr);
|
||||||
|
|
||||||
release.Seeders = ParseUtil.CoerceInt(qSeeders.Text());
|
release.Seeders = ParseUtil.CoerceInt(qSeeders.TextContent);
|
||||||
release.Peers = ParseUtil.CoerceInt(qLeechers.Text()) + release.Seeders;
|
release.Peers = ParseUtil.CoerceInt(qLeechers.TextContent) + release.Seeders;
|
||||||
|
|
||||||
var dateStr = qDateStr.Text().Trim();
|
var dateStr = qDateStr.TextContent.Trim();
|
||||||
var dateGerman = DateTime.SpecifyKind(DateTime.ParseExact(dateStr, "dd.MM.yy HH:mm:ss", CultureInfo.InvariantCulture), DateTimeKind.Unspecified);
|
var dateGerman = DateTime.SpecifyKind(DateTime.ParseExact(dateStr, "dd.MM.yy HH:mm:ss", CultureInfo.InvariantCulture), DateTimeKind.Unspecified);
|
||||||
|
|
||||||
var pubDateUtc = TimeZoneInfo.ConvertTimeToUtc(dateGerman, germanyTz);
|
var pubDateUtc = TimeZoneInfo.ConvertTimeToUtc(dateGerman, germanyTz);
|
||||||
release.PublishDate = pubDateUtc.ToLocalTime();
|
release.PublishDate = pubDateUtc.ToLocalTime();
|
||||||
|
|
||||||
var grabs = qRow.Find("td:nth-child(6)").Text();
|
var grabs = row.QuerySelector("td:nth-child(6)").TextContent;
|
||||||
release.Grabs = ParseUtil.CoerceInt(grabs);
|
release.Grabs = ParseUtil.CoerceInt(grabs);
|
||||||
|
|
||||||
if (qRow.Find("img[src=\"images/free.gif\"]").Length >= 1)
|
if (row.QuerySelector("img[src=\"images/free.gif\"]") != null)
|
||||||
release.DownloadVolumeFactor = 0;
|
release.DownloadVolumeFactor = 0;
|
||||||
else
|
else
|
||||||
release.DownloadVolumeFactor = 1;
|
release.DownloadVolumeFactor = 1;
|
||||||
|
Reference in New Issue
Block a user