notion
Originally fromsteipete/clawdis
SKILL.md
notion
Use the Notion API to create/read/update pages, data sources (databases), and blocks.
Authentication
All requests require these headers:
Authorization: Bearer $NOTION_API_KEYNotion-Version: 2025-09-03Content-Type: application/json(for POST/PATCH requests)
The API key is provided via the $NOTION_API_KEY environment variable.
API Base URL
https://api.notion.com/v1
Common Operations
Search for pages and data sources
POST /v1/search
Body:
{"query": "page title"}
Get page
GET /v1/pages/{page_id}
Get page content (blocks)
GET /v1/blocks/{page_id}/children
Create page in a data source
POST /v1/pages
Body:
{
"parent": {"database_id": "xxx"},
"properties": {
"Name": {"title": [{"text": {"content": "New Item"}}]},
"Status": {"select": {"name": "Todo"}}
}
}
Query a data source (database)
POST /v1/data_sources/{data_source_id}/query
Body:
{
"filter": {"property": "Status", "select": {"equals": "Active"}},
"sorts": [{"property": "Date", "direction": "descending"}]
}
Create a data source (database)
POST /v1/data_sources
Body:
{
"parent": {"page_id": "xxx"},
"title": [{"text": {"content": "My Database"}}],
"properties": {
"Name": {"title": {}},
"Status": {"select": {"options": [{"name": "Todo"}, {"name": "Done"}]}},
"Date": {"date": {}}
}
}
Update page properties
PATCH /v1/pages/{page_id}
Body:
{"properties": {"Status": {"select": {"name": "Done"}}}}
Add blocks to page
PATCH /v1/blocks/{page_id}/children
Body:
{
"children": [
{"object": "block", "type": "paragraph", "paragraph": {"rich_text": [{"text": {"content": "Hello"}}]}}
]
}
Property Types
Common property formats for database items:
- Title:
{"title": [{"text": {"content": "..."}}]} - Rich text:
{"rich_text": [{"text": {"content": "..."}}]} - Select:
{"select": {"name": "Option"}} - Multi-select:
{"multi_select": [{"name": "A"}, {"name": "B"}]} - Date:
{"date": {"start": "2024-01-15", "end": "2024-01-16"}} - Checkbox:
{"checkbox": true} - Number:
{"number": 42} - URL:
{"url": "https://..."} - Email:
{"email": "a@b.com"} - Relation:
{"relation": [{"id": "page_id"}]}
Key Differences in 2025-09-03
- Databases → Data Sources: Use
/data_sources/endpoints for queries and retrieval - Two IDs: Each database now has both a
database_idand adata_source_id- Use
database_idwhen creating pages (parent: {"database_id": "..."}) - Use
data_source_idwhen querying (POST /v1/data_sources/{id}/query)
- Use
- Search results: Databases return as
"object": "data_source"with theirdata_source_id - Parent in responses: Pages show
parent.data_source_idalongsideparent.database_id - Finding the data_source_id: Search for the database, or call
GET /v1/data_sources/{data_source_id}
Notes
- Page/database IDs are UUIDs (with or without dashes)
- The API cannot set database view filters — that's UI-only
- Rate limit: ~3 requests/second average
- Use
is_inline: truewhen creating data sources to embed them in pages
Weekly Installs
3
Repository
stitchi-co/skillsFirst Seen
11 days ago
Security Audits
Installed on
openclaw3
gemini-cli3
github-copilot3
codex3
kimi-cli3
cursor3