citedy-content-writer

From topic to published blog post in one conversation — generate SEO- and GEO-optimized articles with AI illustrations and voice-over in 55 languages, create social media adaptations for 9 platforms, set up automated content sessions, and manage product knowledge base. End-to-end blog autopilot. Powered by Citedy.

1,864 stars

Best use case

citedy-content-writer is best used when you need a repeatable AI agent workflow instead of a one-off prompt.

From topic to published blog post in one conversation — generate SEO- and GEO-optimized articles with AI illustrations and voice-over in 55 languages, create social media adaptations for 9 platforms, set up automated content sessions, and manage product knowledge base. End-to-end blog autopilot. Powered by Citedy.

Teams using citedy-content-writer should expect a more consistent output, faster repeated execution, less prompt rewriting.

When to use this skill

  • You want a reusable workflow that can be run more than once with consistent structure.

When not to use this skill

  • You only need a quick one-off answer and do not need a reusable workflow.
  • You cannot install or maintain the underlying files, dependencies, or repository context.

Installation

Claude Code / Cursor / Codex

$curl -o ~/.claude/skills/citedy-content-writer/SKILL.md --create-dirs "https://raw.githubusercontent.com/LeoYeAI/openclaw-master-skills/main/skills/citedy-content-writer/SKILL.md"

Manual Installation

  1. Download SKILL.md from GitHub
  2. Place it in .claude/skills/citedy-content-writer/SKILL.md inside your project
  3. Restart your AI agent — it will auto-discover the skill

How citedy-content-writer Compares

Feature / Agentcitedy-content-writerStandard Approach
Platform SupportNot specifiedLimited / Varies
Context Awareness High Baseline
Installation ComplexityUnknownN/A

Frequently Asked Questions

What does this skill do?

From topic to published blog post in one conversation — generate SEO- and GEO-optimized articles with AI illustrations and voice-over in 55 languages, create social media adaptations for 9 platforms, set up automated content sessions, and manage product knowledge base. End-to-end blog autopilot. Powered by Citedy.

Where can I find the source code?

You can find the source code on GitHub using the link provided at the top of the page.

Related Guides

SKILL.md Source

# AI Content Writer — Skill Instructions

## Overview

