diff --git a/src/Jackett.Common/Definitions/hdolimpo-api.yml b/src/Jackett.Common/Definitions/hdolimpo-api.yml new file mode 100644 index 000000000..2453964ab --- /dev/null +++ b/src/Jackett.Common/Definitions/hdolimpo-api.yml @@ -0,0 +1,171 @@ +--- +id: hdolimpo-api +name: HD-Olimpo (API) +description: "HD-Olimpo is a SPANISH site for HD content" +language: es-ES +type: private +encoding: UTF-8 +links: + - https://hd-olimpo.club/ +legacylinks: + - https://hdolimpo.co/ + +caps: + # dont forget to update the case block in the search fields category + 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 My configuration / Mi configuración => Secutiy / Seguridad page and clicking on the API Token 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 + +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 + attribute: attributes + + rows: + selector: data + count: + selector: meta.total + + fields: + category: + selector: category + case: + "Películas": 1 + "Series": 2 + "Música": 3 + "Documentales": 4 + title: + selector: name + filters: + - name: re_replace + args: ["\\[", " "] + - name: re_replace + args: ["\\]", " "] + - name: re_replace + args: ["(?i)(full(bluray)?)", "BRDISK"] # FULL(BR/UHD) -> BRDISK + - name: replace + args: ["HDOlimpo", ""] # Delete HDOlimpo + - name: replace + args: ["HD-Olimpo", ""] # Delete HD-Olimpo + - name: replace + args: ["E-AC-3", "EAC3"] + - name: re_replace + args: ["[ -](?i)español[ -]", " SPANiSH "] + - name: re_replace + args: ["[ -](?i)castellano[ -]", " SPANiSH "] + - name: re_replace + args: ["[ -](?i)spa[ -]", " SPANiSH "] + - name: re_replace + args: ["[ -](?i)esp[ -]", " SPANiSH "] + - name: re_replace + args: ["[ -](?i)ingl[eé]s[ -]", " English "] + - name: re_replace + args: ["[ -](?i)[ei]ng[ -]", " English "] + - name: re_replace + args: ["[ -](?i)cat[ -]", " Catalan "] + - name: re_replace + args: ["[ -](?i)vas[ -]", " Basque "] + - name: re_replace + args: ["[ -](?i)fr[ae][ -]", " French "] + - name: re_replace + args: ["[ -](?i)jap[ -]", " Japanese "] + - name: re_replace + args: ["[ -](?i)ita[ -]", " Italian "] + - name: re_replace + args: ["[ -](?i)rus[ -]", " Russian "] + - name: re_replace + args: ["[ -](?i)ger[ -]", " German "] + - name: re_replace + args: ["(?i)(triaudio)", "MULTi/SPANiSH/English"] + - name: re_replace + args: ["(?i)(dual)", " MULTi/SPANiSH "] + - name: re_replace + args: ["\\.+", "."] # More than 1 dot -> . + - name: re_replace + args: ["^\\.", ""] # Delete first dot + - name: re_replace + args: ["\\s+", " "] # More than 1 space to 1 space + + details: + selector: details_link + download: + selector: download_link + poster: + selector: poster + 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 ??? diff --git a/src/Jackett.Common/Definitions/hdolimpo.yml b/src/Jackett.Common/Definitions/hdolimpo.yml deleted file mode 100644 index 31eb1c6b3..000000000 --- a/src/Jackett.Common/Definitions/hdolimpo.yml +++ /dev/null @@ -1,244 +0,0 @@ ---- -id: hdolimpo -name: HD-Olimpo -description: "HD-Olimpo is a SPANISH site for HD content" -language: es-ES -type: private -encoding: UTF-8 -links: - - https://hd-olimpo.club/ -legacylinks: - - https://hdolimpo.co/ - -caps: - categorymappings: - - {id: 1, cat: Movies, desc: "Movies"} - - {id: 2, cat: TV, desc: "TV"} - - {id: 3, cat: Audio, desc: "Music"} - - {id: 4, cat: TV/Documentary, desc: "Documentaries"} - - modes: - search: [q] - tv-search: [q, season, ep, imdbid, tvdbid] - movie-search: [q, imdbid, tmdbid] - -settings: - - name: username - type: text - label: Username - - name: password - type: password - label: Password - - 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: login - method: form - form: form[action$="/login"] - inputs: - username: "{{ .Config.username }}" - password: "{{ .Config.password }}" - remember: on - selectorinputs: - _token: - selector: input[name="_token"] - attribute: value - error: - - selector: div#ERROR_COPY -# test: -# path: / -# selector: a[href$="/logout"] - -search: - paths: - - path: torrents/filter - inputs: - $raw: "{{ range .Categories }}categories[]={{.}}&{{end}}" - search: "{{ if .Query.IMDBID }}{{ else }}{{ .Keywords }}{{ end }}" # for dashboard imdbid search - description: "" - keywords: "" - uploader: "" - imdb: "{{ .Query.IMDBIDShort }}" - tvdb: "{{ .Query.TVDBID }}" - tmdb: "{{ .Query.TMDBID }}" - mal: "" - igdb: "" - sorting: "{{ .Config.sort }}" - direction: "{{ .Config.type }}" - qty: 100 - page: 0 - view: list - freeleech: "{{ if .Config.freeleech }}1{{ else }}{{ end }}" - - rows: - selector: table > tbody > tr - - fields: - category: - selector: a[href*="/categories/"] - attribute: href - filters: - - name: regexp - args: "/categories/(\\d+)" - - title: - selector: a.view-torrent - filters: - - name: re_replace - args: ["\\[", " "] - - name: re_replace - args: ["\\]", " "] - - name: re_replace - args: ["(?i)(full(bluray)?)", "BRDISK"] # FULL(BR/UHD) -> BRDISK - - name: replace - args: ["HDOlimpo", ""] # Delete HDOlimpo - - name: replace - args: ["HD-Olimpo", ""] # Delete HD-Olimpo - - name: replace - args: ["E-AC-3", "EAC3"] - - name: re_replace - args: ["[ -](?i)español[ -]", " SPANiSH "] - - name: re_replace - args: ["[ -](?i)castellano[ -]", " SPANiSH "] - - name: re_replace - args: ["[ -](?i)spa[ -]", " SPANiSH "] - - name: re_replace - args: ["[ -](?i)esp[ -]", " SPANiSH "] - - name: re_replace - args: ["[ -](?i)ingl[eé]s[ -]", " English "] - - name: re_replace - args: ["[ -](?i)[ei]ng[ -]", " English "] - - name: re_replace - args: ["[ -](?i)cat[ -]", " Catalan "] - - name: re_replace - args: ["[ -](?i)vas[ -]", " Basque "] - - name: re_replace - args: ["[ -](?i)fr[ae][ -]", " French "] - - name: re_replace - args: ["[ -](?i)jap[ -]", " Japanese "] - - name: re_replace - args: ["[ -](?i)ita[ -]", " Italian "] - - name: re_replace - args: ["[ -](?i)rus[ -]", " Russian "] - - name: re_replace - args: ["[ -](?i)ger[ -]", " German "] - - name: re_replace - args: ["(?i)(triaudio)", "MULTi/SPANiSH/English"] - - name: re_replace - args: ["(?i)(dual)", " MULTi/SPANiSH "] - - name: re_replace - args: ["\\.+", "."] # More than 1 dot -> . - - name: re_replace - args: ["^\\.", ""] # Delete first dot - - name: re_replace - args: ["\\s+", " "] # More than 1 space to 1 space - - download: - selector: a[href*="/download/"] - attribute: href - details: - selector: a.view-torrent - attribute: href - poster: - selector: div.torrent-poster img - attribute: src - filters: - - name: prepend - args: "https://images.weserv.nl/?url=" # for display on dashboard - - name: append - args: "&w=180&h=270" # for display on dashboard - - name: replace - args: ["https://images.weserv.nl/?url=https://via.placeholder.com/600x900&w=180&h=270", ""] - size: - selector: td:nth-last-child(4) - seeders: - selector: td:nth-last-child(3) - leechers: - selector: td:nth-last-child(2) - grabs: - selector: td:nth-last-child(1) - imdbid: - selector: a[href*="imdb.com/title/tt"] - attribute: href - tmdbid: - selector: a[href*="themoviedb.org/movie/"] - attribute: href - date: - selector: time - filters: - # translations for Turkish|Estonian|Danish|Italian|Polish|Norwegian|Portuguese|Czech|Russian|Romanian|Spanish|French|German|Bulgarian|Dutch|Chinese|Japanese|Swedish - - name: re_replace - args: ["(?i)(önce|tagasi|geleden|fa|temu|siden|há|atrás|nazpět|назад|acum|în urmă|hace|il y a|vor|преди|前|sedan)", " ago"] - - name: re_replace - args: ["(?i)(saniye|sekundit|sekunder|secondi|sekund|segundos|sekundami|секунд|secunde|secondes|Sekunden|секунди|seconden|秒前)", "seconds"] - - name: re_replace - args: ["(?i)(minutit|minutter|minuti|minuty|minutos|минуты|минут|Minuten|минути|minuten|minuter)", "minutes"] - - name: re_replace - args: ["(?i)(dakika|minut|minuto|minuta|minutt|минута|Minute|minuut|分钟|分)", " minute"] - - name: re_replace - args: ["(?i)(tundi|timer|ore|godziny|horas|hodiny|hoden|часа|часов|ore|heures|Stunden|timmar)", "hours"] - - name: re_replace - args: ["(?i)(saat|tund|time|ora|godzina|hora|hodina|час|oră|heure|Stunde|uur|小时|時間|timme)", " hour"] - - name: re_replace - args: ["(?i)(päeva|dage|giorni|dni|dias|dny|дня|дней|zile|días|jours|Tagen|дни|dagen|dagar)", "days"] - - name: re_replace - args: ["(?i)(gün|päev|dag|giorno|dzień|dia|den|день|zi|día|jour|Tag|ден|天|日)", " day"] - - name: re_replace - args: ["(?i)(nädalat|uger|settimane|tygodnie|uker|semanas|týdny|недели|недель|săptămâni|semaines|Wochen|седмици|weken|veckor)", "weeks"] - - name: re_replace - args: ["(?i)(hafta|nädal|uge|settimana|tydzień|uke|semana|týden|неделю|săptămână|semaine|Woche|седмица|周|週間|vecka)", " week"] - - name: re_replace - args: ["(?i) (ay)", "month"] - - name: re_replace - args: ["(?i)(kuud|måneder|mesi|miesiące|meses|měsíce|месяца|месяцев|luni|meses|mois|Monaten|месеца|maanden|månader)", "months"] - - name: re_replace - args: ["(?i)(kuu|måned|mese|miesiąc|mês|měsíc|месяц|lună|mes|Monat|месец|maand|个月|ヶ月|månad)", " month"] - - name: re_replace - args: ["(?i)(aastat|anni|lata|anos|roky|года|ani|años|ans|Jahren|години)", " years"] - - name: re_replace - args: ["(?i)(yil|aasta|år|anno|rok|ano|год|año|Jahr|година|jaar|年)", " year"] - - name: re_replace - args: ["(?i) (an)", "year"] - - name: re_replace - args: ["(?i)(För |und)", ""] # Misc removals - - name: timeago - downloadvolumefactor: - case: - i[class*="fa-id-badge text-orange"]: 0 # 24 Hour FreeLeech From BON Store - i[class*="fa-trophy text-purple"]: 0 # Special FreeLeech For Certain User Groups - i[class*="fa-star text-bold"]: 0 # Freeleech From Token - i[class*="fa-coins text-bold"]: 0 # Freeleech From Token - i[class*="fa-globe text-blue"]: 0 # Global Freeleech - i[class*="fas fa-star text-gold"]: 0 # Freeleech - i[class*="fal fa-star text-gold"]: 0.5 # 50% Freeleech - i[class*="fa-certificate text-pink"]: 0 # Featured Torrent - "*": 1 - uploadvolumefactor: - case: - i[class*="fa-gem text-green"]: 2 # Single Torrent Double Upload - i[class*="fa-globe text-green"]: 2 # Global Double Upload - i[class*="fa-certificate text-pink"]: 2 # Featured Torrent - "*": 1 - minimumseedtime: - # 4 days (as seconds = 4 x 24 x 60 x 60) - text: 345600 -# UNIT3D 2.4.0 diff --git a/src/Jackett.Updater/Program.cs b/src/Jackett.Updater/Program.cs index a05f66a81..8959d7653 100644 --- a/src/Jackett.Updater/Program.cs +++ b/src/Jackett.Updater/Program.cs @@ -356,6 +356,7 @@ namespace Jackett.Updater "Definitions/hdbc.yml", // renamed to hdbitscom "Definitions/hdclub.yml", "Definitions/hddisk.yml", + "Definitions/hdolimpo.yml", // migrated to UNIT3D API "Definitions/hdplus.yml", "Definitions/hdreactor.yml", // renamed to hdhouse "Definitions/hdstreet.yml",