Skip to main content
GET
/
v4
/
posts
List posts
curl --request GET \
  --url https://api.kit.com/v4/posts \
  --header 'X-Kit-Api-Key: <api-key>'
{
  "posts": [
    {
      "id": 3,
      "publication_id": 106,
      "created_at": "2026-04-20T14:00:13Z",
      "title": "Draft Post",
      "slug": null,
      "description": null,
      "meta_description": null,
      "status": "draft",
      "published_at": null,
      "sent_at": null,
      "thumbnail_alt": null,
      "thumbnail_url": null,
      "is_paid": false,
      "public_url": null
    },
    {
      "id": 2,
      "publication_id": 105,
      "created_at": "2026-04-20T14:00:13Z",
      "title": "Email and Web Post",
      "slug": "email-and-web-post",
      "description": null,
      "meta_description": null,
      "status": "published",
      "published_at": "2026-04-18T14:00:13Z",
      "sent_at": "2026-04-20T14:00:13Z",
      "thumbnail_alt": null,
      "thumbnail_url": null,
      "is_paid": false,
      "public_url": "https://asdf.kit.com/posts/email-and-web-post"
    },
    {
      "id": 1,
      "publication_id": 104,
      "created_at": "2026-04-20T14:00:13Z",
      "title": "Web Only Post",
      "slug": "web-only-post",
      "description": null,
      "meta_description": null,
      "status": "published",
      "published_at": "2026-04-19T14:00:13Z",
      "sent_at": null,
      "thumbnail_alt": null,
      "thumbnail_url": null,
      "is_paid": false,
      "public_url": "https://asdf.kit.com/posts/web-only-post"
    }
  ],
  "pagination": {
    "has_previous_page": false,
    "has_next_page": false,
    "start_cursor": "WzNd",
    "end_cursor": "WzFd",
    "per_page": 500
  }
}

Authorizations

X-Kit-Api-Key
string
header
required

Authenticate API requests via an API Key

Query Parameters

after
any | null

To fetch next page of results, use ?after=<end_cursor>

before
any | null

To fetch previous page of results, use ?before=<start_cursor>

include_content
boolean

To include the content field on each post in the response, use true. Omitted by default because it significantly increases response size and latency for large collections.

include_total_count
boolean

To include the total count of records in the response, use true. For large collections, expect a slightly slower response.

per_page
any | null

Number of results per page. Default 500, maximum 1000.

Response

200 - application/json

Returns a paginated list of all posts for your account

posts
object[]
required
pagination
object
required