# Send LinkedIn Content Creation Skill by Reepl to your agent
Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.
## Fast path
- Download the package from Yavira.
- Extract it into a folder your agent can access.
- Paste one of the prompts below and point your agent at the extracted folder.
## Suggested prompts
### New install

```text
I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete.
```
### Upgrade existing

```text
I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run.
```
## Machine-readable fields
```json
{
  "schemaVersion": "1.0",
  "item": {
    "slug": "reepl",
    "name": "LinkedIn Content Creation Skill by Reepl",
    "source": "tencent",
    "type": "skill",
    "category": "开发工具",
    "sourceUrl": "https://clawhub.ai/abhibavishi/reepl",
    "canonicalUrl": "https://clawhub.ai/abhibavishi/reepl",
    "targetPlatform": "OpenClaw"
  },
  "install": {
    "downloadUrl": "/downloads/reepl",
    "sourceDownloadUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=reepl",
    "sourcePlatform": "tencent",
    "targetPlatform": "OpenClaw",
    "packageFormat": "ZIP package",
    "primaryDoc": "SKILL.md",
    "includedAssets": [
      "SKILL.md"
    ],
    "downloadMode": "redirect",
    "sourceHealth": {
      "source": "tencent",
      "slug": "reepl",
      "status": "healthy",
      "reason": "direct_download_ok",
      "recommendedAction": "download",
      "checkedAt": "2026-05-05T00:42:48.645Z",
      "expiresAt": "2026-05-12T00:42:48.645Z",
      "httpStatus": 200,
      "finalUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=reepl",
      "contentType": "application/zip",
      "probeMethod": "head",
      "details": {
        "probeUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=reepl",
        "contentDisposition": "attachment; filename=\"reepl-1.3.1.zip\"",
        "redirectLocation": null,
        "bodySnippet": null,
        "slug": "reepl"
      },
      "scope": "item",
      "summary": "Item download looks usable.",
      "detail": "Yavira can redirect you to the upstream package for this item.",
      "primaryActionLabel": "Download for OpenClaw",
      "primaryActionHref": "/downloads/reepl"
    },
    "validation": {
      "installChecklist": [
        "Use the Yavira download entry.",
        "Review SKILL.md after the package is downloaded.",
        "Confirm the extracted package contains the expected setup assets."
      ],
      "postInstallChecks": [
        "Confirm the extracted package includes the expected docs or setup files.",
        "Validate the skill or prompts are available in your target agent workspace.",
        "Capture any manual follow-up steps the agent could not complete."
      ]
    }
  },
  "links": {
    "detailUrl": "https://openagent3.xyz/skills/reepl",
    "downloadUrl": "https://openagent3.xyz/downloads/reepl",
    "agentUrl": "https://openagent3.xyz/skills/reepl/agent",
    "manifestUrl": "https://openagent3.xyz/skills/reepl/agent.json",
    "briefUrl": "https://openagent3.xyz/skills/reepl/agent.md"
  }
}
```
## Documentation

### LinkedIn Content Creation via Reepl

Full LinkedIn content management through Reepl's MCP integration. Write posts in your authentic voice, schedule content, manage drafts, generate AI images, create carousels, post to Twitter/X, browse your saved content library, and maintain contacts -- all from your AI assistant.

### Prerequisites

Reepl account -- sign up at reepl.io
MCP connection -- connect your account via OAuth (see Setup below)
Gemini API key (optional) -- required only for AI image generation, link at Settings > AI Models

### Setup

# 1. Visit the OAuth page to connect your Reepl account
https://mcp.reepl.io/oauth/authorize

# 2. Log in with your Reepl credentials (Google or email)

# 3. Copy the API key shown after authorization

# 4. Configure the MCP server endpoint
https://mcp.reepl.io/mcp?key=YOUR_API_KEY

If you receive authentication errors at any point, re-authenticate at the URL above.

### Available Tools (31 total)

