mirror of
https://github.com/Jackett/Jackett.git
synced 2025-09-17 17:34:09 +02:00
Add FunFile Tracker
This commit is contained in:
@@ -32,6 +32,7 @@ Developer note: The software implements the [Torznab](https://github.com/Sonarr/
|
|||||||
* EuTorrents
|
* EuTorrents
|
||||||
* FileList
|
* FileList
|
||||||
* Freshon
|
* Freshon
|
||||||
|
* FunFile
|
||||||
* Fuzer
|
* Fuzer
|
||||||
* Ghost City
|
* Ghost City
|
||||||
* HD-Space
|
* HD-Space
|
||||||
|
BIN
src/Jackett/Content/logos/funfile.png
Normal file
BIN
src/Jackett/Content/logos/funfile.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 15 KiB |
142
src/Jackett/Indexers/FunFile.cs
Normal file
142
src/Jackett/Indexers/FunFile.cs
Normal file
@@ -0,0 +1,142 @@
|
|||||||
|
using CsQuery;
|
||||||
|
using Jackett.Models;
|
||||||
|
using Jackett.Services;
|
||||||
|
using Jackett.Utils;
|
||||||
|
using Jackett.Utils.Clients;
|
||||||
|
using Newtonsoft.Json.Linq;
|
||||||
|
using NLog;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using Jackett.Models.IndexerConfig;
|
||||||
|
using System.Collections.Specialized;
|
||||||
|
|
||||||
|
namespace Jackett.Indexers
|
||||||
|
{
|
||||||
|
public class FunFile : BaseIndexer, IIndexer
|
||||||
|
{
|
||||||
|
private string SearchUrl { get { return SiteLink + "browse.php"; } }
|
||||||
|
private string LoginUrl { get { return SiteLink + "takelogin.php"; } }
|
||||||
|
|
||||||
|
new ConfigurationDataBasicLoginWithRSSAndDisplay configData
|
||||||
|
{
|
||||||
|
get { return (ConfigurationDataBasicLoginWithRSSAndDisplay)base.configData; }
|
||||||
|
set { base.configData = value; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public FunFile(IIndexerManagerService i, Logger l, IWebClient w, IProtectionService ps)
|
||||||
|
: base(name: "FunFile",
|
||||||
|
description: "A general tracker",
|
||||||
|
link: "https://www.funfile.org/",
|
||||||
|
caps: new TorznabCapabilities(),
|
||||||
|
manager: i,
|
||||||
|
client: w,
|
||||||
|
logger: l,
|
||||||
|
p: ps,
|
||||||
|
configData: new ConfigurationDataBasicLoginWithRSSAndDisplay())
|
||||||
|
{
|
||||||
|
AddCategoryMapping(44, TorznabCatType.TVAnime); // Anime
|
||||||
|
AddCategoryMapping(22, TorznabCatType.PC); // Applications
|
||||||
|
AddCategoryMapping(43, TorznabCatType.AudioAudiobook); // Audio Books
|
||||||
|
AddCategoryMapping(27, TorznabCatType.Books); // Ebook
|
||||||
|
AddCategoryMapping(4, TorznabCatType.PCGames); // Games
|
||||||
|
AddCategoryMapping(40, TorznabCatType.OtherMisc); // Miscellaneous
|
||||||
|
AddCategoryMapping(19, TorznabCatType.Movies); // Movies
|
||||||
|
AddCategoryMapping(6, TorznabCatType.Audio); // Music
|
||||||
|
AddCategoryMapping(31, TorznabCatType.PCPhoneOther); // Portable
|
||||||
|
AddCategoryMapping(7, TorznabCatType.TV); // TV
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<IndexerConfigurationStatus> ApplyConfiguration(JToken configJson)
|
||||||
|
{
|
||||||
|
configData.LoadValuesFromJson(configJson);
|
||||||
|
var pairs = new Dictionary<string, string> {
|
||||||
|
{ "username", configData.Username.Value },
|
||||||
|
{ "password", configData.Password.Value },
|
||||||
|
{ "login", "Login" },
|
||||||
|
};
|
||||||
|
|
||||||
|
var result = await RequestLoginAndFollowRedirect(LoginUrl, pairs, null, true, null, LoginUrl);
|
||||||
|
await ConfigureIfOK(result.Cookies, result.Content.Contains("logout.php"), () =>
|
||||||
|
{
|
||||||
|
CQ dom = result.Content;
|
||||||
|
var errorMessage = dom["td.mf_content"].Html();
|
||||||
|
throw new ExceptionWithConfigData(errorMessage, configData);
|
||||||
|
});
|
||||||
|
return IndexerConfigurationStatus.RequiresTesting;
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<IEnumerable<ReleaseInfo>> PerformQuery(TorznabQuery query)
|
||||||
|
{
|
||||||
|
List<ReleaseInfo> releases = new List<ReleaseInfo>();
|
||||||
|
|
||||||
|
var searchString = query.GetQueryString();
|
||||||
|
var searchUrl = SearchUrl;
|
||||||
|
var queryCollection = new NameValueCollection();
|
||||||
|
queryCollection.Add("incldead", "1");
|
||||||
|
queryCollection.Add("showspam", "1");
|
||||||
|
|
||||||
|
if (!string.IsNullOrWhiteSpace(searchString))
|
||||||
|
{
|
||||||
|
queryCollection.Add("search", searchString);
|
||||||
|
}
|
||||||
|
|
||||||
|
var cats = MapTorznabCapsToTrackers(query);
|
||||||
|
string cat = "0";
|
||||||
|
if (cats.Count == 1)
|
||||||
|
{
|
||||||
|
cat = cats[0];
|
||||||
|
}
|
||||||
|
queryCollection.Add("cat", cat);
|
||||||
|
|
||||||
|
searchUrl += "?" + queryCollection.GetQueryString();
|
||||||
|
|
||||||
|
var results = await RequestStringWithCookiesAndRetry(searchUrl);
|
||||||
|
try
|
||||||
|
{
|
||||||
|
CQ dom = results.Content;
|
||||||
|
var rows = dom["table[cellpadding=2] > tbody > tr:has(td.row3)"];
|
||||||
|
foreach (var row in rows)
|
||||||
|
{
|
||||||
|
var release = new ReleaseInfo();
|
||||||
|
release.MinimumRatio = 1;
|
||||||
|
release.MinimumSeedTime = 48 * 60 * 60;
|
||||||
|
|
||||||
|
var qRow = row.Cq();
|
||||||
|
var qCatLink = qRow.Find("a[href^=browse.php?cat=]").First();
|
||||||
|
var qDetailsLink = qRow.Find("a[href^=details.php?id=]").First();
|
||||||
|
var qSeeders = qRow.Find("td:eq(9)");
|
||||||
|
var qLeechers = qRow.Find("td:eq(10)");
|
||||||
|
var qDownloadLink = qRow.Find("a[href^=download.php]").First();
|
||||||
|
var qTimeAgo = qRow.Find("td:eq(5)");
|
||||||
|
var qSize = qRow.Find("td:eq(7)");
|
||||||
|
|
||||||
|
var catStr = qCatLink.Attr("href").Split('=')[1].Split('&')[0];
|
||||||
|
release.Category = MapTrackerCatToNewznab(catStr);
|
||||||
|
|
||||||
|
release.Link = new Uri(SiteLink + qDownloadLink.Attr("href"));
|
||||||
|
release.Title = qDetailsLink.Attr("title").Trim();
|
||||||
|
release.Comments = new Uri(SiteLink + qDetailsLink.Attr("href"));
|
||||||
|
release.Guid = release.Link;
|
||||||
|
|
||||||
|
var sizeStr = qSize.Text();
|
||||||
|
release.Size = ReleaseInfo.GetBytes(sizeStr);
|
||||||
|
|
||||||
|
release.Seeders = ParseUtil.CoerceInt(qSeeders.Text());
|
||||||
|
release.Peers = ParseUtil.CoerceInt(qLeechers.Text()) + release.Seeders;
|
||||||
|
|
||||||
|
var dateStr = qTimeAgo.Text();
|
||||||
|
release.PublishDate = DateTimeUtil.FromTimeAgo(dateStr);
|
||||||
|
|
||||||
|
releases.Add(release);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
OnParseError(results.Content, ex);
|
||||||
|
}
|
||||||
|
|
||||||
|
return releases;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@@ -157,6 +157,7 @@
|
|||||||
<Compile Include="Controllers\DownloadController.cs" />
|
<Compile Include="Controllers\DownloadController.cs" />
|
||||||
<Compile Include="Engine.cs" />
|
<Compile Include="Engine.cs" />
|
||||||
<Compile Include="Indexers\BitCityReloaded.cs" />
|
<Compile Include="Indexers\BitCityReloaded.cs" />
|
||||||
|
<Compile Include="Indexers\FunFile.cs" />
|
||||||
<Compile Include="Indexers\GhostCity.cs" />
|
<Compile Include="Indexers\GhostCity.cs" />
|
||||||
<Compile Include="Indexers\Hebits.cs" />
|
<Compile Include="Indexers\Hebits.cs" />
|
||||||
<Compile Include="Indexers\MyAnonamouse.cs" />
|
<Compile Include="Indexers\MyAnonamouse.cs" />
|
||||||
@@ -423,6 +424,9 @@
|
|||||||
<Content Include="Content\login.html">
|
<Content Include="Content\login.html">
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
|
<Content Include="Content\logos\funfile.png">
|
||||||
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
|
</Content>
|
||||||
<Content Include="Content\logos\ghostcity.png">
|
<Content Include="Content\logos\ghostcity.png">
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
|
Reference in New Issue
Block a user