mirror of
https://github.com/Jackett/Jackett.git
synced 2025-09-17 17:34:09 +02:00
Make lib curl more stable
This commit is contained in:
@@ -12,8 +12,16 @@ using System.Net;
|
|||||||
|
|
||||||
namespace Jackett
|
namespace Jackett
|
||||||
{
|
{
|
||||||
public static class CurlHelper
|
public class CurlHelper
|
||||||
{
|
{
|
||||||
|
private static readonly object instance = new object();
|
||||||
|
|
||||||
|
static CurlHelper()
|
||||||
|
{
|
||||||
|
Engine.Logger.Debug("LibCurl init" + Curl.GlobalInit(CurlInitFlag.All).ToString());
|
||||||
|
Engine.Logger.Debug("LibCurl version " + Curl.Version);
|
||||||
|
}
|
||||||
|
|
||||||
public class CurlRequest
|
public class CurlRequest
|
||||||
{
|
{
|
||||||
|
|
||||||
@@ -39,17 +47,11 @@ namespace Jackett
|
|||||||
public class CurlResponse
|
public class CurlResponse
|
||||||
{
|
{
|
||||||
public Dictionary<string, string> Headers { get; private set; }
|
public Dictionary<string, string> Headers { get; private set; }
|
||||||
|
|
||||||
public List<string[]> HeaderList { get; private set; }
|
public List<string[]> HeaderList { get; private set; }
|
||||||
|
|
||||||
public byte[] Content { get; private set; }
|
public byte[] Content { get; private set; }
|
||||||
|
|
||||||
public HttpStatusCode Status { get; private set;}
|
public HttpStatusCode Status { get; private set;}
|
||||||
|
|
||||||
public Dictionary<string, string> Cookies { get; private set; }
|
public Dictionary<string, string> Cookies { get; private set; }
|
||||||
|
|
||||||
public List<string> CookiesFlat { get { return Cookies.Select(c => c.Key + "=" + c.Value).ToList(); } }
|
public List<string> CookiesFlat { get { return Cookies.Select(c => c.Key + "=" + c.Value).ToList(); } }
|
||||||
|
|
||||||
public string CookieHeader { get { return string.Join("; ", CookiesFlat); } }
|
public string CookieHeader { get { return string.Join("; ", CookiesFlat); } }
|
||||||
|
|
||||||
public CurlResponse(List<string[]> headers, byte[] content, HttpStatusCode s)
|
public CurlResponse(List<string[]> headers, byte[] content, HttpStatusCode s)
|
||||||
@@ -94,8 +96,7 @@ namespace Jackett
|
|||||||
{
|
{
|
||||||
var curlRequest = new CurlRequest(HttpMethod.Get, url, cookies, referer);
|
var curlRequest = new CurlRequest(HttpMethod.Get, url, cookies, referer);
|
||||||
var result = await PerformCurlAsync(curlRequest);
|
var result = await PerformCurlAsync(curlRequest);
|
||||||
var checkedResult = await FollowRedirect(url, result);
|
return result;
|
||||||
return checkedResult;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static async Task<CurlResponse> PostAsync(string url, Dictionary<string, string> formData, string cookies = null, string referer = null)
|
public static async Task<CurlResponse> PostAsync(string url, Dictionary<string, string> formData, string cookies = null, string referer = null)
|
||||||
@@ -103,8 +104,7 @@ namespace Jackett
|
|||||||
var curlRequest = new CurlRequest(HttpMethod.Post, url, cookies, referer);
|
var curlRequest = new CurlRequest(HttpMethod.Post, url, cookies, referer);
|
||||||
curlRequest.PostData = formData;
|
curlRequest.PostData = formData;
|
||||||
var result = await PerformCurlAsync(curlRequest);
|
var result = await PerformCurlAsync(curlRequest);
|
||||||
var checkedResult = await FollowRedirect(url, result);
|
return result;
|
||||||
return checkedResult;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static async Task<CurlResponse> FollowRedirect(string url, CurlResponse response)
|
private static async Task<CurlResponse> FollowRedirect(string url, CurlResponse response)
|
||||||
@@ -139,8 +139,8 @@ namespace Jackett
|
|||||||
|
|
||||||
public static CurlResponse PerformCurl(CurlRequest curlRequest)
|
public static CurlResponse PerformCurl(CurlRequest curlRequest)
|
||||||
{
|
{
|
||||||
Curl.GlobalInit(CurlInitFlag.All);
|
lock (instance)
|
||||||
|
{
|
||||||
var headerBuffers = new List<byte[]>();
|
var headerBuffers = new List<byte[]>();
|
||||||
var contentBuffers = new List<byte[]>();
|
var contentBuffers = new List<byte[]>();
|
||||||
|
|
||||||
@@ -149,6 +149,8 @@ namespace Jackett
|
|||||||
easy.Url = curlRequest.Url;
|
easy.Url = curlRequest.Url;
|
||||||
easy.BufferSize = 64 * 1024;
|
easy.BufferSize = 64 * 1024;
|
||||||
easy.UserAgent = BrowserUtil.ChromeUserAgent;
|
easy.UserAgent = BrowserUtil.ChromeUserAgent;
|
||||||
|
easy.FollowLocation = false;
|
||||||
|
easy.ConnectTimeout = 20;
|
||||||
easy.WriteFunction = (byte[] buf, int size, int nmemb, object data) =>
|
easy.WriteFunction = (byte[] buf, int size, int nmemb, object data) =>
|
||||||
{
|
{
|
||||||
contentBuffers.Add(buf);
|
contentBuffers.Add(buf);
|
||||||
@@ -210,7 +212,7 @@ namespace Jackett
|
|||||||
curlResponse.AddCookiesFromHeaders(headers);
|
curlResponse.AddCookiesFromHeaders(headers);
|
||||||
|
|
||||||
return curlResponse;
|
return curlResponse;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static byte[] Combine(params byte[][] arrays)
|
public static byte[] Combine(params byte[][] arrays)
|
||||||
|
@@ -105,7 +105,6 @@ namespace Jackett.Indexers
|
|||||||
dom["#loginform > table"].Remove();
|
dom["#loginform > table"].Remove();
|
||||||
var errorMessage = dom["#loginform"].Text().Trim().Replace("\n\t", " ");
|
var errorMessage = dom["#loginform"].Text().Trim().Replace("\n\t", " ");
|
||||||
throw new ExceptionWithConfigData(errorMessage, (ConfigurationData)config);
|
throw new ExceptionWithConfigData(errorMessage, (ConfigurationData)config);
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@@ -24,7 +24,6 @@ namespace Jackett.Indexers
|
|||||||
|
|
||||||
protected Logger logger;
|
protected Logger logger;
|
||||||
protected IIndexerManagerService indexerService;
|
protected IIndexerManagerService indexerService;
|
||||||
// protected IWebClient webClient;
|
|
||||||
|
|
||||||
protected static List<CachedResult> cache = new List<CachedResult>();
|
protected static List<CachedResult> cache = new List<CachedResult>();
|
||||||
protected static readonly TimeSpan cacheTime = new TimeSpan(0, 9, 0);
|
protected static readonly TimeSpan cacheTime = new TimeSpan(0, 9, 0);
|
||||||
@@ -42,7 +41,6 @@ namespace Jackett.Indexers
|
|||||||
TorznabCaps = caps;
|
TorznabCaps = caps;
|
||||||
this.logger = logger;
|
this.logger = logger;
|
||||||
indexerService = manager;
|
indexerService = manager;
|
||||||
// webClient = wc;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void SaveConfig(JToken config)
|
protected void SaveConfig(JToken config)
|
||||||
|
@@ -55,6 +55,7 @@ namespace Jackett.Utils.Clients
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
logger.Debug(string.Format("UnixLibCurlWebClient: Returning", result.Status));
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -63,12 +64,14 @@ namespace Jackett.Utils.Clients
|
|||||||
logger.Debug(string.Format("UnixLibCurlWebClient:GetString(Url:{0})", request.Url));
|
logger.Debug(string.Format("UnixLibCurlWebClient:GetString(Url:{0})", request.Url));
|
||||||
var result = await GetBytes(request);
|
var result = await GetBytes(request);
|
||||||
|
|
||||||
return new WebClientStringResult()
|
var sresult = new WebClientStringResult()
|
||||||
{
|
{
|
||||||
Content = Encoding.UTF8.GetString(result.Content),
|
Content = Encoding.UTF8.GetString(result.Content),
|
||||||
Cookies = result.Cookies,
|
Cookies = result.Cookies,
|
||||||
Status = result.Status
|
Status = result.Status
|
||||||
};
|
};
|
||||||
|
|
||||||
|
return sresult;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user