fix: sanitize oversized image payloads
This commit is contained in:
@@ -31,6 +31,7 @@ import {
|
||||
isContextOverflowError,
|
||||
isFailoverAssistantError,
|
||||
isFailoverErrorMessage,
|
||||
parseImageDimensionError,
|
||||
isRateLimitAssistantError,
|
||||
isTimeoutErrorMessage,
|
||||
pickFallbackThinkingLevel,
|
||||
@@ -357,6 +358,26 @@ export async function runEmbeddedPiAgent(
|
||||
const failoverFailure = isFailoverAssistantError(lastAssistant);
|
||||
const assistantFailoverReason = classifyFailoverReason(lastAssistant?.errorMessage ?? "");
|
||||
const cloudCodeAssistFormatError = attempt.cloudCodeAssistFormatError;
|
||||
const imageDimensionError = parseImageDimensionError(lastAssistant?.errorMessage ?? "");
|
||||
|
||||
if (imageDimensionError && lastProfileId) {
|
||||
const details = [
|
||||
imageDimensionError.messageIndex !== undefined
|
||||
? `message=${imageDimensionError.messageIndex}`
|
||||
: null,
|
||||
imageDimensionError.contentIndex !== undefined
|
||||
? `content=${imageDimensionError.contentIndex}`
|
||||
: null,
|
||||
imageDimensionError.maxDimensionPx !== undefined
|
||||
? `limit=${imageDimensionError.maxDimensionPx}px`
|
||||
: null,
|
||||
]
|
||||
.filter(Boolean)
|
||||
.join(" ");
|
||||
log.warn(
|
||||
`Profile ${lastProfileId} rejected image payload${details ? ` (${details})` : ""}.`,
|
||||
);
|
||||
}
|
||||
|
||||
// Treat timeout as potential rate limit (Antigravity hangs on rate limit)
|
||||
const shouldRotate = (!aborted && failoverFailure) || timedOut;
|
||||
|
||||
Reference in New Issue
Block a user