ToolPurposecreate_draftSave a new LinkedIn post draftget_draftsList and search your draftsupdate_draftEdit an existing draftdelete_draftRemove a draftpublish_to_linkedinPublish a post to LinkedIn immediatelyschedule_postQueue a post for future publishingupdate_scheduled_postChange time, content, or settings of a scheduled postdelete_scheduled_postCancel and delete a scheduled postpublish_nowImmediately publish a scheduled postschedule_draftSchedule an existing draft for publishingget_published_postsView your published LinkedIn postsget_scheduled_postsView your scheduled post queueadd_comment_to_postAdd a comment to a published postget_user_profileGet your Reepl account infoget_voice_profileRead your voice profile (writing style patterns)update_voice_profileUpdate voice profile with learned patternsget_contactsBrowse saved LinkedIn contactsget_listsBrowse your contact listsget_list_contactsGet contacts in a specific listadd_contact_to_listAdd a contact to a listget_collectionsBrowse your saved post collectionsget_saved_postsRead posts from a specific collectionget_templatesBrowse your post templates and ideasgenerate_imageGenerate an AI image for a post (requires Gemini API key)generate_carousel_contentGenerate AI slide content for a carousellist_carousel_draftsList your saved carousel draftsget_carousel_draftFetch a specific carousel draftcreate_carousel_draftSave a new carousel draftupdate_carousel_draftEdit an existing carousel draftdelete_carousel_draftDelete a carousel drafttwitter_create_postCreate or schedule a Twitter/X post or thread

### Content Rules

All LinkedIn content MUST be plain text. Never use markdown formatting like bold, italic, or # headings. LinkedIn does not render markdown -- it will appear literally in the feed, looking AI-generated. Use line breaks, spacing, and natural punctuation for structure instead.

LinkedIn posts have a 3,000 character limit.

### 1. Create Draft

Save a post idea for later editing or publishing.

{
  "content": "Just wrapped up a deep dive into how AI is reshaping B2B sales.\\n\\nHere are 3 things I learned...",
  "title": "AI in B2B Sales",
  "mediaUrls": ["https://example.com/image.jpg"]
}

ParameterRequiredDescriptioncontentYesPost text (plain text only)titleNoDraft title for organizationmediaUrlsNoArray of image URLs to attach

### 2. Get Drafts

List and search your saved drafts.

{
  "search": "AI sales",
  "limit": 10
}

ParameterRequiredDescriptionlimitNoNumber of drafts to return (default: 20)searchNoFilter drafts by keyword

### 3. Update Draft

Edit an existing draft's content, title, or images.

{
  "draft_id": "abc-123",
  "content": "Updated post content here...",
  "title": "New Title"
}

ParameterRequiredDescriptiondraft_idYesID of the draft to updatecontentNoUpdated post texttitleNoUpdated titlemediaUrlsNoUpdated image URLs (replaces existing)

### 4. Delete Draft

{
  "draft_id": "abc-123"
}

ParameterRequiredDescriptiondraft_idYesID of the draft to delete

### 5. Publish to LinkedIn

Publish a post to LinkedIn immediately. This action is irreversible -- always confirm with the user before calling.

{
  "content": "Excited to share that we just hit 10,000 users on Reepl!\\n\\nBuilding in public has been one of the best decisions we made.\\n\\nHere's what I'd tell founders who are hesitant to share their journey...",
  "visibility": "PUBLIC"
}

ParameterRequiredDescriptioncontentYesPost text (plain text only, max 3000 chars)mediaUrlsNoArray of image URLs to includevisibilityNoPUBLIC (default) or CONNECTIONS

### 6. Schedule Post

Queue a post for future publishing. Times are rounded to 15-minute intervals.

{
  "content": "Monday motivation: the best time to start was yesterday. The second best time is now.",
  "scheduledFor": "2026-02-17T08:00:00Z",
  "visibility": "PUBLIC"
}

ParameterRequiredDescriptioncontentYesPost text (plain text only, max 3000 chars)scheduledForYesISO 8601 timestamp (e.g. 2026-02-17T08:00:00Z)mediaUrlsNoArray of image URLsvisibilityNoPUBLIC (default) or CONNECTIONS

Scheduling tips:

Ask the user for their preferred time rather than picking one yourself.
If they want suggestions, recommend varied slots: early morning (7-8 AM), lunch (12-1 PM), or end of day (5-6 PM) in their timezone.
Avoid scheduling all posts at the same time -- spread them for better engagement.

