|
|
@ -63,7 +63,7 @@ class OpenaiChat(AsyncGeneratorProvider):
|
|
|
|
last_message = new_message
|
|
|
|
last_message = new_message
|
|
|
|
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
@classmethod
|
|
|
|
def fetch_access_token(cls) -> str:
|
|
|
|
def browse_access_token(cls) -> str:
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
from selenium.webdriver.common.by import By
|
|
|
|
from selenium.webdriver.common.by import By
|
|
|
|
from selenium.webdriver.support.ui import WebDriverWait
|
|
|
|
from selenium.webdriver.support.ui import WebDriverWait
|
|
|
@ -85,19 +85,25 @@ class OpenaiChat(AsyncGeneratorProvider):
|
|
|
|
finally:
|
|
|
|
finally:
|
|
|
|
driver.quit()
|
|
|
|
driver.quit()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
|
|
|
|
async def fetch_access_token(cls, cookies: dict, proxies: dict = None) -> str:
|
|
|
|
|
|
|
|
async with StreamSession(proxies=proxies, cookies=cookies, impersonate="chrome107") as session:
|
|
|
|
|
|
|
|
async with session.get(f"{cls.url}/api/auth/session") as response:
|
|
|
|
|
|
|
|
response.raise_for_status()
|
|
|
|
|
|
|
|
auth = await response.json()
|
|
|
|
|
|
|
|
if "accessToken" in auth:
|
|
|
|
|
|
|
|
return auth["accessToken"]
|
|
|
|
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
@classmethod
|
|
|
|
async def get_access_token(cls, cookies: dict = None, proxies: dict = None) -> str:
|
|
|
|
async def get_access_token(cls, cookies: dict = None, proxies: dict = None) -> str:
|
|
|
|
if not cls._access_token:
|
|
|
|
if not cls._access_token:
|
|
|
|
cookies = cookies if cookies else get_cookies("chat.openai.com")
|
|
|
|
cookies = cookies if cookies else get_cookies("chat.openai.com")
|
|
|
|
async with StreamSession(proxies=proxies, cookies=cookies, impersonate="chrome107") as session:
|
|
|
|
if cookies:
|
|
|
|
async with session.get(f"{cls.url}/api/auth/session") as response:
|
|
|
|
cls._access_token = await cls.fetch_access_token(cookies, proxies)
|
|
|
|
response.raise_for_status()
|
|
|
|
if not cls._access_token:
|
|
|
|
auth = await response.json()
|
|
|
|
cls._access_token = cls.browse_access_token()
|
|
|
|
if "accessToken" in auth:
|
|
|
|
if not cls._access_token:
|
|
|
|
cls._access_token = auth["accessToken"]
|
|
|
|
raise RuntimeError("Read access token failed")
|
|
|
|
cls._access_token = cls.fetch_access_token()
|
|
|
|
|
|
|
|
if not cls._access_token:
|
|
|
|
|
|
|
|
raise RuntimeError("Missing access token")
|
|
|
|
|
|
|
|
return cls._access_token
|
|
|
|
return cls._access_token
|
|
|
|
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
@classmethod
|
|
|
|