doodle top mobile

Automate Medium with AI Agents

Publish articles to Medium, manage publications, set canonical URLs for SEO, and organize with tags — all from the command line or through your AI agent.

Setup GuideClawHub

Please make sure there is always a human in the loop.

doodle left mobiledoodle right mobile

Publish to Medium in Seconds

Terminal

# Install globally
npm install -g postiz

# Set your API key
export POSTIZ_API_KEY=your_api_key

# Find your Medium integration
postiz integrations:list

# Publish an article to Medium
postiz posts:create \
  -c "Article body in markdown..." \
  -s "2025-01-15T10:00:00Z" \
  --settings '{"title":"My Article","subtitle":"A deep dive","tags":[{"value":"tech","label":"Tech"}]}' \
  -i "medium-id"

Medium-Specific Features

📝

Article Publishing

Publish long-form articles directly to Medium with full Markdown support. Write once, publish seamlessly.

📚

Publication Support

Publish articles under any Medium publication you belong to. Reach established audiences with a single setting.

🔗

Canonical URLs

Set canonical URLs for SEO to link back to your original content. Avoid duplicate content penalties across platforms.

🏷

Smart Tagging

Add up to 4 tags per article to improve discoverability. Tags help Medium surface your content to the right readers.

📅

Scheduled Publishing

Schedule articles for future publication with precise timestamps. Plan your content calendar weeks in advance.

🤖

AI-Powered Workflows

Let AI agents draft, format, and publish your articles. From idea to published post without leaving your chat app.

How It Works

1

Find Your Medium Integration

List your connected accounts and grab your Medium integration ID. You can also fetch available settings to see what options are supported.

Discovery

# List all integrations
postiz integrations:list

# Filter for Medium
postiz integrations:list | jq \
  '.[] | select(.identifier=="medium")'

# Get Medium settings schema
postiz integrations:settings <medium-id>
2

Write Your Article

Compose your article content in Markdown. Medium supports rich formatting including headers, code blocks, images, and embedded links.

Content

# Write your article content
cat > article.md << 'EOF'
# Building Better APIs

APIs are the backbone of modern software.
Here's how to design them right.

## Key Principles

1. **Consistency** - Use predictable patterns
2. **Versioning** - Plan for change
3. **Documentation** - Make it discoverable
EOF
3

Publish Your Article

Create a post with your article content, title, subtitle, tags, and optional publication and canonical URL settings.

Publish

postiz posts:create \
  -c "$(cat article.md)" \
  -s "2025-03-01T09:00:00Z" \
  --settings '{
    "title": "Building Better APIs",
    "subtitle": "A practical guide to API design",
    "canonical": "https://myblog.com/better-apis",
    "publication": "pub-id",
    "tags": [
      {"value": "api", "label": "API"},
      {"value": "software", "label": "Software"}
    ]
  }' \
  -i "medium-id"

Medium Settings Reference

Every Medium post accepts these platform-specific settings via the --settings flag.

FieldTypeDescription
__typestringMust be "medium"
titlestringArticle title (min 2 characters)
subtitlestringArticle subtitle (min 2 characters)
canonicalstringOriginal URL for SEO canonical link
publicationstringPublication ID to publish under
tagsarrayUp to 4 tags: [{value: string, label: string}]

Common Configurations

Copy-paste these settings for common Medium publishing scenarios.

Simple Article with Tags

settings.json

{
  "title": "Getting Started with TypeScript",
  "subtitle": "A beginner-friendly introduction",
  "tags": [
    {"value": "typescript", "label": "TypeScript"},
    {"value": "javascript", "label": "JavaScript"},
    {"value": "programming", "label": "Programming"}
  ]
}

Cross-Posted Article with Canonical URL

settings.json

{
  "title": "How We Scaled to 1M Users",
  "subtitle": "Lessons from our growth journey",
  "canonical": "https://engineering.myblog.com/scaling-to-1m",
  "tags": [
    {"value": "startup", "label": "Startup"},
    {"value": "scaling", "label": "Scaling"},
    {"value": "engineering", "label": "Engineering"}
  ]
}

Publication Article

settings.json

{
  "title": "The Future of AI Agents",
  "subtitle": "Why autonomous agents are the next paradigm",
  "publication": "towards-data-science-id",
  "tags": [
    {"value": "ai", "label": "Artificial Intelligence"},
    {"value": "agents", "label": "AI Agents"},
    {"value": "automation", "label": "Automation"},
    {"value": "future", "label": "Future"}
  ]
}

What is OpenClaw?

OpenClaw is the open-source personal AI agent with 145k+ GitHub stars. It runs locally on your machine, connects through apps you already use, and takes real actions on your behalf.

💬

Works Where You Are

Message OpenClaw from WhatsApp, Telegram, Slack, Discord, Signal, iMessage, or 10+ other platforms. No new app to learn.

🧩

Skill-Based Architecture

OpenClaw extends its abilities through Skills — lightweight plugins defined in Markdown files. Postiz is available as a skill on ClawHub.

Proactive Automation

Schedule recurring tasks with cron jobs. OpenClaw can publish your Medium articles on a schedule without you having to ask each time.

How Postiz Becomes an OpenClaw Skill

