diff --git a/src/Jackett.Common/Definitions/desitorrents b/src/Jackett.Common/Definitions/desitorrents new file mode 100644 index 000000000..f7bdd6a9f --- /dev/null +++ b/src/Jackett.Common/Definitions/desitorrents @@ -0,0 +1,187 @@ +--- +id: desitorrents +name: DesiTorrents +description: "Desitorrents is a Private Torrent Tracker for BOLLYWOOD / TOLLYWOOD / MUSIC" +language: en-US +type: private +encoding: UTF-8 +links: + - https://desitorrents.tv/ + +caps: + categorymappings: + - {id: 1, cat: Movies, desc: "Movies"} + - {id: 2, cat: TV, desc: "TV"} + - {id: 3, cat: Audio, desc: "Music"} + + modes: + search: [q] + tv-search: [q, season, ep, imdbid, tvdbid] + movie-search: [q, imdbid, tmdbid] + music-search: [q] + +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 + inputs: + $raw: "{{ range .Categories }}categories[]={{.}}&{{end}}" + name: "{{ if .Query.IMDBID }}{{ else }}{{ .Keywords }}{{ end }}" # for dashboard imdbid search + description: "" + mediainfo: "" + keywords: "" + uploader: "" + tmdbId: "{{ .Query.TMDBID }}" + imdbId: "{{ .Query.IMDBIDShort }}" + tvdbId: "{{ .Query.TVDBID }}" + malId: "" + startYear: "" + endYear: "" + playlistId: "" + collectionId: "" + sortField: "{{ .Config.sort }}" + sortDirection: "{{ .Config.type }}" + perPage: 100 + page: 1 + free: "{{ if .Config.freeleech }}1{{ else }}{{ end }}" + + rows: + selector: table > tbody > tr:has(a[href*="/download/"]) + + fields: + category: + selector: a[href*="/categories/"] + attribute: href + filters: + - name: regexp + args: "/categories/(\\d+)" + title: + selector: td div a + download: + selector: a[href*="/download/"] + attribute: href + details: + selector: td div a + attribute: href + poster: + selector: div img + attribute: src + filters: + - name: replace + args: ["https://via.placeholder.com/90x135", ""] + - name: replace + args: ["https://via.placeholder.com/400x600", ""] + size: + selector: td:nth-last-child(6) + seeders: + selector: td:nth-last-child(5) + leechers: + selector: td:nth-last-child(4) + grabs: + selector: td:nth-last-child(3) + date: + selector: td:nth-last-child(2) + 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"]: 0 # 24 Hour FreeLeech From BON Store + i[class*="fa-trophy"]: 0 # Special FreeLeech For Certain User Groups + i[class*="fa-star"]: 0 # Freeleech From Token + i[class*="fa-coins"]: 0 # Freeleech From Token + i[class*="fa-globe"]: 0 # Global Freeleech + i[class*="fa-star"]: 0 # Freeleech + i[class*="fa-certificate"]: 0 # Featured Torrent + "*": 1 + uploadvolumefactor: + case: + i[class*="fa-gem"]: 2 # Single Torrent Double Upload + i[class*="fa-globe"]: 2 # Global Double Upload + i[class*="fa-certificate"]: 2 # Featured Torrent + "*": 1 + minimumratio: + text: 1.0 + minimumseedtime: + # 5 day (as seconds = 5 x 24 x 60 x 60) + text: 432000 +# UNIT3D 5.3.0 (custom) diff --git a/src/Jackett.Common/Indexers/DesiTorrents.cs b/src/Jackett.Common/Indexers/DesiTorrents.cs deleted file mode 100644 index 4c7472c87..000000000 --- a/src/Jackett.Common/Indexers/DesiTorrents.cs +++ /dev/null @@ -1,81 +0,0 @@ -using System.Collections.Generic; -using System.Diagnostics.CodeAnalysis; -using System.Threading.Tasks; -using Jackett.Common.Indexers.Abstract; -using Jackett.Common.Models; -using Jackett.Common.Services.Interfaces; -using Jackett.Common.Utils.Clients; -using Newtonsoft.Json.Linq; -using NLog; - -namespace Jackett.Common.Indexers -{ - [ExcludeFromCodeCoverage] - public class DesiTorrents : GazelleTracker - { - protected override string PosterUrl => SiteLink + "static/media/posters/"; - public DesiTorrents(IIndexerConfigurationService configService, WebClient wc, Logger l, IProtectionService ps, - ICacheService cs) - : base(id: "desitorrents", - name: "DesiTorrents", - description: "Desitorrents is a Private Torrent Tracker for BOLLYWOOD / TOLLYWOOD / GENERAL", - link: "https://desitorrents.tv/", - caps: new TorznabCapabilities - { - TvSearchParams = new List - { - TvSearchParam.Q, TvSearchParam.Season, TvSearchParam.Ep - }, - MovieSearchParams = new List - { - MovieSearchParam.Q - }, - MusicSearchParams = new List - { - MusicSearchParam.Q - }, - BookSearchParams = new List - { - BookSearchParam.Q - } - }, - configService: configService, - client: wc, - logger: l, - p: ps, - cs: cs, - supportsFreeleechTokens: false, - has2Fa: true - ) - { - Language = "en-US"; - Type = "private"; - - AddCategoryMapping(1, TorznabCatType.Movies, "Movies"); - AddCategoryMapping(2, TorznabCatType.TV, "Tv shows"); - AddCategoryMapping(3, TorznabCatType.Audio, "Music"); - AddCategoryMapping(4, TorznabCatType.BooksEBook, "ebooks"); - AddCategoryMapping(5, TorznabCatType.TVSport, "Sports"); - AddCategoryMapping(6, TorznabCatType.PCGames, "Games"); - } - - protected override async Task> PerformQuery(TorznabQuery query) - { - var releases = await base.PerformQuery(query); - foreach (var release in releases) - { - release.MinimumRatio = 0.6; - release.MinimumSeedTime = 259200; - } - return releases; - } - - protected override bool ReleaseInfoPostParse(ReleaseInfo release, JObject torrent, JObject result) - { - // Add missing category information - var category = (string)result["category"]; - release.Category = MapTrackerCatToNewznab(category); - return true; - } - } -} diff --git a/src/Jackett.Updater/Program.cs b/src/Jackett.Updater/Program.cs index 58ead4881..4dd1793c4 100644 --- a/src/Jackett.Updater/Program.cs +++ b/src/Jackett.Updater/Program.cs @@ -300,7 +300,6 @@ namespace Jackett.Updater "Definitions/darmowetorenty.yml", // migrated to C# "Definitions/danishbytes.yml", // migrated to C# "Definitions/demonsite.yml", - "Definitions/desitorrents.yml", // migrated to C# "Definitions/digbt.yml", "Definitions/documentarytorrents.yml", "Definitions/downloadville.yml",