core: implement filters in cardigann json parser (#12922)

This commit is contained in:
Diego Heras
2022-02-07 21:54:17 +01:00
committed by GitHub
parent 7a7144bd9d
commit 198a6d1f8c
25 changed files with 3326 additions and 31 deletions

View File

@@ -1,5 +1,4 @@
using System;
using System.Globalization;
using System.Linq;
using System.Threading.Tasks;
using Jackett.Common.Indexers;

View File

@@ -0,0 +1,82 @@
using System.Linq;
using System.Threading.Tasks;
using Jackett.Common.Indexers;
using Jackett.Common.Models;
using Jackett.Test.TestHelpers;
using NLog;
using NUnit.Framework;
using YamlDotNet.Serialization;
using YamlDotNet.Serialization.NamingConventions;
// todo: test download block
// todo: test login block
// todo: test settings block
// todo: test other search modes
// todo: review coverage, too many things missing (headers, encoding, ...)
namespace Jackett.Test.Common.Indexers
{
[TestFixture]
public class CardigannIndexerJsonTests
{
private readonly TestWebClient _webClient = new TestWebClient();
private readonly Logger _logger = LogManager.GetCurrentClassLogger();
private readonly TestCacheService _cacheService = new TestCacheService();
[Test]
public async Task TestCardigannJsonAsync()
{
_webClient.RegisterRequestCallback("https://jsondefinition1.com/api/torrents/filter?api_token=&name=1080p&sortField=created_at&sortDirection=desc&perPage=100&page=1",
"json-response1.json");
var definition = LoadTestDefinition("json-definition1.yml");
var indexer = new CardigannIndexer(null, _webClient, _logger, null, _cacheService, definition);
var query = new TorznabQuery
{
QueryType = "search",
SearchTerm = "1080p",
};
var result = await indexer.ResultsForQuery(query, false);
Assert.AreEqual(false, result.IsFromCache);
var releases = result.Releases.ToList();
Assert.AreEqual(78, releases.Count);
var firstRelease = releases.First();
Assert.AreEqual(2, firstRelease.Category.Count);
Assert.AreEqual(2000, firstRelease.Category.First());
Assert.AreEqual(100001, firstRelease.Category.Last());
Assert.AreEqual("The Eyes of Tammy Faye (2021) BDRip 1080p AVC ES DD+ 5.1 EN DTSSS 5.1 Subs] HDO", firstRelease.Title);
Assert.AreEqual("https://jsondefinition1.com/torrents/24804", firstRelease.Details.ToString());
Assert.AreEqual("https://jsondefinition1.com/torrent/download/24804.01c887e14d0845f195bc12b31ea27d38", firstRelease.Link.ToString());
Assert.AreEqual("https://jsondefinition1.com/torrent/download/24804.01c887e14d0845f195bc12b31ea27d38", firstRelease.Guid.ToString());
Assert.AreEqual(null, firstRelease.MagnetUri);
Assert.AreEqual(null, firstRelease.InfoHash);
Assert.AreEqual("https://image.tmdb.org/t/p/w92/iBjkm6oxTPrvNkzr63cmnrpsQPR.jpg", firstRelease.Poster.ToString());
Assert.AreEqual(2021, firstRelease.PublishDate.Year);
Assert.AreEqual(17964744704, firstRelease.Size);
Assert.AreEqual(27, firstRelease.Seeders);
Assert.AreEqual(30, firstRelease.Peers);
Assert.AreEqual(1, firstRelease.Files);
Assert.AreEqual(29, firstRelease.Grabs);
Assert.AreEqual(1, firstRelease.DownloadVolumeFactor);
Assert.AreEqual(1, firstRelease.UploadVolumeFactor);
Assert.AreEqual(null, firstRelease.MinimumRatio);
Assert.AreEqual(345600, firstRelease.MinimumSeedTime);
Assert.AreEqual(451.73625183105469, firstRelease.Gain);
Assert.AreEqual(9115530, firstRelease.Imdb);
Assert.AreEqual(null, firstRelease.RageID);
Assert.AreEqual(601470, firstRelease.TMDb);
Assert.AreEqual(0, firstRelease.TVDBId);
}
private static IndexerDefinition LoadTestDefinition(string fileName)
{
var definitionString = TestUtil.LoadTestFile(fileName);
var deserializer = new DeserializerBuilder()
.WithNamingConvention(CamelCaseNamingConvention.Instance)
.Build();
return deserializer.Deserialize<IndexerDefinition>(definitionString);
}
}
}

View File

@@ -0,0 +1,141 @@
---
id: jsondefinition1
name: jsondefinition1
description: "jsondefinition1"
language: es-ES
type: private
encoding: UTF-8
links:
- https://jsondefinition1.com/
caps:
categorymappings:
- {id: 1, cat: Movies, desc: "Películas"}
- {id: 2, cat: TV, desc: "Series"}
- {id: 3, cat: Audio, desc: "Música"}
- {id: 4, cat: TV/Documentary, desc: "Documentales"}
modes:
search: [q]
tv-search: [q, season, ep, imdbid, tvdbid]
movie-search: [q, imdbid, tmdbid]
music-search: [q]
book-search: [q]
settings:
- name: apikey
type: text
label: APIKey
- name: info_key
type: info
label: About your API key
default: "Find or Generate a new API Token by accessing your account <i>My configuration / Mi configuración => Secutiy / Seguridad</i> page and clicking on the <b>API Token</b> tab."
- name: freeleech
type: checkbox
label: Search freeleech only
default: false
- name: sort
type: select
label: Sort requested from site
default: created_at
options:
created_at: created
seeders: seeders
size: size
name: title
- name: type
type: select
label: Order requested from site
default: desc
options:
desc: desc
asc: asc
login:
path: /api/torrents
method: get
inputs:
api_token: "{{ .Config.apikey }}"
error:
- selector: a[href*="/login"]
search:
paths:
# https://hdinnovations.github.io/UNIT3D-Community-Edition-Docs/api_endpoints.html
# https://github.com/HDInnovations/UNIT3D-Community-Edition/blob/master/app/Http/Controllers/API/TorrentController.php
- path: "/api/torrents/filter?api_token={{ .Config.apikey }}&name={{ if .Query.IMDBID }}{{ else }}{{ .Keywords }}{{ end }}{{ if .Query.TMDBID }}&tmdbId={{ .Query.TMDBID }}{{ else }}{{ end }}{{ if .Query.IMDBIDShort }}&imdbId={{ .Query.IMDBIDShort }}{{ else }}{{ end }}{{ if .Query.TVDBID }}&tvdbId={{ .Query.TVDBID }}{{ else }}{{ end }}&sortField={{ .Config.sort }}&sortDirection={{ .Config.type }}&perPage=100&page=1{{ range .Categories }}&categories[]={{.}}{{end}}{{ if .Config.freeleech }}&free=1{{ else }}{{ end }}"
response:
type: json
rows:
selector: data:has(attributes.size):has(attributes.name:contains(1080)):has(attributes.poster:contains(.jpg)):not(attributes.fake_att):not(attributes.uploader:contains(DarkSwan2001))
attribute: attributes
count:
selector: meta.total
fields:
categorydesc:
selector: category
# title:
# selector: name
# filters:
# - name: re_replace
# args: ["\\[", " "]
title_dts:
selector: name:contains(DTS)
optional: true
filters:
- name: re_replace
args: ["DTS", "DTSSS"]
title_notdts:
selector: name:not(:contains(DTS))
optional: true
title:
text: "{{ if .Result.title_dts }}{{ .Result.title_dts }}{{ else }}{{ .Result.title_notdts }}{{ end }}"
filters:
- name: re_replace
args: ["\\[", " "]
details:
selector: details_link
download:
selector: download_link
poster:
selector: poster
filters:
- name: replace
args: ["https://via.placeholder.com/90x135", ""]
imdbid:
selector: imdb_id
tmdbid:
selector: tmdb_id
tvdbid:
selector: tvdb_id
files:
selector: num_file
seeders:
selector: seeders
leechers:
selector: leechers
grabs:
selector: times_completed
date:
# 2021-10-18T00:34:50.000000Z"
selector: created_at
size:
selector: size
downloadvolumefactor:
# api returns 0=false, 1=true
selector: freeleech
case:
0: 1 # not free
1: 0 # freeleech
uploadvolumefactor:
# api returns 0=false, 1=true
selector: double_upload
case:
0: 1 # normal
1: 2 # double
minimumseedtime:
# 4 days (as seconds = 4 x 24 x 60 x 60)
text: 345600
# json UNIT3D ???

File diff suppressed because it is too large Load Diff