### 7. Update Scheduled Post

Change the time, content, visibility, or images on a post that's already scheduled.

{
  "post_id": "post-456",
  "scheduledFor": "2026-02-18T12:30:00Z",
  "content": "Updated content for the scheduled post..."
}

ParameterRequiredDescriptionpost_idYesID of the scheduled postscheduledForNoNew ISO 8601 timestampcontentNoUpdated post textvisibilityNoUpdated visibilitymediaUrlsNoUpdated image URLs (replaces existing)

### 8. Delete Scheduled Post

Cancel and remove a scheduled post. Only works on posts with status scheduled, failed, or pending_approval. Published posts cannot be deleted this way.

{
  "post_id": "post-456"
}

ParameterRequiredDescriptionpost_idYesID of the scheduled post to delete

### 9. Publish Now

Immediately queue a scheduled post for publishing by rescheduling it to now. The post will be picked up by the scheduler within a few minutes. Only works on scheduled posts.

{
  "post_id": "post-456"
}

ParameterRequiredDescriptionpost_idYesID of the scheduled post to publish immediately

### 10. Schedule Draft

Schedule an existing draft for LinkedIn publishing. Fetches the draft content and creates a new scheduled post. The original draft remains as a draft.

{
  "draft_id": "abc-123",
  "scheduledFor": "2026-02-17T08:00:00Z"
}

ParameterRequiredDescriptiondraft_idYesID of the draft to schedule (use get_drafts to find IDs)scheduledForYesISO 8601 timestamp for when to publish

### 11. Get Published Posts

View the user's published LinkedIn posts. Supports keyword search and pagination.

{
  "limit": 10,
  "search": "AI"
}

ParameterRequiredDescriptionlimitNoNumber of posts to return (default: 20)searchNoFilter posts by keyword (case-insensitive content search)nextTokenNoCursor for pagination -- use the nextToken from a previous response

### 12. Get Scheduled Posts

View posts currently queued for future publishing. Supports status filtering, keyword search, and pagination.

{
  "limit": 10,
  "status": "scheduled"
}

ParameterRequiredDescriptionlimitNoNumber of posts to return (default: 20)statusNoFilter by status: scheduled (default), failed, pending_approval, changes_requestedsearchNoFilter posts by keyword (case-insensitive content search)nextTokenNoCursor for pagination -- use the nextToken from a previous response

### 13. Add Comment to Post

Add a comment to a published LinkedIn post. Some post types (reshares, restricted posts) may reject comments -- this is a LinkedIn limitation.

{
  "post_id": "post-456",
  "comment_text": "Great insights! This resonates with what I've seen in enterprise sales."
}

ParameterRequiredDescriptionpost_idYesThe postId of the published post (from get_published_posts)comment_textYesComment text (plain text only, max 1250 characters)

### 14. Get User Profile

Returns the user's name, email, and LinkedIn URL. No parameters required.

### 15. Get Voice Profile

Read the user's voice profile -- writing style patterns learned from their published posts. No parameters required.

Returns:

userInstructions -- guidelines the user has set (topics to avoid/emphasize, brand keywords, custom rules, writing samples)
generatedProfile -- LLM-learned patterns (tone dimensions, vocabulary preferences, hook styles, structure patterns, anti-patterns)
allowAutoUpdate -- whether the generated profile can be updated automatically
isActive -- whether the voice profile is active

Always read the voice profile before generating content. This is the key to writing posts that sound like the user, not like an AI.

### 16. Update Voice Profile

Update the voice profile with newly learned patterns after analyzing the user's posts.

{
  "generatedProfile": {
    "schema_version": "1.0",
    "tone": { "primary": "conversational-authoritative" },
    "vocabulary": { "signature_phrases": ["here's the thing", "let me break this down"] },
    "structure": { "hook_patterns": [{ "type": "bold-statement" }, { "type": "question" }] },
    "anti_patterns": { "never_do": ["use corporate jargon", "start with 'I'm excited to announce'"] }
  }
}

ParameterRequiredDescriptionallowAutoUpdateNoOnly change if user explicitly requestsisActiveNoToggle voice profile on/offuserInstructionsNoUser-controlled guidelines -- only modify if user explicitly asksgeneratedProfileNoLLM-learned patterns from analyzing posts

