List Contacts
Contacts
List Contacts
Retrieve a paginated list of contacts filtered by creation date
GET
List Contacts
Overview
This endpoint allows you to retrieve a paginated list of contacts from Cometly within a specific date range. Each contact includes primary data from the profile (email, name, phone, location). For complete contact information including all associated emails, phones, names, and locations from merged profiles, use the individual contact endpoint GET /contacts/. Results are cursor-paginated for efficient data retrieval and ordered by ID (newest first).Query Parameters
Required Parameters
Start date and time for filtering contacts by creation date in
YYYY-MM-DD HH:MM:SS format. The date is interpreted in your space’s timezone.Example: 2024-01-15 00:00:00End date and time for filtering contacts by creation date in
YYYY-MM-DD HH:MM:SS format. Must be after start_date. The date is interpreted in your space’s timezone.Example: 2024-01-15 23:59:59Optional Parameters
Number of contacts to return per page. Minimum: 1, Maximum: 5000
Pagination cursor from a previous response. Use this to fetch the next page of results.
When set to
1, includes the last 5 comet tokens for each contact, ordered by most recent first. Accepts 1 or 0.When set to
1, includes all email addresses associated with the contact (including emails from merged profiles). Accepts 1 or 0.When set to
1, includes all 30 custom field columns for each contact. Fields 1-15 are text, 16-25 are numeric, 26-30 are date. Accepts 1 or 0.When set to
1, custom field keys in the response will use the user-defined labels (e.g. "Customer Age") instead of the raw column names (e.g. "profile_field_1"). Only applies when include_custom_fields=1. Fields without a configured label will keep their raw column name. Accepts 1 or 0.Filter contacts by their custom profile field values. Array of AND-joined conditions. Each condition is
{ "field": "profile_field_N", "operator": "<op>", "value": <val> }, or for ranges { "field": "profile_field_N", "operator": "between", "start": <a>, "end": <b> }. The field must reference a custom field slot that has been configured with a label in your space (e.g. profile_field_5). Maximum 10 conditions per request.Operator vocabulary by field type:| Slot range | Type | Valid operators |
|---|---|---|
profile_field_1 – profile_field_15 | text | equal_to, not_equal_to, contains, not_contains, starts_with, ends_with, contains_word, any, unknown |
profile_field_16 – profile_field_25 | number | equal_to, not_equal_to, greater_than, greater_than_or_equal_to, less_than, less_than_or_equal_to, any, unknown |
profile_field_26 – profile_field_30 | date | equal_to, between, greater_than, less_than, age_greater_than, age_equal_to, age_less_than, any, unknown |
any matches contacts where the field has a value; unknown matches contacts where the field is empty or unset. For numeric fields, any requires a value greater than 0 — unknown matches 0 or unset. Date comparisons (equal_to, greater_than, less_than, between) are evaluated in your space’s configured timezone; equal_to matches the full calendar day. not_equal_to and not_contains do not include contacts where the field is unset — add a separate unknown condition if you need those.Example query string: custom_field_filters[0][field]=profile_field_5&custom_field_filters[0][operator]=equal_to&custom_field_filters[0][value]=PremiumResponse
Success Response
The response follows Laravel’s cursor pagination structure:Array of contact objects. Each contact includes:
id(integer): The unique identifier of the contactemail(string|null): Primary email addressname(string|null): Primary namephone(string|null): Primary phone numberlocation(string|null): Primary locationcomet_tokens(array): Array of comet tokens (only included wheninclude_comet_tokens=1)emails(array): Array of all email addresses associated with the contact, including emails from merged profiles (only included wheninclude_all_emails=1)profile_field_1throughprofile_field_30: Custom field values (only included wheninclude_custom_fields=1). Fields 1-15 are text (string|null), 16-25 are numeric (number|null), 26-30 are date (string|null)
The base URL path for the endpoint
Number of items per page
Cursor for the next page of results.
null if there are no more pages.Full URL for the next page of results.
null if there are no more pages.Cursor for the previous page of results.
null if on the first page.Full URL for the previous page of results.
null if on the first page.Error Response
Error description explaining what went wrong
Example Requests
Status Codes
| Status Code | Description |
|---|---|
| 200 | Contacts successfully retrieved |
| 401 | Missing or invalid API key |
| 403 | API key doesn’t have permission or subscription is inactive |
| 422 | Invalid parameters provided (check error message for details) |
| 429 | Too many requests - rate limit exceeded. See Rate Limiting |
Notes
- Rate Limit: This endpoint has a limit of 15 requests per minute per Space. See Rate Limiting for details.
- Primary Data Only: This endpoint returns primary contact data (email, name, phone, location) from the profiles table for efficient browsing.
- Complete Contact Data: For full contact information including all associated emails, phones, names, and locations from merged profiles, use GET /contacts/.
- Performance: This endpoint uses a single efficient query, making it ideal for listing and browsing large numbers of contacts.
- Ordering: Results are ordered by ID in descending order (newest first).
- Pagination: Cursor pagination is used for efficient traversal of large result sets.
- Comet Tokens: Use the
include_comet_tokens=1query parameter to include the last 5 comet tokens for each contact. This parameter is optional and defaults to0. - All Emails: Use the
include_all_emails=1query parameter to include all email addresses for each contact, including emails from merged profiles. This parameter is optional and defaults to0. - Custom Fields: Use the
include_custom_fields=1query parameter to include all 30 custom fields in the response. Fields 1-15 are text, 16-25 are numeric, 26-30 are date. This parameter is optional and defaults to0. - Custom Field Labels: Use
use_custom_field_labels=1alongsideinclude_custom_fields=1to replace raw column names (profile_field_1) with user-defined labels (e.g.Customer Age). Fields without a configured label will retain their raw column name. - Custom Field Filters: Use
custom_field_filtersto narrow results to contacts whose custom profile fields match specified values. Conditions AND together; up to 10 per request. Slots that haven’t been configured with a label in your space cannot be filtered against and will be rejected with a 422. Age operators (age_greater_than,age_equal_to,age_less_than) accept a whole-number day count and are supported on date fields (profile_field_26–profile_field_30). The_and\characters in text filter values are treated as literals, not LIKE wildcards.