From anthropic-pack
Diagnoses and fixes Anthropic Claude API errors by HTTP status code, covering invalid requests, authentication, permissions, rate limits, and overloads.
npx claudepluginhub jeremylongshore/claude-code-plugins-plus-skills --plugin anthropic-packThis skill is limited to using the following tools:
Quick reference for all Claude API error types with exact HTTP codes, error bodies, and fixes. The API returns errors as JSON: `{"type": "error", "error": {"type": "...", "message": "..."}}`.
Identifies common Anthropic Claude API anti-patterns in Python and TypeScript code. Use for reviewing integrations, onboarding developers, or debugging subtle issues.
Integrates Anthropic Claude Messages API with @anthropic-ai/sdk for streaming, prompt caching, tool use, vision, and rate limit handling in Node.js and Cloudflare Workers.
Diagnoses and fixes Groq API errors like 401 authentication and 429 rate limits using curl diagnostics, rate limit headers, and Bash/TypeScript solutions.
Share bugs, ideas, or general feedback.
Quick reference for all Claude API error types with exact HTTP codes, error bodies, and fixes. The API returns errors as JSON: {"type": "error", "error": {"type": "...", "message": "..."}}.
invalid_request_error{"type": "error", "error": {"type": "invalid_request_error", "message": "messages: roles must alternate between \"user\" and \"assistant\""}}
Common causes and fixes:
| Message Pattern | Cause | Fix |
|---|---|---|
messages: roles must alternate | Consecutive same-role messages | Merge adjacent user/assistant messages |
max_tokens: must be >= 1 | Missing or zero max_tokens | Always set max_tokens (required param) |
model: invalid model id | Typo in model name | Use exact ID: claude-sonnet-4-20250514 |
messages.0.content: empty | Empty message content | Ensure content is non-empty string or array |
tool_result: tool_use_id not found | Mismatched tool ID | Copy id from the tool_use block exactly |
authentication_error# Verify your key is set and valid
echo $ANTHROPIC_API_KEY | head -c 15 # Should show: sk-ant-api03-...
# Test directly with curl
curl -s https://api.anthropic.com/v1/messages \
-H "x-api-key: $ANTHROPIC_API_KEY" \
-H "anthropic-version: 2023-06-01" \
-H "content-type: application/json" \
-d '{"model":"claude-sonnet-4-20250514","max_tokens":16,"messages":[{"role":"user","content":"hi"}]}'
permission_errorAPI key lacks required permissions. Generate a new key at console.anthropic.com.
not_found_errorInvalid endpoint or model. Check you're using https://api.anthropic.com/v1/messages and a valid model ID.
rate_limit_error{"type": "error", "error": {"type": "rate_limit_error", "message": "Number of request tokens has exceeded your per-minute rate limit"}}
Check headers for details:
retry-after — seconds to waitanthropic-ratelimit-requests-limit — RPM capanthropic-ratelimit-tokens-limit — TPM capanthropic-ratelimit-tokens-remaining — tokens left this windowFix: The SDK handles 429 with automatic retry (configurable via maxRetries). For manual handling, see anth-rate-limits.
overloaded_errorAPI is temporarily overloaded. Retry after 30-60 seconds. Not counted against rate limits.
api_errorInternal server error. Retry with exponential backoff. If persistent, check status.anthropic.com.
# 1. Check API status
curl -s https://status.anthropic.com/api/v2/status.json | python3 -c "import sys,json; d=json.load(sys.stdin); print(d['status']['description'])"
# 2. Verify key format
echo $ANTHROPIC_API_KEY | grep -qE '^sk-ant-api03-' && echo "Key format OK" || echo "Key format WRONG"
# 3. Test minimal request
curl -s -w "\nHTTP %{http_code}" https://api.anthropic.com/v1/messages \
-H "x-api-key: $ANTHROPIC_API_KEY" \
-H "anthropic-version: 2023-06-01" \
-H "content-type: application/json" \
-d '{"model":"claude-sonnet-4-20250514","max_tokens":8,"messages":[{"role":"user","content":"1+1="}]}'
import anthropic
try:
message = client.messages.create(...)
except anthropic.AuthenticationError as e:
print(f"Auth failed: {e.status_code}")
except anthropic.RateLimitError as e:
print(f"Rate limited. Retry after: {e.response.headers.get('retry-after')}s")
except anthropic.BadRequestError as e:
print(f"Invalid request: {e.message}")
except anthropic.APIStatusError as e:
print(f"API error {e.status_code}: {e.message}")
except anthropic.APIConnectionError:
print("Network error — check connectivity")
For comprehensive debugging, see anth-debug-bundle.