Skip to main content

APIs

All features that are available on the listmonk dashboard are also available as REST-like HTTP APIs that can be interacted with directly. Request and response bodies are JSON. This allows easy scripting of listmonk and integration with other systems, for instance, synchronisation with external subscriber databases.

API requests require BasicAuth authentication with the admin credentials.

The API section is a work in progress. There may be API calls that are yet to be documented. Please consider contributing to docs.

OpenAPI (Swagger) spec

The auto-generated OpenAPI (Swagger) specification site for the APIs are available at listmonk.app/docs/swagger

Response structure

Successful request

HTTP/1.1 200 OK
Content-Type: application/json

{
"data": {}
}

All responses from the API server are JSON with the content-type application/json unless explicitly stated otherwise. A successful 200 OK response always has a JSON response body with a status key with the value success. The data key contains the full response payload.

Failed request

HTTP/1.1 500 Server error
Content-Type: application/json

{
"message": "Error message"
}

A failure response is preceded by the corresponding 40x or 50x HTTP header. There may be an optional data key with additional payload.

Timestamps

All timestamp fields are in the format 2019-01-01T09:00:00.000000+05:30. The seconds component is suffixed by the milliseconds, followed by the + and the timezone offset.

Common HTTP error codes

code 
400Missing or bad request parameters or values
403Session expired or invalidate. Must relogin
404Request resource was not found
405Request method (GET, POST etc.) is not allowed on the requested endpoint
410The requested resource is gone permanently
429Too many requests to the API (rate limiting)
500Something unexpected went wrong
502The backend OMS is down and the API is unable to communicate with it
503Service unavailable; the API is down
504Gateway timeout; the API is unreachable