mirror of
https://github.com/zhayujie/chatgpt-on-wechat.git
synced 2026-06-02 00:57:41 +08:00
63 lines
2.9 KiB
Python
63 lines
2.9 KiB
Python
import time
|
|
|
|
from common.log import logger
|
|
from common.token_bucket import TokenBucket
|
|
from config import conf
|
|
from models.openai.openai_compat import RateLimitError, wrap_http_error
|
|
from models.openai.openai_http_client import OpenAIHTTPClient, OpenAIHTTPError
|
|
|
|
|
|
# OpenAI image generation API wrapper
|
|
class OpenAIImage(object):
|
|
def __init__(self):
|
|
# Lazy default client; subclasses (ChatGPTBot/OpenAIBot) typically
|
|
# construct their own _http_client and override _get_image_client().
|
|
self._image_api_key = conf().get("open_ai_api_key")
|
|
self._image_api_base = conf().get("open_ai_api_base") or None
|
|
self._image_proxy = conf().get("proxy") or None
|
|
self._image_client = OpenAIHTTPClient(
|
|
api_key=self._image_api_key,
|
|
api_base=self._image_api_base,
|
|
proxy=self._image_proxy,
|
|
)
|
|
if conf().get("rate_limit_dalle"):
|
|
self.tb4dalle = TokenBucket(conf().get("rate_limit_dalle", 50))
|
|
|
|
def create_img(self, query, retry_count=0, api_key=None, api_base=None):
|
|
try:
|
|
if conf().get("rate_limit_dalle") and not self.tb4dalle.get_token():
|
|
return False, "请求太快了,请休息一下再问我吧"
|
|
logger.info("[OPEN_AI] image_query={}".format(query))
|
|
response = self._image_client.images_generate(
|
|
api_key=api_key or None,
|
|
api_base=api_base or None,
|
|
prompt=query, # image description
|
|
n=1,
|
|
model=conf().get("text_to_image") or "dall-e-2",
|
|
# size=conf().get("image_create_size", "256x256"),
|
|
)
|
|
image_url = response["data"][0]["url"]
|
|
logger.info("[OPEN_AI] image_url={}".format(image_url))
|
|
return True, image_url
|
|
except OpenAIHTTPError as http_err:
|
|
mapped = wrap_http_error(http_err)
|
|
if isinstance(mapped, RateLimitError):
|
|
logger.warn(mapped)
|
|
if retry_count < 1:
|
|
time.sleep(5)
|
|
logger.warn("[OPEN_AI] ImgCreate RateLimit exceed, 第{}次重试".format(retry_count + 1))
|
|
return self.create_img(query, retry_count + 1)
|
|
return False, "画图出现问题,请休息一下再问我吧"
|
|
logger.exception(mapped)
|
|
return False, "画图出现问题,请休息一下再问我吧"
|
|
except RateLimitError as e:
|
|
logger.warn(e)
|
|
if retry_count < 1:
|
|
time.sleep(5)
|
|
logger.warn("[OPEN_AI] ImgCreate RateLimit exceed, 第{}次重试".format(retry_count + 1))
|
|
return self.create_img(query, retry_count + 1)
|
|
return False, "画图出现问题,请休息一下再问我吧"
|
|
except Exception as e:
|
|
logger.exception(e)
|
|
return False, "画图出现问题,请休息一下再问我吧"
|