in aidial_interceptors_sdk/utils/_exceptions.py [0:0]
def to_dial_exception(exc: Exception) -> DialException:
if isinstance(exc, APIStatusError):
# Non-streaming errors reported by `openai` library via this exception
r = exc.response
headers = r.headers
# The original content length may have changed
# due to the response modification in the adapter.
if "Content-Length" in headers:
del headers["Content-Length"]
# httpx library (used by openai) automatically sets
# "Accept-Encoding:gzip,deflate" header in requests to the upstream.
# Therefore, we may receive from the upstream gzip-encoded
# response along with "Content-Encoding:gzip" header.
# We either need to encode the response, or
# remove the "Content-Encoding" header.
if "Content-Encoding" in headers:
del headers["Content-Encoding"]
plain_headers = {k.decode(): v.decode() for k, v in headers.raw}
try:
content = r.json()
except Exception:
content = r.text
return _parse_dial_exception(
status_code=r.status_code,
headers=plain_headers,
content=content,
)
if isinstance(exc, APIError):
# Streaming errors reported by `openai` library via this exception
status_code: int = 500
if exc.code:
try:
status_code = int(exc.code)
except Exception:
pass
return _parse_dial_exception(
status_code=status_code,
headers={},
content={"error": exc.body or {}},
)
if isinstance(exc, APITimeoutError):
return DialException("Request timed out", 504, "timeout")
if isinstance(exc, APIConnectionError):
return DialException(
"Error communicating with OpenAI", 502, "connection"
)
if isinstance(exc, DialException):
return exc
return DialException(
status_code=500,
type="internal_server_error",
message=str(exc),
)