Important: Before updating generatedProfile, always check that allowAutoUpdate is true. If the user has locked their profile, do not update it.

### 17. Get Contacts

Browse saved LinkedIn contacts and profiles. Supports pagination.

{
  "search": "product manager",
  "limit": 20
}

ParameterRequiredDescriptionlimitNoNumber of contacts (default: 20)searchNoFilter by name, headline, or keywordnextTokenNoCursor for pagination -- use the nextToken from a previous response

### 18. Get Lists

Browse the user's contact lists (curated groups of contacts).

{
  "search": "leads",
  "limit": 10
}

ParameterRequiredDescriptionsearchNoFilter lists by namelimitNoNumber of lists (default: 20)

### 19. Get List Contacts

Get all contacts in a specific contact list. Use get_lists to find list IDs.

{
  "list_id": "list-123",
  "limit": 20
}

ParameterRequiredDescriptionlist_idYesThe ID of the list to fetch contacts fromlimitNoNumber of contacts (default: 20)nextTokenNoCursor for pagination -- use the nextToken from a previous response

### 20. Add Contact to List

Add an existing contact to a contact list. Use get_contacts to find profile IDs and get_lists to find list IDs.

{
  "profile_id": "profile-abc",
  "list_id": "list-123"
}

ParameterRequiredDescriptionprofile_idYesThe profileID of the contact to addlist_idYesThe ID of the list to add the contact to

### 21. Get Collections

Browse saved post collections (groups of bookmarked LinkedIn posts).

{
  "search": "inspiration",
  "limit": 10
}

ParameterRequiredDescriptionsearchNoFilter collections by namelimitNoNumber of collections (default: 20)

### 22. Get Saved Posts

Read posts from a specific collection. Use get_collections first to find the collection ID.

{
  "collectionID": "col-789",
  "search": "storytelling",
  "limit": 10
}

ParameterRequiredDescriptioncollectionIDYesThe collection to fetch fromlimitNoNumber of posts (default: 20)searchNoFilter posts by keyword

### 23. Get Templates

Browse post templates and content ideas saved in the user's library.

{
  "search": "product launch",
  "limit": 10
}

ParameterRequiredDescriptionlimitNoNumber of templates (default: 20)searchNoFilter by keywordcatalogIDNoFilter by specific catalog

### 24. Generate Image

Generate an AI image for a LinkedIn post using Google Gemini. Requires the user to have linked their Gemini API key in Reepl settings.

{
  "style": "infographic",
  "postContent": "3 ways AI is changing B2B sales in 2026..."
}

ParameterRequiredDescriptionstyleYesImage style (see table below)postContentNoPost content for contextcustomPromptIf style is customYour own image prompt

Available styles:

StyleOutputinfographicProfessional data visuals and chartsminimal-illustrationClean line art illustrationsbold-textTypography and quote cardsscreenshot-social-proofMockup screenshotscomic-storyboardComic-style panelsrealistic-portraitPhotorealistic scenesdiagram-flowchartDiagrams and process flowscustomYour own prompt (requires customPrompt)

Always show the generated image to the user for approval before publishing. Pass the returned URL as mediaUrls when calling publish_to_linkedin or schedule_post.

### 25. Generate Carousel Content

Generate AI slide content for a LinkedIn carousel. Supports plain text topics, YouTube URLs, and article URLs. Returns slide headlines and body text to pass into create_carousel_draft.

Note: the API adds a hook slide and CTA slide automatically, so the actual slide count will be number_of_slides + 2.

{
  "topic": "remote work productivity tips",
  "number_of_slides": 5
}

{
  "url": "https://youtube.com/watch?v=...",
  "number_of_slides": 6
}

ParameterRequiredDescriptiontopicNoTopic or subject for the carousel (use for plain text topics)urlNoYouTube or article URL to extract content fromnumber_of_slidesNoNumber of content slides to generate (1-10, default: 5)

### 26. List Carousel Drafts

List the user's carousel drafts saved in Reepl.

{
  "search": "productivity",
  "limit": 10
}

ParameterRequiredDescriptionsearchNoFilter drafts by titlelimitNoNumber of drafts to return (default: 20)

### 27. Get Carousel Draft

Fetch a single carousel draft by ID, including all slide content, theme, and styling.

{
  "draft_id": "carousel-abc"
}

ParameterRequiredDescriptiondraft_idYesThe draft ID (use list_carousel_drafts to find IDs)

### 28. Create Carousel Draft

Save a new carousel draft in Reepl. Pass slides from generate_carousel_content or write your own. If no theme or colors are specified, your saved brand kit styling is applied automatically.

{
  "title": "5 Remote Work Tips",
  "slides": [
    { "headline": "Stop working from the couch", "body": "Your brain associates spaces with activities. Create a dedicated workspace." },
    { "headline": "Time-block your deep work", "body": "90-minute focus blocks beat 8 hours of fragmented attention every time." }
  ],
  "theme": "3"
}

ParameterRequiredDescriptiontitleYesTitle for this carousel draftslidesYesArray of slides, each with a headline (required) and optional bodythemeNoTheme preset ID ('1' through '22'). Leave unset to use brand kit defaulttitle_font_sizeNoFont size for slide titles: lg, md (default), or smbody_font_sizeNoFont size for slide body text: lg, md (default), or sm

### 29. Update Carousel Draft

Update an existing carousel draft. Only provide the fields you want to change -- unspecified fields are left as-is. Note: providing slides replaces ALL slides in the carousel.

{
  "draft_id": "carousel-abc",
  "title": "Updated Title",
  "slides": [
    { "headline": "New headline", "body": "New body text" }
  ]
}

ParameterRequiredDescriptiondraft_idYesThe ID of the draft to updatetitleNoNew titleslidesNoReplacement slides (replaces ALL existing slides)themeNoNew theme preset ID ('1' through '22')title_font_sizeNolg, md, or smbody_font_sizeNolg, md, or sm

### 30. Delete Carousel Draft

Permanently delete a carousel draft. This cannot be undone.

{
  "draft_id": "carousel-abc"
}

ParameterRequiredDescriptiondraft_idYesThe ID of the carousel draft to delete

### 31. Twitter/X: Create Post

Create or schedule a Twitter/X post or thread. Requires a Twitter account connected in Reepl Settings > Integrations and an active Premium subscription.

For a single tweet, pass an array with one item. For a thread, pass multiple items in order.

{
  "threadTweets": [
    { "index": 0, "text": "I spent 6 months studying how top creators grow on LinkedIn. Here's what actually works (thread):" },
    { "index": 1, "text": "1/ Consistency beats virality. Posting 3x/week for 6 months outperforms a single viral post every time." },
    { "index": 2, "text": "2/ Comments matter more than posts. Thoughtful replies on big accounts drive more followers than original posts." }
  ],
  "scheduledFor": "2026-03-15T14:00:00Z"
}

ParameterRequiredDescriptionthreadTweetsYesArray of tweet objects with index (0-based position) and text (max 280 chars each)scheduledForNoISO 8601 timestamp. If omitted, post is saved as a draft (status: pending)linkedPostIdNoThe postId of a LinkedIn post this thread was cross-posted from

### Pattern 1: Write a Post in the User's Voice

1. get_voice_profile          -- read their writing style
2. Ask user for topic          -- what do they want to write about?
3. Write draft (plain text!)   -- match their tone, hooks, vocabulary
4. Show draft, get feedback    -- iterate until they're happy
5. create_draft OR publish     -- save or go live

### Pattern 2: Schedule a Week of Content

1. get_voice_profile           -- read writing style
2. get_templates               -- browse content ideas
3. get_saved_posts             -- browse inspiration from collections
4. Write 3-5 posts             -- vary topics, hooks, formats
5. schedule_post (x5)          -- spread across Mon-Fri at varied times

### Pattern 3: Repurpose Saved Content

1. get_collections             -- find the right collection
2. get_saved_posts             -- browse posts in it
3. Pick a post, rewrite it     -- new angle, user's voice
4. create_draft or publish     -- save or go live

### Pattern 4: Post with AI-Generated Image

1. Write the post content first
2. generate_image              -- use post content as context
3. Show the image to user      -- get approval
4. publish_to_linkedin         -- pass image URL in mediaUrls

### Pattern 5: Analyze and Update Voice Profile

1. get_published_posts         -- fetch recent posts (limit: 20)
2. Analyze patterns            -- tone, hooks, vocabulary, structure
3. get_voice_profile           -- check if allowAutoUpdate is true
4. update_voice_profile        -- save learned patterns to generatedProfile

### Pattern 6: Create a LinkedIn Carousel

1. Read carousel_guidelines prompt  -- understand content and styling rules
2. generate_carousel_content        -- provide topic or URL
3. Review slides with user          -- adjust if needed
4. create_carousel_draft            -- save with brand kit styling
5. Share the deep link              -- user fine-tunes in Reepl editor
6. update_carousel_draft            -- apply any requested edits

### Pattern 7: Cross-Post to Twitter/X

1. Write or retrieve the LinkedIn post content
2. Adapt for Twitter format           -- split into 280-char chunks for threads
3. twitter_create_post                -- schedule or save as draft
4. Pass linkedPostId if cross-posting -- links the Twitter thread to the LinkedIn post

### Pattern 8: Schedule a Draft

1. get_drafts                  -- find the draft to publish
2. Ask user for preferred time -- or suggest morning/lunch/evening slots
3. schedule_draft              -- pass draft_id and scheduledFor

### Error Handling

ErrorCauseSolutionSession expired or invalidOAuth token expiredRe-authenticate at https://mcp.reepl.io/oauth/authorizeContent exceeds 3000 character limitPost too longShorten the contentdraft_id is requiredMissing draft IDCall get_drafts first to find the IDcollectionID is requiredMissing collection IDCall get_collections first to find the IDGEMINI_NOT_LINKEDNo Gemini API keyUser must link key at https://app.reepl.io/settings/ai-models-apiRate limit exceededToo many requestsWait a moment and retryResource not foundInvalid IDThe draft/post/collection may have been deletedCouldn't comment on this postReshare or restricted postLinkedIn limitation, not a bug -- try a different post

### Best Practices

Always read the voice profile first. Before writing any content, call get_voice_profile to understand the user's writing style. Posts should sound like them, not like an AI.
Plain text only. Never use markdown in post content. No **bold**, no *italic*, no # headings. LinkedIn renders these literally.
Confirm before publishing. Always show the final content and get explicit confirmation before calling publish_to_linkedin, schedule_post, or publish_now. These affect the user's real LinkedIn profile.
Vary scheduling times. Don't default to 9 AM for every post. Ask the user, or suggest varied slots across mornings, lunch, and end of day.
Never fabricate data. Don't invent engagement metrics, analytics, or post performance numbers. Only report what the API returns.
Respect voice profile locks. If allowAutoUpdate is false, do not modify generatedProfile. The user has intentionally locked their voice profile.
Use the library. Before writing from scratch, check templates and saved posts for inspiration. The user has curated these for a reason.
Read carousel guidelines before creating carousels. Call the carousel_guidelines prompt to understand content rules and the slide structure before generating or saving carousel content.

### See Also

Reepl -- AI-powered LinkedIn content management platform
Reepl Help Center -- Documentation and guides
MCP Setup Guide -- Connect your Reepl account to Claude
Reepl Chrome Extension -- AI writing assistant for LinkedIn
## Trust
- Source: tencent
- Verification: Indexed source record
- Publisher: abhibavishi
- Version: 1.3.1
## Source health
- Status: healthy
- Item download looks usable.
- Yavira can redirect you to the upstream package for this item.
- Health scope: item
- Reason: direct_download_ok
- Checked at: 2026-05-05T00:42:48.645Z
- Expires at: 2026-05-12T00:42:48.645Z
- Recommended action: Download for OpenClaw
## Links
- [Detail page](https://openagent3.xyz/skills/reepl)
- [Send to Agent page](https://openagent3.xyz/skills/reepl/agent)
- [JSON manifest](https://openagent3.xyz/skills/reepl/agent.json)
- [Markdown brief](https://openagent3.xyz/skills/reepl/agent.md)
- [Download page](https://openagent3.xyz/downloads/reepl)