Error contract reference for user-facing CLI and exported helper behavior.
0: successful execution1: usage error, invalid arguments, sync/persistence failure, or command failure
- Human-readable command output is written to
stdout. - Argument/usage and failure diagnostics are written to
stderr. - On invalid command/arguments, usage text is printed with a non-zero exit code.
Examples:
- unknown subcommand:
Unknown command: <name>plus usage switchwith missing index:Missing index. Usage: codex auth switch <index>switchwith invalid index:Invalid index: <value>
The following commands support --json and produce pretty-printed JSON objects:
codex auth forecast --jsoncodex auth report --jsoncodex auth fix --jsoncodex auth doctor --jsoncodex auth verify-flagged --json
Compatibility guarantees:
- Output is valid JSON.
commandfield identifies the command family.- Documented top-level sections remain stable unless a migration note is provided.
- Upstream entitlement-like 404 payloads are normalized to
403withentitlement_errorpayloads. - Entitlement errors are not treated as rate limits.
- Upstream usage-limit indicators normalize to rate-limit semantics.
handleErrorResponsemay return parsedrateLimit.retryAfterMsmetadata.
- Error responses are normalized to JSON error payloads with a stable
error.messagefield. - Diagnostics may include request/correlation IDs when available.
The default-on localhost Responses proxy returns JSON error payloads with a stable error.code field.
| Code | HTTP status | Meaning |
|---|---|---|
runtime_rotation_proxy_not_found |
404 |
Request path or method is outside the supported Responses/model discovery surface |
runtime_rotation_proxy_unauthorized |
401 |
Local request did not include the per-process proxy client key |
runtime_rotation_proxy_payload_too_large |
413 |
Request body exceeded the proxy safety cap |
codex_runtime_rotation_pool_exhausted |
429 or 503 |
No managed account can currently service the runtime request |
codex_runtime_rotation_proxy_error |
500 |
Proxy failed before forwarding the request |
Pool exhaustion includes a reason, retry_after_ms, and a hint to run codex auth rotation status.
For selected exported helper APIs, options-object forms were added without removing positional signatures.
Supported dual-call forms include:
selectHybridAccount(...)andselectHybridAccount({ ... })exponentialBackoff(...)andexponentialBackoff({ ... })getTopCandidates(...)andgetTopCandidates({ ... })createCodexHeaders(...)andcreateCodexHeaders({ ... })getRateLimitBackoffWithReason(...)andgetRateLimitBackoffWithReason({ ... })transformRequestBody(...)andtransformRequestBody({ ... })