kopia lustrzana https://github.com/gd3kr/BlenderGPT
51 wiersze
1.5 KiB
Python
51 wiersze
1.5 KiB
Python
import time
|
|
|
|
from openai import util
|
|
from openai.api_resources.abstract.engine_api_resource import EngineAPIResource
|
|
from openai.error import TryAgain
|
|
|
|
|
|
class ChatCompletion(EngineAPIResource):
|
|
engine_required = False
|
|
OBJECT_NAME = "chat.completions"
|
|
|
|
@classmethod
|
|
def create(cls, *args, **kwargs):
|
|
"""
|
|
Creates a new chat completion for the provided messages and parameters.
|
|
|
|
See https://platform.openai.com/docs/api-reference/chat-completions/create
|
|
for a list of valid parameters.
|
|
"""
|
|
start = time.time()
|
|
timeout = kwargs.pop("timeout", None)
|
|
|
|
while True:
|
|
try:
|
|
return super().create(*args, **kwargs)
|
|
except TryAgain as e:
|
|
if timeout is not None and time.time() > start + timeout:
|
|
raise
|
|
|
|
util.log_info("Waiting for model to warm up", error=e)
|
|
|
|
@classmethod
|
|
async def acreate(cls, *args, **kwargs):
|
|
"""
|
|
Creates a new chat completion for the provided messages and parameters.
|
|
|
|
See https://platform.openai.com/docs/api-reference/chat-completions/create
|
|
for a list of valid parameters.
|
|
"""
|
|
start = time.time()
|
|
timeout = kwargs.pop("timeout", None)
|
|
|
|
while True:
|
|
try:
|
|
return await super().acreate(*args, **kwargs)
|
|
except TryAgain as e:
|
|
if timeout is not None and time.time() > start + timeout:
|
|
raise
|
|
|
|
util.log_info("Waiting for model to warm up", error=e)
|