首页龙虾技能列表 › Notion API 2026 01 15 — Notion API工具

Notion API 2026 01 15 — Notion API工具

v1.0.1

使用Notion API(2026-01-15)创建、移动、更新和管理页面、数据库、块,并应用支持锁定和数据源查询的模板。

0· 1,300·0 当前·0 累计
by @dongkukim (DongkuKim)·MIT-0
下载技能包
License
MIT-0
最后更新
2026/3/1
安全扫描
VirusTotal
无害
查看报告
OpenClaw
可疑
high confidence
这是一个连贯的Notion API助手,但技能清单省略了它需要Notion API密钥和本地配置路径——在信任或安装之前应该解决的不一致问题。
评估建议
此技能似乎是正常的Notion API助手,但其清单不一致:README指导您在~/.config/notion/api_key存储和读取Notion API令牌(或作为NOTION_KEY),即使技能元数据未列出所需的凭证或配置路径。在安装或使用之前:1) 要求发布者更正清单以声明所需的凭证或配置路径;2) 优先将令牌存储在安全密钥管理器或平台密钥存储中,而不是纯文本文件;3) 仅提供您信任的Notion集成令牌(创建具有最小范围的专用集成,而不是重用强大的账户令牌);4) 如果您依赖新描述的功能,请验证Notion-Version头和端点日期;5) 避免授予不受信任的技能持久或广泛的访问权限——如果平台允许每技能秘密,请使用它而不是将令牌放在您的主目录中。...
详细分析 ▾
用途与能力
SKILL.md是直接的Notion API指南(创建/移动/页面/模板/块)。显示的操作与Notion集成的目的一致。然而,注册表元数据未声明所需的凭证或配置路径,即使指令明确要求在~/.config/notion/api_key存储和读取Notion API密钥(或使用NOTION_KEY环境变量)。该遗漏是不一致的。
指令范围
运行时指令告诉代理/用户创建~/.config/notion/api_key并读取它(NOTION_KEY=$(cat ~/.config/notion/api_key)),然后运行对api.notion.com的curl调用。读取/写入该本地文件并使用令牌在Notion助手的目的是范围内,但技能清单未声明此文件访问。除此之外,指令是具体的,仅限于Notion端点(没有广泛的文件系统或网络外泄指导)。
安装机制
这是纯指令的,无安装规范或代码文件,因此没有安装程序风险,除了用户遵循指南时明确所做的之外,平台不会向磁盘写入任何内容。
凭证需求
该技能合法需要Notion API令牌,但清单未列出所需的环境变量或主凭证。SKILL.md告诉用户在~/.config/notion/api_key以纯文本存储秘密令牌,然后读取它——这对于Notion助手是预期的,但应在requires.env/所需配置路径中声明。以纯文本存储令牌也是安全考虑;密钥管理器或平台的密钥存储会更可取。
持久化与权限
该技能不请求always:true,没有安装脚本;它只会在调用时使用令牌。请记住,如果允许代理自主调用技能(默认),任何提供的令牌都可能被代理使用而无需额外确认——这是标准行为,但如果令牌被授予不受信任的技能,会增加影响范围。
安装前注意事项
  1. 要求发布者更正清单以声明所需的凭证或配置路径
  2. 优先将令牌存储在安全密钥管理器或平台密钥存储中,而不是纯文本文件
  3. 仅提供您信任的Notion集成令牌(创建具有最小范围的专用集成,而不是重用强大的账户令牌)
  4. 如果您依赖新描述的功能,请验证Notion-Version头和端点日期
  5. 避免授予不受信任的技能持久或广泛的访问权限——如果平台允许每技能秘密,请使用它而不是将令牌放在您的主目录中
安全有层次,运行前请审查代码。

License

MIT-0

可自由使用、修改和再分发,无需署名。

运行时依赖

无特殊依赖

版本

latestv1.0.12026/2/8

更新技能名称和描述以反映2026年1月15日的Notion API更改。无功能或代码更改;仅文档和元数据。

● 无害

安装命令 点击复制

官方npx clawhub@latest install notion-2026-01-15
镜像加速npx clawhub@latest install notion-2026-01-15 --registry https://cn.clawhub-mirror.com

技能文档

Here is the complete SKILL.md file updated for the January 15, 2026 API state.