When you install Postiz Agent globally, OpenClaw automatically discovers it by reading the bundled SKILL.md file. This file tells OpenClaw what commands are available, what environment variables are needed, and how to compose Medium articles with the right settings.

  • Install from ClawHub with one command: clawhub install nevo-david/postiz
  • OpenClaw reads the SKILL.md and learns all Postiz commands
  • Eligibility is checked automatically — POSTIZ_API_KEY must be set
  • Skills are loaded on-demand, keeping the agent context clean
  • Works with any LLM backend: Claude, GPT, Gemini, Llama, and more

Install from ClawHub

# Install the Postiz skill
clawhub install nevo-david/postiz

# Or install the CLI globally
npm install -g postiz

# Set your API key
export POSTIZ_API_KEY=your_api_key

# Verify OpenClaw sees it
openclaw skills list --eligible

# Output:
# - postiz: Social media automation
#   CLI for scheduling posts
#   across 30+ platforms

Medium Publishing with OpenClaw

Message OpenClaw from any platform — it reads the Postiz skill, discovers your Medium integration, and handles the entire publishing workflow autonomously.

🦀

From Any Chat App

WhatsApp, Telegram, Slack, Discord...

Send a message to OpenClaw from your favorite chat app. It runs as a persistent daemon on your machine, so it picks up your message, discovers your Medium account via Postiz, formats the article, and publishes it — all while you go about your day.

WhatsApp / Telegram

You: Publish my draft about API design
  to Medium under the engineering pub,
  tag it with "api" and "software"

OpenClaw: Got it! Here's what I'll do:
  1. Read your draft from ~/drafts/api.md
  2. Publish to your engineering publication
  3. Tags: API, Software Engineering

  Done! Your Medium article is live.
  Post ID: abc-123
🦀

Scheduled & Proactive

Cron jobs for recurring content

OpenClaw supports cron-based heartbeat tasks. Set up a recurring job that checks a folder for new Markdown drafts and publishes them to Medium automatically — no manual trigger needed.

openclaw.json (heartbeat)

{
  "heartbeat": [
    {
      "cron": "0 8 * * 1,3,5",
      "prompt": "Check ~/articles/pending
  for new .md files. For each one,
  extract the title from the first
  heading, publish to Medium with
  appropriate tags. Move published
  files to ~/articles/published."
    }
  ]
}

Why OpenClaw + Postiz for Medium

OpenClaw's skill system makes Postiz a natural fit. The agent reads the SKILL.md to understand every available command, then autonomously chains them together for Medium workflows.

  • Message from WhatsApp to publish a Medium article — no terminal needed
  • Cron jobs for hands-free weekly publishing schedules
  • Structured JSON output lets OpenClaw verify each step succeeded
  • Canonical URLs applied automatically when cross-posting from your blog
  • Cross-post to Medium + other platforms in a single conversation
  • Model-agnostic — works with Claude, GPT, Gemini, or open-source LLMs

SKILL.md (auto-discovered)

---
name: postiz
description: Social media automation
  CLI for scheduling posts across
  30+ platforms including Medium
metadata:
  openclaw:
    requirements:
      env:
        - POSTIZ_API_KEY
      binaries:
        - postiz
---

# Available Commands
- postiz integrations:list
- postiz integrations:settings <id>
- postiz posts:create
- postiz upload <file>
- postiz analytics:platform <id>

# Medium Settings
title, subtitle, canonical,
publication, tags

Also Works with Claude Code

Postiz Agent works as a CLI tool with any AI agent that can execute shell commands — including Anthropic's Claude Code.

C

Claude Code

by Anthropic

Claude reads the SKILL.md file to learn all available Postiz commands, then autonomously discovers your Medium integration, formats your article, applies tags and publication settings, and publishes the post.

Claude Code

> Publish my API design article to Medium
  under the engineering publication with
  a canonical URL back to my blog

Claude will automatically run:
  postiz integrations:list
  postiz posts:create \
    -c "$(cat api-design.md)" \
    -s "2025-03-02T09:00:00Z" \
    --settings '{"title":
      "Building Better APIs",
      "subtitle":"A practical guide",
      "canonical":"https://myblog.com/apis",
      "publication":"eng-pub-id",
      "tags":[...]}' \
    -i "medium-id"

Medium + Other Platforms

Publish the same article to Medium and other platforms in a single command. Each platform gets its own settings.

Terminal

# Cross-post an article to Medium and Dev.to
postiz posts:create \
  -c "$(cat article.md)" \
  -s "2025-03-01T09:00:00Z" \
  --settings '{
    "title": "Building Better APIs",
    "subtitle": "A practical guide",
    "canonical": "https://myblog.com/better-apis",
    "tags": [
      {"value": "api", "label": "API"},
      {"value": "software", "label": "Software"}
    ]
  }' \
  -i "medium-id,devto-id"

# Batch schedule a week of Medium articles
for day in 1 2 3 4 5; do
  postiz posts:create \
    -c "$(cat articles/day${day}.md)" \
    -s "2025-03-0${day}T08:00:00Z" \
    --settings '{"title":"Day '"$day"' Insights","subtitle":"Weekly series","tags":[{"value":"series","label":"Series"}]}' \
    -i "medium-id"
done

Start publishing to Medium

Install Postiz Agent and automate your Medium content strategy with AI-powered scheduling and publishing.

Ready to get started?

Grow your social media presence with Postiz.
Schedule, analyze, and engage with your audience.

Grow your social media presence with Postiz.