Skip to main content
GET
/
knowledge-hub
/
sources
List sources
curl --request GET \
  --url https://api.exec.com/rest/v1/knowledge-hub/sources \
  --header 'Authorization: Bearer <token>'
{
  "data": [
    {
      "id": "s1a2b3c4d5e6",
      "title": "Q2 pricing deck.pdf",
      "source_type": "upload",
      "status": "ready",
      "content_format": "plain_text",
      "token_count": 5234,
      "has_images": false,
      "external_url": null,
      "summary": "Quarterly pricing and packaging overview.",
      "cover": "",
      "folders": [
        {
          "id": "f9a8b7c6d5e4",
          "name": "File Attachments",
          "emoji": "📎"
        }
      ],
      "created_by": {
        "id": "u1a2b3c4d5e6",
        "email": "[email protected]",
        "first_name": "Jane",
        "last_name": "Smith"
      },
      "created_at": "2026-05-01T09:00:00Z",
      "updated_at": "2026-05-01T09:05:00Z",
      "processed_at": "2026-05-01T09:05:00Z"
    }
  ],
  "pagination": {
    "page": 1,
    "page_size": 50,
    "total_count": 42,
    "total_pages": 1
  }
}

Authorizations

Authorization
string
header
required

API key created in Settings > API.

Format: exec_live_ followed by 40 alphanumeric characters.

Query Parameters

type
enum<string>

Filter by source type

Available options:
upload,
url,
notion,
google_drive,
guru,
page,
integration
status
enum<string>

Filter by extraction status

Available options:
pending,
processing,
ready,
failed
folder_id
string

Filter by folder UUID

query
string

Case-insensitive search over source titles

page_id
string

Filter to sources attached to this page (page UUID)

page
integer
default:1

Pagination page number (1-indexed) — which page of results to return, not a Knowledge Hub page.

Required range: x >= 1
page_size
integer
default:50

Number of results per page (max 100)

Required range: 1 <= x <= 100

Response

Paginated list of sources (metadata only)

data
object[]
pagination
object