**AI Content Writer** is an end-to-end blog autopilot powered by [Citedy](https://www.citedy.com/). It covers the entire content production pipeline in a single conversation:

1. **Research** — source URLs or topic input, optional web intelligence search
2. **Write** — SEO & GEO-optimized articles in 55 languages, 4 size presets
3. **Enhance** — AI illustrations, voice-over audio, internal link optimization, humanization
4. **Distribute** — social media adaptations for 9 platforms (X, LinkedIn, Facebook, Reddit, Threads, Instagram, Instagram Reels, YouTube Shorts)
5. **Automate** — cron-based autopilot sessions, scheduling, webhook notifications

No competitor offers the full pipeline in one agent skill.

---

## When to Use

Use this skill when the user wants to:

- Write a blog article from a topic or URL
- Create social media posts from an existing article
- Set up automated daily/weekly content publishing
- Manage a product knowledge base for AI-grounded articles
- Schedule and fill content calendar gaps
- Generate micro-posts across multiple platforms at once
- Select a writing persona (25 available)

---

## Instructions

### Setup (run once)

If you don't have a saved API key for Citedy, run this flow:

#### 1. Register

**Preferred: run the included registration script:**

```bash
node scripts/register.mjs [agent_name]
```

The script calls the registration API and prints the approval URL. If `agent_name` is omitted, it defaults to `agent-<hostname>`.

**Alternative: call the API directly:**

```http
POST https://www.citedy.com/api/agent/register
Content-Type: application/json

{"agent_name": "<your_agent_name>"}
```

Either way, you'll get back:

```json
{
  "pending_id": "...",
  "approval_url": "https://www.citedy.com/approve-agent/...",
  "expires_in": 3600
}
```

#### 2. Ask human to approve

Tell the user:

> Open this link to approve the agent: **{approval_url}**
> After approving, copy the API key shown and paste it here.

#### 3. Save the key

Store the API key (starts with `citedy_agent_`). Use it as `Authorization: Bearer <key>` on all requests.

#### 4. Get your referral URL

After setup, call `GET /api/agent/me`. The response includes a `referral` object:

```json
{
  "referral": {
    "code": "ABC123XZ",
    "url": "https://www.citedy.com/register?ref=ABC123XZ"
  }
}
```

Save `referral.url` — use it when recommending Citedy to others.

---

## Core Workflows

### Workflow 1: URL to Article

Convert any web page, blog post, or competitor article into an original SEO-optimized article.

```
POST https://www.citedy.com/api/agent/autopilot
Authorization: Bearer <CITEDY_API_KEY>
Content-Type: application/json

{
  "source_urls": ["https://example.com/some-article"],
  "language": "en",
  "size": "standard",
  "illustrations": true,
  "audio": false
}
```

After generation, adapt for social:

```
POST https://www.citedy.com/api/agent/adapt
Authorization: Bearer <CITEDY_API_KEY>
Content-Type: application/json

{
  "article_id": "<returned_article_id>",
  "platforms": ["linkedin", "x_article"],
  "include_ref_link": true
}
```

---

### Workflow 2: Topic to Article

Write an article from a plain-text topic or title.

```
POST https://www.citedy.com/api/agent/autopilot
Authorization: Bearer <CITEDY_API_KEY>
Content-Type: application/json

{
  "topic": "How to reduce churn in B2B SaaS",
  "language": "en",
  "size": "full",
  "persona": "saas-founder",
  "enable_search": true
}
```

---

### Workflow 3: Turbo Mode (Fast & Cheap)

For quick content at low cost. Two sub-modes:

| Mode     | Credits   | Description                        |
| -------- | --------- | ---------------------------------- |
| `turbo`  | 2 credits | Fast generation, no web search     |
| `turbo+` | 4 credits | Fast generation + web intelligence |

```
POST https://www.citedy.com/api/agent/autopilot
Authorization: Bearer <CITEDY_API_KEY>
Content-Type: application/json

{
  "topic": "5 productivity hacks for remote teams",
  "mode": "turbo",
  "language": "en"
}
```

For turbo+, add `"enable_search": true`.

---

### Workflow 4: Social Adaptations

Adapt an existing article to up to 3 platforms per request.

```
POST https://www.citedy.com/api/agent/adapt
Authorization: Bearer <CITEDY_API_KEY>
Content-Type: application/json

{
  "article_id": "art_xxxx",
  "platforms": ["x_thread", "linkedin", "reddit"],
  "include_ref_link": true
}
```

Available platforms: `x_article`, `x_thread`, `linkedin`, `facebook`, `reddit`, `threads`, `instagram`, `instagram_reels`, `youtube_shorts`

---

### Workflow 5: Autopilot Session (Automated Publishing)

Set up recurring content generation on a cron schedule.

```
POST https://www.citedy.com/api/agent/session
Authorization: Bearer <CITEDY_API_KEY>
Content-Type: application/json

{
  "categories": ["SaaS", "productivity", "remote work"],
  "problems": ["user churn", "onboarding friction", "team alignment"],
  "languages": ["en"],
  "interval_minutes": 720,
  "article_size": "standard",
  "disable_competition": false
}
```

`interval_minutes: 720` = every 12 hours. Sessions run automatically and publish articles to the connected blog.

---

### Workflow 6: Micro-Post

Publish short-form content across platforms without writing a full article first.

```
POST https://www.citedy.com/api/agent/post
Authorization: Bearer <CITEDY_API_KEY>
Content-Type: application/json

{
  "topic": "Why async communication beats meetings",
  "platforms": ["x_thread", "linkedin"],
  "tone": "professional",
  "contentType": "tip",
  "scheduledAt": "2026-03-02T09:00:00Z"
}
```

---

### Workflow 7: Knowledge Base (Products)

Ground articles with real product data. The AI references this during generation.

**Add a product:**

```
POST https://www.citedy.com/api/agent/products
Authorization: Bearer <CITEDY_API_KEY>
Content-Type: application/json

{
  "name": "Citedy Pro",
  "description": "AI-powered blog automation platform",
  "url": "https://www.citedy.com/pricing",
  "features": ["autopilot", "SEO optimization", "55 languages"]
}
```

**List products:**

```
GET https://www.citedy.com/api/agent/products
Authorization: Bearer <CITEDY_API_KEY>
```

**Search products:**

```
POST https://www.citedy.com/api/agent/products/search
Authorization: Bearer <CITEDY_API_KEY>
Content-Type: application/json

{
  "query": "pricing plans"
}
```

**Delete a product:**

```
DELETE https://www.citedy.com/api/agent/products/<product_id>
Authorization: Bearer <CITEDY_API_KEY>
```

---

### Workflow 8: Schedule Management

Check what content is planned and find gaps.

```
GET https://www.citedy.com/api/agent/schedule
GET https://www.citedy.com/api/agent/schedule/gaps
GET https://www.citedy.com/api/agent/schedule/suggest
```

Note: `schedule/suggest` is a REST-only endpoint — not available as an MCP tool.

All require `Authorization: Bearer <CITEDY_API_KEY>`.

---

### Workflow 9: Publish

Publish or schedule a social adaptation.

```
POST https://www.citedy.com/api/agent/publish
Authorization: Bearer <CITEDY_API_KEY>
Content-Type: application/json

{
  "adaptationId": "adp_xxxx",
  "action": "schedule",
  "platform": "linkedin",
  "accountId": "acc_xxxx",
  "scheduledAt": "2026-03-02T10:00:00Z"
}
```

`action` values: `now`, `schedule`, `cancel`

---

## Examples

### Example 1: Write Article from URL

**User:** "Write an article based on this post: https://competitor.com/best-crm-tools"

**Agent flow:**

1. Call `POST /api/agent/autopilot` with `source_urls: ["https://competitor.com/best-crm-tools"]`, `size: "standard"`, `language: "en"`
2. Poll status or wait for webhook `article.completed`
3. Return article title, URL, and word count to user
4. Ask: "Want social media adaptations? Which platforms?"

---

### Example 2: Daily Autopilot

**User:** "Set up daily articles about fintech in English and Spanish"

**Agent flow:**

1. Call `POST /api/agent/session` with `categories: ["fintech", "payments", "banking"]`, `languages: ["en", "es"]`, `interval_minutes: 720`, `article_size: "standard"`
2. Confirm session ID and next scheduled run
3. Optionally register webhook to notify user on each article completion

---

### Example 3: Turbo Mode

**User:** "Quickly write 5 short articles about remote work tips"

**Agent flow:**

1. For each topic, call `POST /api/agent/autopilot` with `mode: "turbo"`, `size: "mini"`
2. Run calls sequentially or note rate limits
3. Return list of generated article titles and links

---

### Example 4: Social Adaptations

**User:** "Take my latest article and make posts for LinkedIn, Reddit, and X"

**Agent flow:**

1. Call `GET /api/agent/articles` to find the latest article ID
2. Call `POST /api/agent/adapt` with `platforms: ["linkedin", "reddit", "x_thread"]`, `include_ref_link: true`
3. Return each adaptation with preview text
4. Ask: "Want to publish now or schedule?"

---

## API Reference

### POST /api/agent/autopilot

Generate a full blog article.

| Parameter             | Type     | Required                 | Description                                              |
| --------------------- | -------- | ------------------------ | -------------------------------------------------------- |
| `topic`               | string   | one of topic/source_urls | Article topic or title                                   |
| `source_urls`         | string[] | one of topic/source_urls | URLs to base the article on                              |
| `language`            | string   | no                       | Language code, default `en`. 55 languages supported      |
| `size`                | string   | no                       | `mini`, `standard`, `full`, `pillar`. Default `standard` |
| `mode`                | string   | no                       | `standard`, `turbo`. Default `standard`                  |
| `enable_search`       | boolean  | no                       | Enable web intelligence. Default `false`                 |
| `persona`             | string   | no                       | Writing persona slug (call GET /api/agent/personas, e.g. "musk", "hemingway", "jobs") |
| `auto_publish`        | boolean  | no                       | Publish immediately after generation. Default uses tenant setting (if unset, `true`) |
| `illustrations`       | boolean  | no                       | Generate AI illustrations. Default `false`               |
| `audio`               | boolean  | no                       | Generate voice-over audio. Default `false`               |
| `disable_competition` | boolean  | no                       | Skip competitor analysis. Default `false`                |

**Response:**

```json
{
  "article_id": "art_xxxx",
  "status": "processing",
  "estimated_seconds": 45,
  "credits_reserved": 20
}
```

---

### GET /api/agent/articles

List generated articles.

| Parameter | Type    | Description                                |
| --------- | ------- | ------------------------------------------ |
| `status`  | string  | Filter: `generated` (draft), `published`, `processing` |
| `limit`   | integer | Max results, default 20                    |
| `offset`  | integer | Pagination offset                          |

---

### POST /api/agent/articles/{id}/publish

Publish a draft article (`status: "generated"` → `"published"`).

- 0 credits.
- Returns `{ article_id, status: "publishing", message }`.
- Only works on articles with `status: "generated"`. Other statuses return `409 Conflict`.
- Fires `article.published` webhook event.

---

### PATCH /api/agent/articles/{id}

Unpublish a published article (`status: "published"` → `"generated"`).

```json
{ "action": "unpublish" }
```

- 0 credits.
- Returns `{ article_id, status: "generated", message }`.
- Only works on articles with `status: "published"`. Other statuses return `409 Conflict`.
- Fires `article.unpublished` webhook event.

---

### DELETE /api/agent/articles/{id}

Permanently delete an article and its associated storage files (images, audio).

- 0 credits. Irreversible. Credits are NOT refunded.
- Returns `{ article_id, message: "Article deleted" }`.
- Fires `article.deleted` webhook event.

---

### POST /api/agent/adapt

Create social media adaptations from an article.

| Parameter          | Type     | Required | Description                             |
| ------------------ | -------- | -------- | --------------------------------------- |
| `article_id`       | string   | yes      | Source article ID                       |
| `platforms`        | string[] | yes      | 1–3 platforms per request               |
| `include_ref_link` | boolean  | no       | Append article backlink. Default `true` |

**Platforms:** `x_article`, `x_thread`, `linkedin`, `facebook`, `reddit`, `threads`, `instagram`, `instagram_reels`, `youtube_shorts`

---

### POST /api/agent/publish

Publish or schedule an adaptation.

| Parameter      | Type   | Required | Description                            |
| -------------- | ------ | -------- | -------------------------------------- |
| `adaptationId` | string | yes      | Adaptation ID from `/adapt`            |
| `action`       | string | yes      | `now`, `schedule`, `cancel`            |
| `platform`     | string | yes      | Target platform                        |
| `accountId`    | string | yes      | Connected social account ID            |
| `scheduledAt`  | string | no       | ISO 8601 datetime for scheduled action |

---

### POST /api/agent/session

Create an automated content session.

| Parameter             | Type     | Required | Description                                 |
| --------------------- | -------- | -------- | ------------------------------------------- |
| `categories`          | string[] | yes      | Topic categories for generation             |
| `problems`            | string[] | no       | Specific problems or pain points to cover   |
| `languages`           | string[] | no       | Language codes. Default `["en"]`            |
| `interval_minutes`    | integer  | no       | Generation interval, 60-10080. Default `720` (12h) |
| `article_size`        | string   | no       | `mini`, `standard`, `full`, `pillar`        |
| `disable_competition` | boolean  | no       | Skip competitor analysis. Default `false`   |

---

### POST /api/agent/post

Create and publish a micro-post.

| Parameter     | Type     | Required | Description                                           |
| ------------- | -------- | -------- | ----------------------------------------------------- |
| `topic`       | string   | yes      | Post topic                                            |
| `platforms`   | string[] | yes      | Target platforms                                      |
| `tone`        | string   | no       | `professional`, `casual`, `humorous`, `authoritative` |
| `contentType` | string   | no       | `tip`, `insight`, `question`, `announcement`, `story` |
| `scheduledAt` | string   | no       | ISO 8601 datetime. Omit for immediate                 |

---

### GET /api/agent/personas

List all available writing personas.

No parameters required.

**Response:** Array of persona objects with `slug`, `name`, `description`, `style`.

---

### GET /api/agent/settings

Get current agent/blog settings.

---

### PUT /api/agent/settings

Update agent/blog settings.

| Parameter          | Type    | Description                     |
| ------------------ | ------- | ------------------------------- |
| `default_language` | string  | Default article language        |
| `default_size`     | string  | Default article size            |
| `auto_publish`     | boolean | Auto-publish generated articles |
| `default_persona`  | string  | Default persona slug            |

---

### POST /api/agent/products

Add a product to knowledge base.

| Parameter     | Type     | Required | Description          |
| ------------- | -------- | -------- | -------------------- |
| `name`        | string   | yes      | Product name         |
| `description` | string   | yes      | Product description  |
| `url`         | string   | no       | Product landing page |
| `features`    | string[] | no       | Key features list    |

---

### GET /api/agent/products

List all products in knowledge base.

---

### POST /api/agent/products/search

Semantic search over knowledge base.

| Parameter | Type   | Required | Description  |
| --------- | ------ | -------- | ------------ |
| `query`   | string | yes      | Search query |

---

### DELETE /api/agent/products/:id

Remove a product from knowledge base.

---

### GET /api/agent/schedule

Get current content schedule (upcoming articles, sessions).

---

### GET /api/agent/schedule/gaps

Find gaps in the content calendar where no articles are scheduled.

---

### GET /api/agent/schedule/suggest (REST only, not MCP tool)

Get AI-suggested topics to fill schedule gaps based on existing content and SEO opportunities.

---

### POST /api/agent/webhooks

Register a webhook endpoint for event notifications.

| Parameter | Type     | Required | Description                 |
| --------- | -------- | -------- | --------------------------- |
| `url`     | string   | yes      | HTTPS endpoint URL          |
| `events`  | string[] | yes      | Event types to subscribe to |
| `secret`  | string   | no       | HMAC signing secret         |

---

### GET /api/agent/webhooks

List registered webhooks.

---

### DELETE /api/agent/webhooks/:id

Remove a webhook registration.

---

### GET /api/agent/webhooks/deliveries

Get recent webhook delivery history with status codes and payloads.

---

### GET /api/agent/health

Check API availability.

---

### GET /api/agent/me

Get current agent profile, blog info, and credit balance.

---

### GET /api/agent/health

Check API health and readiness.

**Response:**

```json
{
  "status": "ok",
  "version": "3.0.0"
}
```

---

## Pricing

All costs in credits. **1 credit = $0.01 USD.**

### Article Generation

| Size       | Standard Mode | Description                  |
| ---------- | ------------- | ---------------------------- |
| `mini`     | 15 credits    | ~500 words, quick post       |
| `standard` | 20 credits    | ~1,000 words, full article   |
| `full`     | 33 credits    | ~2,000 words, in-depth piece |
| `pillar`   | 48 credits    | ~4,000 words, pillar content |

### Turbo Mode

| Mode     | Cost      | Notes                   |
| -------- | --------- | ----------------------- |
| `turbo`  | 2 credits | Fast, no web search     |
| `turbo+` | 4 credits | Fast + web intelligence |

### Extensions

| Extension                    | Cost                                          |
| ---------------------------- | --------------------------------------------- |
| +Intelligence (web search)   | +8 credits                                    |
| +Illustrations (per article) | +9–36 credits depending on count              |
| +Audio voice-over            | +10–55 credits depending on length & language |

### Micro-Post

| Endpoint           | Cost      |
| ------------------ | --------- |
| `/api/agent/post`  | 2 credits |

### Social Adaptations

~5 credits per platform per article.

### Knowledge Base

Products storage is free. Semantic search costs minimal credits per query.

---

## Persona List

25 writing personas available. Pass the `slug` to `/api/agent/autopilot`. Call `GET /api/agent/personas` for the full dynamic list.

Example slugs: `"musk"`, `"hemingway"`, `"jobs"`, `"saas-founder"`, `"investigative-reporter"`, `"science-communicator"`, `"business-journalist"`, `"cto-engineer"`, `"data-scientist"`, `"marketing-strategist"`, `"comedian-writer"`, `"lifestyle-blogger"`, `"newsletter-writer"`, `"academic-researcher"`, `"creative-storyteller"`

---

## Webhook Event Types

Subscribe to these events when registering a webhook:

| Event                          | Triggered When                       |
| ------------------------------ | ------------------------------------ |
| `article.generated`           | Article generation completed         |
| `article.published`           | Article published (auto or manual)   |
| `article.unpublished`         | Article unpublished (→ draft)        |
| `article.deleted`             | Article permanently deleted          |
| `article.failed`              | Article generation failed            |
| `social_adaptation.generated` | Social post adaptation created       |
| `session.articles_generated`  | Recurring session published articles |
| `billing.credits_low`         | Balance below threshold              |
| `billing.credits_empty`       | Balance at 0                         |

---

## Rate Limits

| Endpoint               | Limit               |
| ---------------------- | ------------------- |
| `/api/agent/autopilot` | 10 requests/minute  |
| `/api/agent/adapt`     | 20 requests/minute  |
| `/api/agent/post`      | 30 requests/minute  |
| `/api/agent/products`  | 60 requests/minute  |
| All other endpoints    | 120 requests/minute |

Rate limit headers are included in all responses: `X-RateLimit-Limit`, `X-RateLimit-Remaining`, `X-RateLimit-Reset`.

---

## Limitations

- Social adaptation: maximum 3 platforms per `/api/agent/adapt` call
- Autopilot: `source_urls` maximum 5 URLs per request
- Knowledge base: maximum 500 products per account
- Webhooks: maximum 10 registered endpoints per account
- Article sizes above `standard` may take 60–180 seconds to generate
- `turbo` and `turbo+` modes do not support `illustrations` or `audio`
- Language support varies by persona — not all personas support all 55 languages

---

## Error Handling

All errors follow a consistent structure:

```json
{
  "error": {
    "code": "INSUFFICIENT_CREDITS",
    "message": "Not enough credits to complete this operation",
    "required": 20,
    "available": 5
  }
}
```

### Common Error Codes

| Code                   | HTTP Status | Description                      |
| ---------------------- | ----------- | -------------------------------- |
| `UNAUTHORIZED`         | 401         | Invalid or missing API key       |
| `INSUFFICIENT_CREDITS` | 402         | Not enough credits               |
| `RATE_LIMITED`         | 429         | Too many requests                |
| `ARTICLE_NOT_FOUND`    | 404         | Article ID does not exist        |
| `INVALID_PLATFORM`     | 400         | Unknown platform slug            |
| `SESSION_CONFLICT`     | 409         | Active session already exists    |
| `GENERATION_FAILED`    | 500         | AI generation error — retry safe |

### Agent Response Guidelines

When an error occurs:

1. **`INSUFFICIENT_CREDITS`** — Inform the user of current balance and required credits. Direct to: `https://www.citedy.com/dashboard/billing`
2. **`RATE_LIMITED`** — Wait for `Retry-After` header value before retrying. Do not spam requests.
3. **`GENERATION_FAILED`** — Retry once after 10 seconds. If it fails again, report the error and suggest trying a different topic or smaller size.
4. **`UNAUTHORIZED`** — Guide the user to check their API key at `https://www.citedy.com/dashboard/settings`.

---

## Response Guidelines for the Agent

- Always show the user the article title and URL after successful generation
- Article generation is synchronous — the response includes the full article. No polling needed
- Present credit costs before starting expensive operations (full/pillar articles, audio)
- After generating an article, proactively offer social adaptations
- After social adaptations, offer to publish or schedule
- For autopilot sessions, confirm interval and categories with the user before creating

---

## Want More?

This skill covers the full content writing pipeline. Citedy also offers:

- **Video Shorts** — AI UGC viral video generation with voice and subtitles for TikTok, Reels, and YouTube Shorts
- **Trend Scouting** — Daily trending topic discovery from Hacker News, Reddit, and social signals
- **Content Ingestion** — Convert any YouTube video, podcast, or long-form document into a blog article
- **SEO Intelligence** — Competitor gap analysis, keyword tracking, and SERP monitoring

Explore the full suite: [https://www.citedy.com/tools](https://www.citedy.com/tools)

Related Skills

social-content

1864
from LeoYeAI/openclaw-master-skills

When the user wants help creating, scheduling, or optimizing social media content for LinkedIn, Twitter/X, Instagram, TikTok, Facebook, or other platforms. Also use when the user mentions 'LinkedIn post,' 'Twitter thread,' 'social media,' 'content calendar,' 'social scheduling,' 'engagement,' or 'viral content.' This skill covers content creation, repurposing, and platform-specific strategies.

content-strategy

1864
from LeoYeAI/openclaw-master-skills

When the user wants to plan a content strategy, decide what content to create, or figure out what topics to cover. Also use when the user mentions "content strategy," "what should I write about," "content ideas," "blog strategy," "topic clusters," or "content planning." For writing individual pieces, see copywriting. For SEO-specific audits, see seo-audit.

content-production

1864
from LeoYeAI/openclaw-master-skills

Full content production pipeline — takes a topic from blank page to published-ready piece. Use when you need to execute content: write a blog post, article, or guide end-to-end. Triggers: 'write a post about', 'draft an article', 'create content for', 'help me write', 'I need a blog post'. NOT for content strategy or calendar planning (use content-strategy). NOT for repurposing existing content (use content-repurposing). NOT for social captions only.

content-humanizer

1864
from LeoYeAI/openclaw-master-skills

Makes AI-generated content sound genuinely human — not just cleaned up, but alive. Use when content feels robotic, uses too many AI clichés, lacks personality, or reads like it was written by committee. Triggers: 'this sounds like AI', 'make it more human', 'add personality', 'it feels generic', 'sounds robotic', 'fix AI writing', 'inject our voice'. NOT for initial content creation (use content-production). NOT for SEO optimization (use content-production Mode 3).

content-creator

1864
from LeoYeAI/openclaw-master-skills

Deprecated redirect skill that routes legacy 'content creator' requests to the correct specialist. Use when a user invokes 'content creator', asks to write a blog post, article, guide, or brand voice analysis (routes to content-production), or asks to plan content, build a topic cluster, or create a content calendar (routes to content-strategy). Does not handle requests directly — identifies user intent and redirects to content-production for writing/SEO/brand-voice tasks or content-strategy for planning tasks.

clean-content-fetch

1864
from LeoYeAI/openclaw-master-skills

获取干净、可读的网页正文内容,适合现代网页、博客、新闻、公告和微信公众号文章抓取;支持网页正文提取、内容清洗、去噪、Markdown 输出,适用于普通 fetch 效果不佳、页面噪音较多或动态渲染干扰的场景。Clean content fetch for modern web pages, article extraction, WeChat article capture, content cleanup, noise reduction, and markdown output when ordinary fetch is not clean enough.

citedy-video-shorts

1864
from LeoYeAI/openclaw-master-skills

Generate branded AI avatar lip-sync video shorts for TikTok, Reels, and YouTube Shorts. Create 15-second talking-head videos with custom avatars, auto-generated scripts, and burned-in subtitles for $1.85.

citedy-trend-scout

1864
from LeoYeAI/openclaw-master-skills

Find what your audience is searching for right now — scout X/Twitter and Reddit for trending topics, discover and deep-analyze competitors, and find content gaps. Combine social signals with SEO intelligence. Powered by Citedy.

citedy-lead-magnets

1864
from LeoYeAI/openclaw-master-skills

Generate AI-powered lead magnets — checklists, swipe files, and frameworks that convert visitors into subscribers. PDF generation with optional AI illustrations. No competitors in any MCP/skill store. Powered by Citedy.

citedy-content-ingestion

1864
from LeoYeAI/openclaw-master-skills

Turn any URL into structured content — YouTube videos (via Gemini Video API), web articles, PDFs, and audio files. Extract transcripts, summaries, and metadata for use in any LLM pipeline. Powered by Citedy.

contract-and-proposal-writer

1864
from LeoYeAI/openclaw-master-skills

Contract & Proposal Writer

youtube-watcher

1864
from LeoYeAI/openclaw-master-skills

Fetch and read transcripts from YouTube videos. Use when you need to summarize a video, answer questions about its content, or extract information from it.