Error handling and status codes
When implementing an integration it is important to include error handling. This guide gives a few ideas.
Important HTTP response codes:
2xx (Success): Request was successful:
- 200 OK: General success.
- 201 Created: Resource created successfully.
4xx (Client Errors): Issue with the request:
- 400 Bad Request: Invalid input or malformed request: Check your parameters and function call.
- 401 Unauthorized: Authentication required or failed: Check your tenant and credentials.
- 403 Forbidden: Lacking permission to access: Check your permissions for the API user.
- 404 Not Found: Resource not found.
- 429 Too Many Requests: Rate-limiting hit: Reduce the frequency of API calls
5xx (Server Errors): Server-side issues:
- 500 Internal Server Error: General server issue.
- 502 Bad Gateway: API service is down or unresponsive.
- 503 Service Unavailable: Temporary downtime.
Implement Retry Logic
For temporary errors (i.e. 429 Too Many Requests, 503 Service Unavailable), implement retries with exponential backoff.
Example:
import time
for attempt in range(5): # Retry 5 times
try:
response = requests.get("<https://api.operations1.app/tenants/<tenant>/users/<userId>">, timeout=5)
response.raise_for_status()
break # Exit loop on success
except requests.exceptions.RequestException as e:
if attempt < 4: # Retry only on first 4 attempts
time.sleep(2 ** attempt) # Exponential backoff
else:
print(f"Failed after 5 attempts: {e}")
Log errors
Log all errors for debugging and monitoring purposes.
Example:
import logging
logging.basicConfig(level=logging.ERROR, filename="api_errors.log")
try:
response = requests.get("https://api.operations1.app/tenants/<tenant>/users/<userId>")
response.raise_for_status()
except requests.exceptions.RequestException as e:
logging.error(f"API error: {e}")
Test error scenarios
Simulate and test common API error scenarios:
- Invalid inputs
- Authentication failure
- Server unavailability
Updated about 2 months ago