---
name: notion api 202601 15
description: Notion API updated to 2026 01 15 changes for creating, moving, and managing pages, data sources, and blocks.
homepage: https://developers.notion.com
metadata: {"clawdbot":{"emoji":"📝"}}

# notion

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

Setup

  • Create an integration at https://notion.so/my-integrations
  • Copy the API key (starts with ntn_ or secret_)
  • Store it:
bash mkdir -p ~/.config/notion echo "ntn_your_key_here" > ~/.config/notion/api_key


  • 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 "否tion-版本: 2025-09-03" \ -H "Content-Type: application/json"


Note: The Notion-Version header is required. Use 2025-09-03. The features released in Jan 2026 (Move Page, Templates) are additive and use this version header.

Common Operations

Search for pages and data sources:

bash curl -X POST "https://api.notion.com/v1/search" \ -H "Authorization: Bearer $NOTION_KEY" \ -H "否tion-版本: 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 "否tion-版本: 2025-09-03"


Move a page (Change Parent):

bash curl -X POST "https://api.notion.com/v1/pages/{page_id}/move" \ -H "Authorization: Bearer $NOTION_KEY" \ -H "否tion-版本: 2025-09-03" \ -H "Content-Type: application/json" \ -d '{ "parent": {"type": "page_id", "page_id": "new_parent_page_id"} }'


Note: To move to a database, use {"type": "data_source_id", "data_source_id": "..."}.

Create page (Standard):

bash curl -X POST "https://api.notion.com/v1/pages" \ -H "Authorization: Bearer $NOTION_KEY" \ -H "否tion-版本: 2025-09-03" \ -H "Content-Type: application/json" \ -d '{ "parent": {"database_id": "xxx"}, "properties": { "Name": {"title": [{"text": {"content": "New Item"}}]}, "Status": {"select": {"name": "Todo"}} } }'


Create page from Template:

bash curl -X POST "https://api.notion.com/v1/pages" \ -H "Authorization: Bearer $NOTION_KEY" \ -H "否tion-版本: 2025-09-03" \ -H "Content-Type: application/json" \ -d '{ "parent": {"database_id": "xxx"}, "template": {"type": "template_id", "template_id": "yyy"} }'


List Data Source Templates:

bash curl -X GET "https://api.notion.com/v1/data_sources/{data_source_id}/templates" \ -H "Authorization: Bearer $NOTION_KEY" \ -H "否tion-版本: 2025-09-03"


Update page properties:

bash curl -X PATCH "https://api.notion.com/v1/pages/{page_id}" \ -H "Authorization: Bearer $NOTION_KEY" \ -H "否tion-版本: 2025-09-03" \ -H "Content-Type: application/json" \ -d '{ "properties": {"Status": {"select": {"name": "Done"}}}, "is_locked": true }'


Apply Template to existing page (erasing content):

bash curl -X PATCH "https://api.notion.com/v1/pages/{page_id}" \ -H "Authorization: Bearer $NOTION_KEY" \ -H "否tion-版本: 2025-09-03" \ -H "Content-Type: application/json" \ -d '{ "template": {"type": "template_id", "template_id": "yyy"}, "erase_content": true }'


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 "否tion-版本: 2025-09-03" \ -H "Content-Type: application/json" \ -d '{ "filter": {"property": "Status", "select": {"equals": "Active"}}, "sorts": [{"property": "Date", "direction": "descending"}] }'


Add blocks to page:

bash curl -X PATCH "https://api.notion.com/v1/blocks/{page_id}/children" \ -H "Authorization: Bearer $NOTION_KEY" \ -H "否tion-版本: 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"}]}

Recent Changes (Jan 2026)

Move Page API: Use /v1/pages/{id}/move to reparent pages. Templates: New endpoints to list templates and parameters to apply them during page creation/update. Locking: is_locked boolean now supported in Update Page. Tokens: New tokens use ntn_ prefix (formerly secret_). Data Sources: Continue using data_source_id for queries (introduced in 2025-09-03).

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

```

数据来源:ClawHub ↗ · 中文优化:龙虾技能库
OpenClaw 技能定制 / 插件定制 / 私有工作流定制

免费技能或插件可能存在安全风险,如需更匹配、更安全的方案,建议联系付费定制

了解定制服务