Install
openclaw skills install wechat-to-notionSave WeChat public account articles to a Notion database. Use when user sends a mp.weixin.qq.com link and wants to save/archive it to Notion. Fetches title, cover image, body content (paragraphs, headings, images, code blocks, lists) and writes them as Notion blocks.
openclaw skills install wechat-to-notionSave a WeChat article to Notion in three steps: fetch → analyze → save.
Check if the Notion API key is configured:
echo ${NOTION_API_KEY:0:8}...
If missing, tell the user:
You haven't configured a Notion API key yet:
- Go to https://notion.so/my-integrations → + New integration → copy the key (starts with
ntn_)- Open your Notion database → ... → Connect to → select your integration
- Set the key in your OpenClaw config — do not paste it into chat:
OpenClaw will inject it asopenclaw config set skills.entries.wechat-to-notion.NOTION_API_KEY "ntn_xxx"NOTION_API_KEYautomatically.
⚠️ Never ask the user to send the API key as a chat message — it will be exposed in conversation logs.
Ask if the user has an existing Notion database. If yes, use it directly. If no, ask for a parent page URL and create one:
curl -s -X POST https://api.notion.com/v1/databases \
-H "Authorization: Bearer $NOTION_API_KEY" \
-H "Notion-Version: 2025-09-03" \
-H "Content-Type: application/json" \
-d '{
"parent": {"type": "page_id", "page_id": "<parent_page_id>"},
"title": [{"type": "text", "text": {"content": "WeChat Articles"}}],
"properties": {
"Title": {"title": {}},
"URL": {"url": {}},
"Read Time": {"date": {}},
"Rating": {"select": {"options": [
{"name": "⭐", "color": "gray"},
{"name": "⭐⭐", "color": "gray"},
{"name": "⭐⭐⭐", "color": "yellow"},
{"name": "⭐⭐⭐⭐", "color": "orange"},
{"name": "⭐⭐⭐⭐⭐", "color": "red"}
]}},
"Tags": {"multi_select": {}},
"Notes": {"rich_text": {}}
}
}'
Match field names to the user's language (e.g. Chinese users get Chinese field names).
python3 {skillDir}/scripts/fetch_wechat.py <wechat_url> > /tmp/wx_article.json
Use the read tool to load /tmp/wx_article.json. Read the title and text content from blocks, then produce two outputs by reasoning directly:
Keywords (3–5):
Rating (1–5 stars): Based on readability and value, give a star rating:
3 stars and above automatically get a "Featured" tag.
Comment (1 sentence, written in the user's language): Evaluate the article's readability and value, not summarize its content. Focus on:
python3 {skillDir}/scripts/save_to_notion.py \
/tmp/wx_article.json \
<notion_db_url> \
<wechat_url> \
<read_time_iso8601+08:00> \
"<kw1>,<kw2>,<kw3>" \
"<comment>" \
<rating>
read_time: current time in the user's local timezone as ISO 8601 with offset, e.g. 2026-03-12T14:00:00+08:00keywords: comma-separated stringcomment: the single-sentence comment from Step 2rating: integer 1–5 (star rating); 3+ automatically adds "Featured" to tagsThe script auto-detects field names from the database schema by type (title, url, date, select, multi_select), writes all content blocks in batches of 100, and posts the comment to the Notion Comments panel.
og:image meta tag, inserted as the first blockfetch_wechat.py