List webhooks
Returns a paginated list of webhooks configured for the workspace.
curl -X GET "https://api.sendkit.ai/v1/webhooks?cursor=664a1b2c3d4e5f6a7b8c9d0e&limit=42" \
-H "Content-Type: application/json" \
-H "X-Api-Key: YOUR_API_KEY"
import requests
import json
url = "https://api.sendkit.ai/v1/webhooks?cursor=664a1b2c3d4e5f6a7b8c9d0e&limit=42"
headers = {
"Content-Type": "application/json",
"X-Api-Key": "YOUR_API_KEY"
}
response = requests.get(url, headers=headers)
print(response.json())
const response = await fetch("https://api.sendkit.ai/v1/webhooks?cursor=664a1b2c3d4e5f6a7b8c9d0e&limit=42", {
method: "GET",
headers: {
"Content-Type": "application/json",
"X-Api-Key": "YOUR_API_KEY"
}
});
const data = await response.json();
console.log(data);
package main
import (
"fmt"
"net/http"
)
func main() {
req, err := http.NewRequest("GET", "https://api.sendkit.ai/v1/webhooks?cursor=664a1b2c3d4e5f6a7b8c9d0e&limit=42", nil)
if err != nil {
panic(err)
}
req.Header.Set("Content-Type", "application/json")
req.Header.Set("X-Api-Key", "YOUR_API_KEY")
client := &http.Client{}
resp, err := client.Do(req)
if err != nil {
panic(err)
}
defer resp.Body.Close()
fmt.Println("Response Status:", resp.Status)
}
require 'net/http'
require 'json'
uri = URI('https://api.sendkit.ai/v1/webhooks?cursor=664a1b2c3d4e5f6a7b8c9d0e&limit=42')
http = Net::HTTP.new(uri.host, uri.port)
http.use_ssl = true
request = Net::HTTP::Get.new(uri)
request['Content-Type'] = 'application/json'
request['X-Api-Key'] = 'YOUR_API_KEY'
response = http.request(request)
puts response.body
{
"success": true,
"data": [
{
"_id": "664a1b2c3d4e5f6a7b8c9d0e",
"workspaceId": "ws_123",
"name": "Analytics Pipeline",
"url": "https://analytics.internal.example.com/ingest",
"events": [
"email.sent",
"email.opened",
"email.clicked",
"email.replied",
"email.bounced",
"email.unsubscribed"
],
"status": "inactive",
"secret": "whsec_test_53668aa2-e9dc-45",
"retryAttempts": 2,
"timeoutMs": 5000,
"stats": {
"totalDelivered": 2444,
"totalFailed": 79,
"lastDeliveredAt": "2026-01-27T04:49:34.111Z"
},
"createdBy": "user_123",
"createdAt": "2026-01-30T11:30:46.006Z",
"updatedAt": "2026-01-19T04:56:19.760Z"
}
],
"pagination": {
"limit": 25,
"total": 3,
"hasMore": false,
"nextCursor": "664a1b2c3d4e5f6a7b8c9d0e"
}
}
GET
/v1/webhooks
GET
API Key (header: X-Api-Key)
X-Api-Keystring
RequiredPlatform API key (sk_user_...) or Workspace API key (sk_...)
Platform API key (sk_user_...) or Workspace API key (sk_...)
query
cursorstring
Cursor for pagination - use the nextCursor value from the previous response to fetch the next page
query
limitinteger
Items per page (default 25, max 100)
Min: 1 • Max: 100
Request Preview
Response
Response will appear here after sending the request
Authentication
header
X-Api-Keystring
RequiredAPI Key for authentication. Platform API key (sk_user_...) or Workspace API key (sk_...)
Query Parameters
cursorstring
Cursor for pagination - use the nextCursor value from the previous response to fetch the next page
limitinteger
Items per page (default 25, max 100)
Responses
successboolean
dataarray
_idstring
workspaceIdstring
namestring
urlstring
eventsstring[]
Allowed values:
email.sentemail.openedemail.clickedemail.bouncedemail.repliedemail.unsubscribedemail.positive_replycampaign.startedcampaign.pausedcampaign.completedlead.addedlead.updatedlead.tag_changedsecretstring
retryAttemptsinteger
timeoutMsinteger
statusstring
Allowed values:
activeinactivestatsobject
Delivery statistics
totalDeliveredinteger
totalFailedinteger
lastDeliveredAtstring
createdBystring
createdAtstring
updatedAtstring
paginationobject
limitinteger
totalinteger
hasMoreboolean
nextCursorstring
Was this page helpful?
Last updated 4 days ago
Built with Documentation.AI