Campaign Leads
List leads in campaign
Returns a paginated list of leads within a campaign. Each lead includes its campaign-specific status, sequence progress, email history, and populated lead details (email, name, company).
curl -X GET "https://api.sendkit.ai/v1/campaigns/example_string/leads?status=pending&page=25&limit=42&cursor=example_string" \
-H "Content-Type: application/json" \
-H "X-Api-Key: YOUR_API_KEY" \
-H "Authorization: Bearer YOUR_API_TOKEN"
import requests
import json
url = "https://api.sendkit.ai/v1/campaigns/example_string/leads?status=pending&page=25&limit=42&cursor=example_string"
headers = {
"Content-Type": "application/json",
"X-Api-Key": "YOUR_API_KEY",
"Authorization": "Bearer YOUR_API_TOKEN"
}
response = requests.get(url, headers=headers)
print(response.json())
const response = await fetch("https://api.sendkit.ai/v1/campaigns/example_string/leads?status=pending&page=25&limit=42&cursor=example_string", {
method: "GET",
headers: {
"Content-Type": "application/json",
"X-Api-Key": "YOUR_API_KEY",
"Authorization": "Bearer YOUR_API_TOKEN"
}
});
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/campaigns/example_string/leads?status=pending&page=25&limit=42&cursor=example_string", nil)
if err != nil {
panic(err)
}
req.Header.Set("Content-Type", "application/json")
req.Header.Set("X-Api-Key", "YOUR_API_KEY")
req.Header.Set("Authorization", "Bearer YOUR_API_TOKEN")
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/campaigns/example_string/leads?status=pending&page=25&limit=42&cursor=example_string')
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'
request['Authorization'] = 'Bearer YOUR_API_TOKEN'
response = http.request(request)
puts response.body
{
"success": true,
"data": [
{
"_id": "666a1b2c3d4e5f6a7b8c9d01",
"leadId": {
"_id": "665d4e5f6a7b8c9d0e1f2a3b",
"email": "john@acme.com",
"firstName": "John",
"lastName": "Doe",
"companyName": "Acme Corp"
},
"status": "active",
"currentSequenceStep": 1,
"emailsSent": [
{
"sequenceStep": 0,
"variant": null,
"sentAt": "2025-06-16T10:30:00.000Z",
"opened": true,
"clicked": false,
"bounced": false
}
],
"replied": false,
"repliedAt": null,
"aiTag": null,
"tags": [
"vip"
],
"addedAt": "2025-06-15T09:00:00.000Z"
},
{
"_id": "666a1b2c3d4e5f6a7b8c9d02",
"leadId": {
"_id": "665d4e5f6a7b8c9d0e1f2a3c",
"email": "jane@example.com",
"firstName": "Jane",
"lastName": "Smith",
"companyName": "Example Inc"
},
"status": "replied",
"currentSequenceStep": 0,
"emailsSent": [
{
"sequenceStep": 0,
"variant": null,
"sentAt": "2025-06-16T11:00:00.000Z",
"opened": true,
"clicked": true,
"bounced": false
}
],
"replied": true,
"repliedAt": "2025-06-17T08:30:00.000Z",
"aiTag": "interested",
"tags": [],
"addedAt": "2025-06-15T09:00:00.000Z"
}
],
"pagination": {
"page": 1,
"limit": 25,
"total": 2,
"pages": 1
}
}
GET
/v1/campaigns/{id}/leadsGET
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_...)
path
idstring
RequiredResource ID
query
statusstring
Filter by campaign lead status
Options: pending, active, paused, completed, bounced, unsubscribed, replied, removed
query
pageinteger
Min: 1
query
limitinteger
Min: 1 • Max: 100
query
cursorstring
Cursor ID for cursor-based pagination (use instead of page for large datasets)
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_...)
header
Authorizationstring
RequiredBearer token. API key as Bearer token
Path Parameters
idstring
RequiredResource ID
Query Parameters
statusstring
Filter by campaign lead status
Allowed values:
pendingactivepausedcompletedbouncedunsubscribedrepliedremovedcursorstring
Cursor ID for cursor-based pagination (use instead of page for large datasets)
Responses
successboolean
dataarray
paginationobject
Was this page helpful?
Last updated today
Built with Documentation.AI