← ClaudeAtlas

bloggerlisted

Publish posts to your Blogger blog and read your blogs / posts via the Blogger API v3. Use when the user mentions Blogger, blogspot, publishing a post to their blog, listing their blogs, or updating an existing Blogger post.
AceDataCloud/Skills · ★ 8 · AI & Automation · score 69
Install: claude install-skill AceDataCloud/Skills
Call the **Blogger API v3** with `curl + jq`. The user's OAuth bearer token is in `$GOOGLE_BLOGGER_TOKEN`; every call needs `Authorization: Bearer $GOOGLE_BLOGGER_TOKEN`. Base URL: `https://www.googleapis.com/blogger/v3`. Errors are `{"error": {"code": ..., "message": ...}}` — show them verbatim. `401` → token expired, re-connect the Blogger connector. **Always start by listing the user's blogs** to get a `blogId`: ```bash curl -sS -H "Authorization: Bearer $GOOGLE_BLOGGER_TOKEN" \ "https://www.googleapis.com/blogger/v3/users/self/blogs" \ | jq '.items[] | {id, name, url}' ``` ## Publish a post **Confirm before publishing publicly.** Use `?isDraft=true` to stage a draft. ```bash BLOG_ID="1234567890" jq -n --arg t "My title" --arg c "<p>HTML content of the post…</p>" \ '{kind:"blogger#post", title:$t, content:$c, labels:["ai","video"]}' \ | curl -sS -X POST \ "https://www.googleapis.com/blogger/v3/blogs/$BLOG_ID/posts/?isDraft=false" \ -H "Authorization: Bearer $GOOGLE_BLOGGER_TOKEN" \ -H "Content-Type: application/json" \ -d @- \ | jq '{id, url, status}' ``` `content` is **HTML** (not Markdown) — convert Markdown to HTML first (e.g. with `pandoc -f markdown -t html` or a simple converter). - Publish a staged draft: `POST /blogs/{blogId}/posts/{postId}/publish`. - Update a post: `PUT /blogs/{blogId}/posts/{postId}` with the same shape. ## List / read posts ```bash curl -sS -H "Authorization: Bearer $GOOGLE_BLOGGER_TOKEN" \ "https://www.googlea