🎯

notion

🎯Skill

from steipete/clawdis

VibeIndex|
What it does

Manages Notion pages, databases, and blocks through the Notion API, enabling creation, retrieval, and updating of content programmatically.

πŸ“¦

Part of

steipete/clawdis(48 items)

notion

Installation

npm installInstall npm package
npm install -g openclaw@latest
git cloneClone repository
git clone https://github.com/openclaw/openclaw.git
pnpmRun with pnpm
pnpm install
πŸ“– Extracted from docs: steipete/clawdis
12Installs
-
AddedFeb 4, 2026

Skill Details

SKILL.md

Notion API for creating and managing pages, databases, and blocks.

Overview

# notion

Use the Notion API to create/read/update pages, data sources (databases), and blocks.

Setup

  1. Create an integration at https://notion.so/my-integrations
  2. Copy the API key (starts with ntn_ or secret_)
  3. Store it:

```bash

mkdir -p ~/.config/notion

echo "ntn_your_key_here" > ~/.config/notion/api_key

```

  1. Share target pages/databases with your integration (click "..." β†’ "Connect to" β†’ your integration name)

API Basics

All requests need:

```bash

NOTION_KEY=$(cat ~/.config/notion/api_key)

curl -X GET "https://api.notion.com/v1/..." \

-H "Authorization: Bearer $NOTION_KEY" \

-H "Notion-Version: 2025-09-03" \

-H "Content-Type: application/json"

```

> Note: The Notion-Version header is required. This skill uses 2025-09-03 (latest). In this version, databases are called "data sources" in the API.

Common Operations

Search for pages and data sources:

```bash

curl -X POST "https://api.notion.com/v1/search" \

-H "Authorization: Bearer $NOTION_KEY" \

-H "Notion-Version: 2025-09-03" \

-H "Content-Type: application/json" \

-d '{"query": "page title"}'

```

Get page:

```bash

curl "https://api.notion.com/v1/pages/{page_id}" \

-H "Authorization: Bearer $NOTION_KEY" \

-H "Notion-Version: 2025-09-03"

```

Get page content (blocks):

```bash

curl "https://api.notion.com/v1/blocks/{page_id}/children" \

-H "Authorization: Bearer $NOTION_KEY" \

-H "Notion-Version: 2025-09-03"

```

Create page in a data source:

```bash

curl -X POST "https://api.notion.com/v1/pages" \

-H "Authorization: Bearer $NOTION_KEY" \

-H "Notion-Version: 2025-09-03" \

-H "Content-Type: application/json" \

-d '{

"parent": {"database_id": "xxx"},

"properties": {

"Name": {"title": [{"text": {"content": "New Item"}}]},

"Status": {"select": {"name": "Todo"}}

}

}'

```

Query a data source (database):

```bash

curl -X POST "https://api.notion.com/v1/data_sources/{data_source_id}/query" \

-H "Authorization: Bearer $NOTION_KEY" \

-H "Notion-Version: 2025-09-03" \

-H "Content-Type: application/json" \

-d '{

"filter": {"property": "Status", "select": {"equals": "Active"}},

"sorts": [{"property": "Date", "direction": "descending"}]

}'

```

Create a data source (database):

```bash

curl -X POST "https://api.notion.com/v1/data_sources" \

-H "Authorization: Bearer $NOTION_KEY" \

-H "Notion-Version: 2025-09-03" \

-H "Content-Type: application/json" \

-d '{

"parent": {"page_id": "xxx"},

"title": [{"text": {"content": "My Database"}}],

"properties": {

"Name": {"title": {}},

"Status": {"select": {"options": [{"name": "Todo"}, {"name": "Done"}]}},

"Date": {"date": {}}

}

}'

```

Update page properties:

```bash

curl -X PATCH "https://api.notion.com/v1/pages/{page_id}" \

-H "Authorization: Bearer $NOTION_KEY" \

-H "Notion-Version: 2025-09-03" \

-H "Content-Type: application/json" \

-d '{"properties": {"Status": {"select": {"name": "Done"}}}}'

```

Add blocks to page:

```bash

curl -X PATCH "https://api.notion.com/v1/blocks/{page_id}/children" \

-H "Authorization: Bearer $NOTION_KEY" \

-H "Notion-Version: 2025-09-03" \

-H "Content-Type: application/json" \

-d '{

"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_id and a data_source_id

- Use database_id when creating pages (parent: {"database_id": "..."})

- Use data_source_id when querying (POST /v1/data_sources/{id}/query)

  • Search results: Databases return as "object": "data_source" with their data_source_id
  • Parent in responses: Pages show parent.data_source_id alongside parent.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: true when creating data sources to embed them in pages

More from this repository10

🎯
gog🎯Skill

Manages Gmail, Calendar, Drive, Contacts, Sheets, and Docs via CLI with OAuth-based Google Workspace interactions.

🎯
weather🎯Skill

Retrieves current weather and forecasts for any location using free services, with multiple output formats and no API key required.

🎯
summarize🎯Skill

Quickly summarizes URLs, local files, and YouTube links using AI models with flexible extraction options.

🎯
coding-agent🎯Skill

Runs coding agents like Claude Code or Codex in bash with PTY support, enabling programmatic control and background processing.

🎯
mcporter🎯Skill

Streamlines interaction with MCP servers through CLI, enabling listing, configuration, authentication, and direct tool calls via HTTP or stdio.

🎯
apple-reminders🎯Skill

Manages Apple Reminders via CLI, enabling listing, adding, editing, completing, and deleting tasks with flexible date and list filtering.

🎯
gifgrep🎯Skill

Searches and downloads GIFs from Tenor/Giphy with a CLI/TUI, enabling preview, extraction, and easy sharing.

🎯
nano-pdf🎯Skill

Edits PDFs using natural language instructions, allowing precise page-level modifications with simple CLI commands.

🎯
obsidian🎯Skill

Automates interactions with Obsidian vaults, enabling searching, creating, moving, and managing Markdown notes via obsidian-cli.

🎯
peekaboo🎯Skill

Automates macOS UI interactions by capturing screens, targeting elements, driving input, and managing apps via a powerful CLI tool.