API Idempotency
Learn how to use idempotency keys to safely retry API requests without causing duplicate operations
Idempotency is a crucial feature for building reliable integrations with Novu's API. It allows you to safely retry requests without worrying about duplicate operations, which is especially important for critical actions like triggering workflows.
An idempotent request is one that can be made multiple times with the same effect as making it once. This is achieved by including a unique idempotency key with your request.
Idempotency feature is currently not enabled for all organizations. Please contact us at [email protected] to enable it for your organization.
How It Works
When you send a request with an idempotency key:
- Novu checks if a request with the same key has been processed before
- If it's a new key, the request is processed normally and the response is cached
- If the key was seen before, Novu returns the cached response without reprocessing the request
This mechanism protects against network issues, timeouts, and other scenarios where a request might be retried.
Using Idempotency Keys
To make an idempotent request, include the Idempotency-Key header with a unique identifier:
Key Requirements
- Maximum length: 255 characters
- Uniqueness: Keys should be unique per organization
- Format: Any string value (UUIDs are recommended)
We recommend using UUIDs or other unique identifiers that include context about the operation, such as order-confirmation-{orderId}-{timestamp}.
Supported Methods
Idempotency is supported for the following HTTP methods:
| Method | Supported |
|---|---|
| POST | ✅ Yes |
| PATCH | ✅ Yes |
| GET | ❌ No |
| PUT | ❌ No |
| DELETE | ❌ No |
GET, PUT, and DELETE methods are inherently idempotent by design and don't require idempotency keys.
Authentication Requirements
Idempotency is only available when authenticating with an API Key:
Requests using other authentication methods will be processed normally without idempotency support.
Cache Duration
| Scenario | Cache TTL |
|---|---|
| Successful response | 24 hours |
| Error response | 24 hours |
| In-progress request | 5 minutes |
After the cache expires, the same idempotency key can be reused.
HTTP Response Headers
When making idempotent requests, Novu includes helpful headers in the response:
Idempotency-Key
Confirms the idempotency key that was used for the request:
Idempotency-Replay
Indicates that the response was served from the cache rather than processing a new request:
This header is only present when returning a cached response.
Error Handling
Request In Progress (409 Conflict)
If you send a request with an idempotency key while a previous request with the same key is still being processed:
The response includes a Retry-After header indicating when to retry:
Key Reused with Different Body (422 Unprocessable Entity)
If you send a request with an idempotency key that was previously used with a different request body:
Each idempotency key must be associated with a specific request body. Using the same key with different payloads will result in an error.
Key Too Long (400 Bad Request)
If the idempotency key exceeds 255 characters:
Best Practices
- Generate unique keys: Use UUIDs or combine entity IDs with timestamps to ensure uniqueness
- Store keys: Keep track of idempotency keys you've used in case you need to retry requests
- Handle 409 responses: Implement retry logic with exponential backoff when you receive a conflict response
- Don't reuse keys for different operations: Each unique operation should have its own idempotency key
- Include meaningful context: Consider including the operation type and relevant IDs in your key for easier debugging
Example: Safe Retry Logic
Here's an example of implementing safe retry logic with idempotency: