notipo

v1.0.3

Publish blog posts from AI agents to WordPress via Notion. One API call handles page creation, markdown conversion, image uploads, featured image generation,...

0· 245·0 current·0 all-time

Install

OpenClaw Prompt Flow

Install with OpenClaw

Best for remote or guided setup. Copy the exact prompt, then paste it into OpenClaw for kfuras/notipo.

Previewing Install & Setup.
Prompt PreviewInstall & Setup
Install the skill "notipo" (kfuras/notipo) from ClawHub.
Skill page: https://clawhub.ai/kfuras/notipo
Keep the work scoped to this skill only.
After install, inspect the skill metadata and help me finish setup.
Required env vars: NOTIPO_URL, NOTIPO_API_KEY
Use only the metadata you can verify from ClawHub; do not invent missing requirements.
Ask before making any broader environment changes.

Command Line

CLI Commands

Use the direct CLI path if you want to install manually and keep every step visible.

OpenClaw CLI

Bare skill slug

openclaw skills install notipo

ClawHub CLI

Package manager switcher

npx clawhub@latest install notipo
Security Scan
VirusTotalVirusTotal
Benign
View report →
OpenClawOpenClaw
Benign
medium confidence
Purpose & Capability
Name, description, and runtime instructions all focus on creating and syncing posts via Notipo/Notion/WordPress. The only required environment variables (NOTIPO_URL, NOTIPO_API_KEY) are directly related to calling the Notipo service.
Instruction Scope
SKILL.md confines runtime actions to calling the Notipo API and using the notipo CLI/curl. It does recommend running `npm install -g notipo` if the CLI is missing (which instructs installing third-party code on the host). It also allows a customizable NOTIPO_URL, so ensure that variable points to the official service.
Install Mechanism
There is no formal install spec in the skill bundle (instruction-only), but the docs recommend a global npm install. Installing an npm package can run arbitrary code (postinstall scripts) and will add binaries to the host; verify the npm package and prefer constrained installs (container, VM, or isolated environment) if you have concerns.
Credentials
Only two env vars are required: NOTIPO_URL and NOTIPO_API_KEY. Both are necessary and proportional for making authenticated API calls to the Notipo service. The skill does not request unrelated credentials or filesystem paths.
Persistence & Privilege
The skill is not always-enabled and does not request elevated or persistent platform privileges. It does not attempt to modify other skills or system-wide agent configs in the provided instructions.
Assessment
This skill appears to do what it says, but take these precautions before installing or using it: 1) Confirm NOTIPO_URL points to the official https://notipo.com endpoint (or a trusted self-host) so you aren't sending content or API keys to an unknown server. 2) Treat NOTIPO_API_KEY like any secret—store it securely and avoid pasting it into shared shells; rotate it if you suspect exposure. 3) If you follow the SKILL.md recommendation to run `npm install -g notipo`, verify the npm package (publisher, downloads, source repo) and consider installing in an isolated environment (container or VM) to limit any postinstall scripts. 4) Review Notipo's privacy/security docs and the WordPress integration settings—automated publishing can leak drafts if misconfigured. 5) If you need higher assurance, ask for the skill's source code or an explicit install spec so you can audit what will be executed.

Like a lobster shell, security has layers — review code before you run it.

Runtime requirements

📝 Clawdis
EnvNOTIPO_URL, NOTIPO_API_KEY
latestvk974pny9020bgd98fce1vvhw6d84k4md
245downloads
0stars
4versions
Updated 2w ago
v1.0.3
MIT-0

Install Notipo CLI if it doesn't exist

npm install -g notipo

Setup

Sign up at notipo.com, connect your Notion database and WordPress site through the dashboard, then grab your API key from Settings → Account.

Set the environment variables:

export NOTIPO_URL="https://notipo.com"
export NOTIPO_API_KEY="ntp_your-api-key"

Core Workflow

  1. Generate — AI agent creates title, body (markdown), category, tags, SEO keyword
  2. Fetch context — get categories and tags from Notipo to pick valid values
  3. Publishnotipo posts create with all fields
  4. Monitornotipo jobs to check completion status

Essential Commands

Check connection status

notipo status

Fetch categories and tags

# Get available categories (for picking a valid category)
curl -s $NOTIPO_URL/api/categories \
  -H "X-API-Key: $NOTIPO_API_KEY" | jq '.data[].name'

# Get available tags
curl -s $NOTIPO_URL/api/tags \
  -H "X-API-Key: $NOTIPO_API_KEY" | jq '.data[].name'

Create a post (draft)

notipo posts create \
  --title "Your Post Title" \
  --body "## Introduction\n\nYour markdown content here.\n\n## Main Section\n\nMore content." \
  --category "Tutorials" \
  --tags "automation,ai" \
  --seo-keyword "your focus keyword" \
  --image-title "Featured Image Title" \
  --slug "custom-url-slug"

Create and publish immediately

notipo posts create \
  --title "Your Post Title" \
  --body "Markdown content here." \
  --category "Guides" \
  --seo-keyword "focus keyword" \
  --publish

Create, publish, and wait for completion

notipo posts create \
  --title "Your Post Title" \
  --body "Markdown content here." \
  --category "Guides" \
  --publish --wait

The --wait flag polls until the job completes and returns the result with the WordPress URL.

Create with inline Unsplash images (Pro plan, curl only)

curl -X POST $NOTIPO_URL/api/posts/create \
  -H "X-API-Key: $NOTIPO_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{
    "title": "Your Post Title",
    "body": "## Introduction\n\nContent here.\n\n## Getting Started\n\nMore content.",
    "category": "Tutorials",
    "seoKeyword": "focus keyword",
    "images": [
      { "query": "developer workspace laptop", "afterHeading": "## Introduction" },
      { "query": "getting started tutorial", "afterHeading": "## Getting Started" }
    ],
    "publish": true
  }'

Update a post (fix content, change metadata, re-sync to WordPress)

notipo posts update POST_ID \
  --body "## Introduction\n\nUpdated content without the H1." \
  --seo-keyword "updated focus keyword" \
  --wait

Updates the Notion page content and/or properties, then triggers a re-sync to WordPress. Only the provided fields are updated — omitted fields stay unchanged. This is the correct way to fix post content after creation.

Check job status

notipo jobs

List posts

notipo posts

Trigger a sync (pick up Notion changes)

notipo sync

Delete a post

notipo posts delete POST_ID

Common Patterns

AI-generated blog post with full metadata

# 1. Fetch categories to pick a valid one
curl -s $NOTIPO_URL/api/categories -H "X-API-Key: $NOTIPO_API_KEY" | jq '.data[].name'

# 2. Create the post with all fields and wait for completion
notipo posts create \
  --title "10 Docker Best Practices for Production" \
  --body "## Introduction\n\nDocker containers are the standard...\n\n## Use Multi-Stage Builds\n\nReduce image size by separating build and runtime...\n\n## Pin Base Image Versions\n\nAvoid surprises by pinning specific tags..." \
  --category "DevOps" \
  --tags "docker,containers,production" \
  --seo-keyword "docker best practices production" \
  --image-title "Docker Best Practices" \
  --slug "docker-best-practices-production" \
  --publish --wait

Batch content pipeline

# Generate and publish multiple posts in sequence
for topic in "React hooks" "TypeScript generics" "Node.js streams"; do
  notipo posts create \
    --title "A Guide to $topic" \
    --body "## Overview\n\nGenerated content about $topic." \
    --category "Tutorials" \
    --seo-keyword "$(echo $topic | tr '[:upper:]' '[:lower:]')" \
    --wait
done

Full pipeline with inline images (curl)

curl -X POST $NOTIPO_URL/api/posts/create \
  -H "X-API-Key: $NOTIPO_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{
    "title": "10 Docker Best Practices for Production",
    "body": "## Introduction\n\nDocker containers are the standard...\n\n## Use Multi-Stage Builds\n\nReduce image size...",
    "category": "DevOps",
    "tags": ["docker", "containers", "production"],
    "seoKeyword": "docker best practices production",
    "imageTitle": "Docker Best Practices",
    "slug": "docker-best-practices-production",
    "images": [
      { "query": "docker containers server", "afterHeading": "## Introduction" }
    ],
    "publish": true
  }'

CLI Reference

CommandDescription
notipo statusShow Notion and WordPress connection status
notipo syncTrigger an immediate Notion poll
notipo postsList all posts
notipo posts createCreate a post in Notion and sync to WordPress
notipo posts update <id>Update post content/properties and re-sync to WordPress
notipo posts delete <id>Delete a post (cleans up WordPress + Notion)
notipo jobsList recent sync and publish jobs
notipo helpShow usage and examples

posts create flags

FlagDescription
--title <title>Post title (required)
--body <markdown>Markdown content
--category <name>Category name (must exist in WordPress)
--tags <a,b,c>Comma-separated tag names
--seo-keyword <kw>Focus keyword for Rank Math / SEOPress
--image-title <text>Text overlay on featured image (Pro)
--slug <slug>Custom URL slug
--publishPublish immediately (default: draft)
--waitWait for job completion and return result

posts update flags

FlagDescription
--title <title>New post title
--body <markdown>New markdown content (replaces all existing content)
--category <name>New category name
--tags <a,b,c>New comma-separated tag names
--seo-keyword <kw>New focus keyword for Rank Math / SEOPress
--slug <slug>New URL slug
--publishPublish after syncing (default: keep current status)
--waitWait for job completion and return result

API Request Body Reference

PATCH /api/posts/:id (update)

FieldTypeRequiredDescription
titlestringNoNew post title
bodystringNoNew markdown content (replaces all existing content on the Notion page)
categorystringNoNew category name
tagsstring[]NoNew tag names
seoKeywordstringNoNew focus keyword
slugstringNoNew URL slug
publishbooleanNoPublish after syncing

Returns { jobId, postId, message }. The update writes to Notion first, then triggers a sync job to push changes to WordPress.

POST /api/posts/create

For curl/HTTP usage, POST /api/posts/create accepts:

FieldTypeRequiredDescription
titlestringYesPost title
bodystringNoMarkdown content with headings and paragraphs
categorystringNoCategory name (must exist in WordPress)
tagsstring[]NoArray of tag names
seoKeywordstringNoFocus keyword for Rank Math / SEOPress
imageTitlestringNoText overlay on featured image (Pro)
slugstringNoCustom URL slug
publishbooleanNoPublish immediately (default: false)
imagesobject[]NoInline Unsplash images (Pro). Each: {query, afterHeading}

What Notipo Handles

  • Notion page creation from markdown (no Notion credentials needed)
  • Markdown → Notion blocks → WordPress Gutenberg block conversion
  • Image download from Notion and upload to WordPress media library
  • Featured image generation (1200×628 with category background + title overlay)
  • Inline Unsplash image insertion by search query (Pro plan)
  • SEO metadata — Rank Math, Yoast, SEOPress, AIOSEO
  • Post status management in Notion
  • Failure notifications via Slack/Discord webhook

Common Gotchas

  1. Use posts update to fix content — don't delete and recreate. notipo posts update <id> --body "..." updates the Notion page and re-syncs to WordPress in one call.
  2. Include all fields for best results — only title is technically required, but AI agents should always generate body, category, tags, seoKeyword, imageTitle, and slug for a complete post.
  3. Category must exist — the category name must match an existing WordPress category. Fetch valid options first.
  4. --publish runs two jobs — first SYNC_POST (creates draft), then PUBLISH_POST (makes it live). Use --wait to block until both complete.
  5. Images require Pro plan — the images array and featured image generation are Pro features. On Free plan, these fields are silently ignored.
  6. Fire and forget — the API returns a jobId immediately. Processing happens in the background. Use notipo jobs to check status.
  7. Markdown body format — use ## Heading for h2, ### Heading for h3. Paragraphs are separated by \n\n. Images can be included as ![alt](url).
  8. Rate limitsnotipo sync has a 15-second cooldown. notipo posts create has no rate limit.
  9. API key format — keys start with ntp_. Get yours from Settings → Account in the dashboard.
  10. Slug defaults — if not set, the slug is derived from the SEO keyword. If no SEO keyword, WordPress generates it from the title.

Comments

Loading comments...