TROUBLESHOOTING.md¶
General¶
- 401 Invalid API key: set API_KEYand passX-API-Keyheader.
- 413 File too large: adjust MAX_FILE_SIZE_MB.
- 415 Unsupported file type: only PDF and TXT allowed.
- Prefer HTTPS for PUBLIC_API_URLin production. The cloud backend fetches PDFs from your server; use TLS.
Phaxio Backend¶
- "phaxio not configured": ensure FAX_BACKEND=phaxio,PHAXIO_API_KEY,PHAXIO_API_SECRET.
- No status updates: verify your callback URL (PHAXIO_CALLBACK_URLorPHAXIO_STATUS_CALLBACK_URL) and that your server is publicly reachable.
- 403 on /fax/{id}/pdf: invalid token or wrongPUBLIC_API_URL.
- Phaxio API error: confirm credentials and sufficient account balance.
Sinch Fax API v3 Backend¶
- "sinch not configured": ensure FAX_BACKEND=sinch,SINCH_PROJECT_ID,SINCH_API_KEY,SINCH_API_SECRET(or setPHAXIO_API_KEY/SECRETwhich are used as fallback values).
- Region/base URL: if requests fail, try SINCH_BASE_URL(e.g.,https://us.fax.api.sinch.com/v3).
- Webhooks: current build does not expose a Sinch webhook endpoint; status reflects the immediate response from Sinch. Poll your job via GET /fax/{id}if needed.
SIP/Asterisk Backend¶
- AMI connection failed:
- Asterisk container running and reachable on 5038.
- ASTERISK_AMI_*match- manager.conftemplate.
- API logs show reconnect with exponential backoff.
- T.38 negotiation failed:
- Provider supports UDPTL.
- Firewall forwards UDP 4000-4999.
- pjsip.confhas- t38_udptl=yesand redundancy.
- No fax send:
- Check Asterisk logs for SendFAXandFaxResultevents.
- Validate destination formatting.
Conversion¶
- Ghostscript missing: API warns and stubs TIFF conversion; install ghostscriptfor production.
- Garbled pages: use clean PDF fonts or provide PDF instead of TXT.
MCP (AI Assistant Integration)¶
Transport Selection Issues¶
If you're unsure which MCP transport to use:
| Transport | File | Port | Auth | Use Case | 
|---|---|---|---|---|
| stdio | node_mcp/src/servers/stdio.js (recommended) or api/mcp_server.js (legacy) | N/A | API key | Desktop AI | 
| HTTP | api/mcp_http_server.js or node_mcp/src/servers/http.js | 3001 | API key | Web apps, cloud AI | 
| SSE+OAuth | api/mcp_sse_server.js or node_mcp/src/servers/sse.js | 3002 | JWT/Bearer | Enterprise, HIPAA | 
Common MCP Problems¶
MCP Usage Tips¶
- Ensure the main Faxbot API is reachable (FAX_API_URL) and yourAPI_KEYis set.
- For local files, use tooling that can access your filesystem as needed.
Connection & Authentication¶
- MCP server not found: Ensure you’re starting from the correct path:
- Legacy servers: api/scripts/start-mcp*.sh
- New servers (recommended): node_mcp/scripts/start-*.sh
- Python servers: python_mcp/(stdio_server.py,http_server.py,server.py)
Environment¶
- FAX_API_URL,- API_KEY: Required for authentication.
- Authentication failures:
- stdio: Check API_KEYenvironment variable matches Faxbot API setting
- HTTP: Verify X-API-Keyheader is being passed correctly
- SSE+OAuth: Confirm JWT token has correct iss,aud, and hasn't expired
- Connection refused:
- Ensure main Faxbot API is running on FAX_API_URL(default: http://localhost:8080)
- For HTTP/SSE transports, check port availability (3001/3002)
- "No tools available": MCP server started successfully but tools not loading - check MCP server logs for initialization errors
Filesystem Access Required¶
- Claude can't read files: Install and configure filesystem MCP server alongside Faxbot MCP
- Permission denied: Check filesystem MCP server has access to directory containing your PDFs
- Wrong file path: Use absolute paths or ensure filesystem MCP server is configured for correct directories
File Types and Paths¶
- Only PDF and TXT are accepted. Convert images (PNG/JPG) to PDF first.
- macOS: sips -s format pdf "in.png" --out "out.pdf"
- Linux: img2pdf in.png -o out.pdformagick convert in.png out.pdf
- Filenames with spaces: quote the full path. Example (curl): -F "file=@'./My File.pdf'"
- macOS screenshot names sometimes include a “narrow no‑break space” (U+202F) that looks like a regular space and breaks shell quoting. If a quoted path still fails, try renaming with a wildcard: cp Screenshot*.pdf doc.pdfand use the new name.
Reverse Proxy Examples (Rate Limiting)¶
Nginx (basic example):
server {
  listen 443 ssl;
  server_name your-domain.com;
  # ... ssl_certificate / ssl_certificate_key ...
  # Simple rate limit per IP
  limit_req_zone $binary_remote_addr zone=faxbot:10m rate=5r/s;
  location / {
    limit_req zone=faxbot burst=10 nodelay;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header Host $host;
    proxy_pass http://127.0.0.1:8080;
  }
}
Caddy (basic example):
your-domain.com {
  reverse_proxy 127.0.0.1:8080
  # Rate limiting plugins vary; consider layer-4 or WAF if needed
}