mirror of
https://github.com/xtekky/gpt4free.git
synced 2024-11-17 09:25:50 +00:00
9239cadd8b
Update Providers with WebDriver Add WebDriverSession helper Use native streaming in curl_cffi
53 lines
1.7 KiB
Python
53 lines
1.7 KiB
Python
from __future__ import annotations
|
|
|
|
import json
|
|
from contextlib import asynccontextmanager
|
|
from functools import partialmethod
|
|
from typing import AsyncGenerator
|
|
|
|
from curl_cffi.requests import AsyncSession, Response
|
|
|
|
class StreamResponse:
|
|
def __init__(self, inner: Response) -> None:
|
|
self.inner: Response = inner
|
|
self.request = inner.request
|
|
self.status_code: int = inner.status_code
|
|
self.reason: str = inner.reason
|
|
self.ok: bool = inner.ok
|
|
self.headers = inner.headers
|
|
self.cookies = inner.cookies
|
|
|
|
async def text(self) -> str:
|
|
return await self.inner.atext()
|
|
|
|
def raise_for_status(self) -> None:
|
|
self.inner.raise_for_status()
|
|
|
|
async def json(self, **kwargs) -> dict:
|
|
return json.loads(await self.inner.acontent(), **kwargs)
|
|
|
|
async def iter_lines(self) -> AsyncGenerator[bytes, None]:
|
|
async for line in self.inner.aiter_lines():
|
|
yield line
|
|
|
|
async def iter_content(self) -> AsyncGenerator[bytes, None]:
|
|
async for chunk in self.inner.aiter_content():
|
|
yield chunk
|
|
|
|
class StreamSession(AsyncSession):
|
|
@asynccontextmanager
|
|
async def request(
|
|
self, method: str, url: str, **kwargs
|
|
) -> AsyncGenerator[StreamResponse]:
|
|
response = await super().request(method, url, stream=True, **kwargs)
|
|
try:
|
|
yield StreamResponse(response)
|
|
finally:
|
|
await response.aclose()
|
|
|
|
head = partialmethod(request, "HEAD")
|
|
get = partialmethod(request, "GET")
|
|
post = partialmethod(request, "POST")
|
|
put = partialmethod(request, "PUT")
|
|
patch = partialmethod(request, "PATCH")
|
|
delete = partialmethod(request, "DELETE") |