mirror of
https://github.com/HIllya51/LunaTranslator.git
synced 2024-12-28 08:04:13 +08:00
fix pull/501
This commit is contained in:
parent
c182cbbf99
commit
52515993aa
@ -140,6 +140,8 @@ class CURLoption(c_int):
|
||||
CURLOPT_SHARE=CURLOPTTYPE_OBJECTPOINT+100
|
||||
CURLOPT_ACCEPT_ENCODING=CURLOPTTYPE_STRINGPOINT+102
|
||||
CURLOPT_CONNECT_ONLY=CURLOPTTYPE_LONG+141
|
||||
CURLOPT_TIMEOUT_MS=CURLOPTTYPE_LONG+155
|
||||
CURLOPT_CONNECTTIMEOUT_MS=CURLOPTTYPE_LONG+156
|
||||
class CURLINFO(c_int):
|
||||
CURLINFO_STRING =0x100000
|
||||
CURLINFO_LONG =0x200000
|
||||
@ -280,15 +282,13 @@ class AutoCURLHandle(CURL):
|
||||
|
||||
class CURLException(Exception):
|
||||
def __init__(self,code) -> None:
|
||||
self.errorcode=code
|
||||
self.errorcode=code.value
|
||||
if isinstance(code,CURLcode):
|
||||
error=curl_easy_strerror(code).decode('utf8')
|
||||
for _ in dir(CURLcode):
|
||||
if _.startswith('CURLE_') and code.value==getattr(CURLcode,_):
|
||||
error=str(code.value)+' '+_+' : '+error
|
||||
break
|
||||
elif isinstance(code,str):
|
||||
error=code
|
||||
else:
|
||||
error=''
|
||||
raise Exception("not a valid CURLException")
|
||||
super().__init__(error)
|
@ -58,7 +58,17 @@ class Session(Sessionbase):
|
||||
def _getmembyte(self,mem):
|
||||
return cast(mem.memory,POINTER(c_char))[:mem.size]
|
||||
def request_impl(self,
|
||||
method,scheme,server,port,param,url,headers,cookies,dataptr,datalen,proxy,stream,verify):
|
||||
method,scheme,server,port,param,url,headers,cookies,dataptr,datalen,proxy,stream,verify,timeout):
|
||||
try:
|
||||
_= self.request_impl_1(method,scheme,server,port,param,url,headers,cookies,dataptr,datalen,proxy,stream,verify,timeout)
|
||||
return _
|
||||
except CURLException as e:
|
||||
if e.errorcode==CURLcode.CURLE_OPERATION_TIMEDOUT:
|
||||
raise Timeout(e)
|
||||
else:
|
||||
raise e
|
||||
def request_impl_1(self,
|
||||
method,scheme,server,port,param,url,headers,cookies,dataptr,datalen,proxy,stream,verify,timeout):
|
||||
|
||||
if self._status==0:
|
||||
curl=self.curl
|
||||
@ -73,6 +83,9 @@ class Session(Sessionbase):
|
||||
if cookies:
|
||||
cookie=self._parsecookie(cookies)
|
||||
curl_easy_setopt(curl, CURLoption.CURLOPT_COOKIE, cookie.encode('utf8'));
|
||||
if timeout:
|
||||
curl_easy_setopt(curl, CURLoption.CURLOPT_TIMEOUT_MS, timeout);
|
||||
curl_easy_setopt(curl, CURLoption.CURLOPT_CONNECTTIMEOUT_MS, timeout);
|
||||
curl_easy_setopt(curl,CURLoption.CURLOPT_ACCEPT_ENCODING, headers['Accept-Encoding'].encode('utf8'))
|
||||
|
||||
curl_easy_setopt(curl,CURLoption.CURLOPT_CUSTOMREQUEST,method.upper().encode('utf8'))
|
||||
|
@ -3,6 +3,8 @@ from collections.abc import Callable, Mapping, MutableMapping
|
||||
from collections import OrderedDict
|
||||
from urllib.parse import urlencode,urlsplit
|
||||
from functools import partial,partialmethod
|
||||
class Timeout(Exception):
|
||||
pass
|
||||
class CaseInsensitiveDict(MutableMapping):
|
||||
|
||||
def __init__(self, data=None, **kwargs):
|
||||
@ -190,8 +192,6 @@ class Sessionbase:
|
||||
def request(self,
|
||||
method, url, params=None, data=None, headers=None,proxies=None, json=None,cookies=None, files=None,
|
||||
auth=None, timeout=None, allow_redirects=True, hooks=None, stream=None, verify=False, cert=None, ):
|
||||
# 0 means infinity, cite: WinHttpSetTimeouts
|
||||
timeout = timeout or 0
|
||||
_h=self.headers.copy()
|
||||
if headers:
|
||||
_h.update(headers)
|
||||
@ -204,7 +204,8 @@ class Sessionbase:
|
||||
scheme,server,port,param,url=self._parseurl(url,params)
|
||||
headers,dataptr,datalen=self._parsedata(data,headers,json)
|
||||
proxy= proxies.get(scheme,None) if proxies else None
|
||||
|
||||
if timeout:
|
||||
timeout = int(timeout * 1000) # convert to milliseconds
|
||||
_= self.request_impl(method,scheme,server,port,param,url,headers,cookies,dataptr,datalen,proxy,stream,verify,timeout)
|
||||
|
||||
if _.status_code==301:
|
||||
|
@ -60,10 +60,18 @@ class Session(Sessionbase):
|
||||
if verify==False:
|
||||
dwFlags=DWORD(SECURITY_FLAG_IGNORE_ALL_CERT_ERRORS)
|
||||
WinHttpSetOption(curl,WINHTTP_OPTION_SECURITY_FLAGS, pointer(dwFlags),sizeof(dwFlags))
|
||||
|
||||
# 30s is the default timeout on Windows
|
||||
def request_impl(self,
|
||||
method,scheme,server,port,param,url,headers,cookies,dataptr,datalen,proxy,stream,verify,timeout=30):
|
||||
method,scheme,server,port,param,url,headers,cookies,dataptr,datalen,proxy,stream,verify,timeout):
|
||||
try:
|
||||
_= self.request_impl_1(method,scheme,server,port,param,url,headers,cookies,dataptr,datalen,proxy,stream,verify,timeout)
|
||||
return _
|
||||
except WinhttpException as e:
|
||||
if e.errorcode==WinhttpException.ERROR_WINHTTP_TIMEOUT:
|
||||
raise Timeout(e)
|
||||
else:
|
||||
raise e
|
||||
def request_impl_1(self,
|
||||
method,scheme,server,port,param,url,headers,cookies,dataptr,datalen,proxy,stream,verify,timeout):
|
||||
headers=self._parseheader(headers,cookies)
|
||||
flag=WINHTTP_FLAG_SECURE if scheme=='https' else 0
|
||||
#print(server,port,param,dataptr)
|
||||
@ -73,18 +81,8 @@ class Session(Sessionbase):
|
||||
if hConnect==0:
|
||||
raise WinhttpException(GetLastError())
|
||||
hRequest=AutoWinHttpHandle(WinHttpOpenRequest( hConnect ,method,param,None,WINHTTP_NO_REFERER,WINHTTP_DEFAULT_ACCEPT_TYPES,flag) )
|
||||
timeout = timeout * 1000 # convert to milliseconds
|
||||
'''
|
||||
WINHTTPAPI BOOL WinHttpSetTimeouts(
|
||||
[in] HINTERNET hInternet,
|
||||
[in] int nResolveTimeout,
|
||||
[in] int nConnectTimeout,
|
||||
[in] int nSendTimeout,
|
||||
[in] int nReceiveTimeout
|
||||
);
|
||||
'''
|
||||
WinHttpSetTimeouts(hRequest, timeout, timeout, timeout, timeout)
|
||||
|
||||
if timeout:
|
||||
WinHttpSetTimeouts(hRequest, timeout, timeout, timeout, timeout)
|
||||
if hRequest==0:
|
||||
raise WinhttpException(GetLastError())
|
||||
self._set_verify(hRequest,verify)
|
||||
|
@ -1,4 +1,3 @@
|
||||
import winhttp
|
||||
from traceback import print_exc
|
||||
from translator.basetranslator import basetrans
|
||||
import requests
|
||||
@ -92,12 +91,9 @@ class TS(basetrans):
|
||||
stream=False,
|
||||
)
|
||||
output = self.session.post(self.api_url + "/chat/completions", timeout=self.timeout, json=data).json()
|
||||
except winhttp.WinhttpException as e:
|
||||
code = e.errorcode
|
||||
if code == winhttp.WinhttpException.ERROR_WINHTTP_TIMEOUT:
|
||||
raise ValueError(f"连接到Sakura API超时:{self.api_url},当前最大连接时间为: {self.timeout},请尝试修改参数。")
|
||||
else:
|
||||
raise ValueError(f"连接到Sakura API网络错误:{self.api_url},错误代码: {code}")
|
||||
except requests.Timeout as e:
|
||||
raise ValueError(f"连接到Sakura API超时:{self.api_url},当前最大连接时间为: {self.timeout},请尝试修改参数。")
|
||||
|
||||
except Exception as e:
|
||||
print(e)
|
||||
raise ValueError(f"无法连接到Sakura API:{self.api_url},请检查你的API链接是否正确填写,以及API后端是否成功启动。")
|
||||
|
Loading…
x
Reference in New Issue
Block a user