Install
openclaw skills install makepost-com-app-growthManage social media across 9 platforms, track App Store analytics, monitor ASO keywords, analyze competitors, and control subscription pricing — all through conversation.
openclaw skills install makepost-com-app-growthMakePost is a growth platform for iOS app developers. Publish to 9 social platforms, track downloads and revenue via App Store Connect, monitor ASO keyword rankings, watch competitor apps, and manage subscription pricing — from one place or from your AI agent.
MAKEPOST_API_KEY=sk_live_your_key_here
All requests use Bearer token:
Authorization: Bearer <MAKEPOST_API_KEY>
MCP endpoint: https://makepost.com/api/mcp/
API docs: https://api.makepost.com
list_videos — List uploaded videos ready for posting.
limit (int, default 50) — Max videos to return.upload_video — Upload a video from a public URL into MakePost.
video_url (string, required) — Public URL to .mp4, .mov, .webm, or .m4v. Max 500MB, max 10 minutes.title (string, required) — Video title.caption (string) — Default caption for publishing. Falls back to title if empty.app_id (string) — App to link to. Accepts app ID, name, or bundle ID. Auto-selects if you have one app.cover_timestamp (float) — Seconds into the video to extract as cover frame (e.g. 5.5).cover_image_url (string) — Public URL to a custom cover image (JPEG/PNG/WebP/GIF, max 10MB). Alternative to cover_timestamp. Accepts any public URL directly — no need to upload the cover image separately first.POST /v1/media/upload-file with multipart form data.list_accounts — List connected social media accounts.
list_account_groups — List account groups with their member accounts.
schedule_post — Schedule a video to one or more social media accounts at a specific time.
video_id (string, required) — Video ID from list_videos.account_ids (list of strings, required) — Account IDs from list_accounts.scheduled_at (string, required) — ISO 8601 datetime (e.g. "2026-03-22T15:00:00").timezone (string) — IANA timezone (e.g. "America/New_York"). Defaults to your account timezone.caption (string) — Post caption. Falls back to video script, then title.list_posts — List your posts, optionally filtered by status.
status (string) — Filter: "scheduled", "published", "failed", "pending", or "processing".limit (int, default 50) — Max posts to return (1-100).cancel_scheduled_post — Cancel a scheduled post before it publishes.
post_id (string, required) — Post ID to cancel.reschedule_scheduled_post — Change when a scheduled post will be published.
post_id (string, required) — Post ID to reschedule.scheduled_at (string, required) — New publish time in ISO 8601.timezone (string) — IANA timezone. Defaults to your account timezone.edit_scheduled_post_caption — Edit the caption of a scheduled post.
post_id (string, required) — Post ID to edit.caption (string, required) — The new caption text.get_publishing_results — Check publishing results for a post.
post_id (string, required) — Post ID to check.publish_content — Create and publish content (text, image, video, or carousel) to one or more accounts.
content_type (string, required) — "text", "image", "video", or "carousel".caption (string, required) — Main post caption. Used for all platforms unless overridden by captions.account_ids (list of strings) — Account IDs to post to. Required unless is_draft=True.media_id (string) — Pre-uploaded media ID (from upload_image or upload_video). Required for image/video/carousel.scheduled_at (string) — ISO 8601 datetime. Omit to publish immediately.timezone (string) — IANA timezone for scheduled_at.is_draft (bool, default false) — Save as draft without publishing. Account IDs and captions are stored for later use.title (string) — Optional title (used by YouTube).app_id (string) — App or project ID to associate content with (from list_apps).captions (dict) — Per-platform caption overrides, e.g. {"linkedin": "Professional version", "x": "Short version"}.group_ids (list of strings) — Account group IDs to resolve to individual accounts (from list_account_groups).tiktok_is_draft (bool, default false) — Send to TikTok as a draft instead of publishing live. The video appears in the user's TikTok drafts for editing before posting.upload_image — Upload an image from a public URL into MakePost.
image_url (string, required) — Public URL to .jpg, .png, .webp, or .gif. Max 20MB.title (string) — Image title.app_id (string) — App to link to. Auto-selects if you have one app.POST /v1/media/upload-file with multipart form data.list_drafts — List your draft posts.
limit (int, default 50) — Max drafts to return (1-100).publish_draft_tool — Publish a draft post (immediately or scheduled).
post_id (string, required) — Draft post ID from list_drafts.account_ids (list of strings) — Account IDs. If omitted, uses accounts stored when the draft was created.scheduled_at (string) — ISO 8601 datetime. Omit for immediate.timezone (string) — IANA timezone.update_draft_tool — Update a draft post's content, accounts, or captions.
post_id (string, required) — Draft post ID.caption (string) — New main caption text.content_type (string) — New content type.media_id (string) — New media ID.account_ids (list of strings) — Updated list of account IDs for this draft.captions (dict) — Updated per-platform caption overrides, e.g. {"x": "Short", "linkedin": "Long"}.delete_draft_tool — Delete a draft post permanently.
post_id (string, required) — Draft post ID to delete.bulk_publish_content — Publish, schedule, or draft up to 20 content items in a single request.
items (list, required) — Array of content items (max 20). Each item has the same fields as publish_content: content_type, caption, account_ids, media_id, scheduled_at, timezone, is_draft, title, app_id, captions, group_ids, tiktok_is_draft.bulk_upload_media — Upload up to 20 images or videos from public URLs in a single request.
items (list, required) — Array of media items (max 20). Each item has: url (string, required), type ("image" or "video", default "image"), title (string), app_id (string).bulk_cancel_posts — Cancel up to 50 scheduled posts in a single request.
post_ids (list of strings, required) — Post IDs to cancel (max 50).bulk_reschedule_posts — Reschedule up to 50 scheduled posts in a single request.
items (list, required) — Array of reschedule items (max 50). Each item has: post_id (string, required), scheduled_at (string, required — ISO 8601 datetime), timezone (string).list_apps — List your apps and projects.
get_app_analytics — Get download and revenue stats for an app over a period.
app_id (string) — App ID, name, or bundle ID. Auto-selects if you have one app.days (int, default 7) — Days of data to return (1-90).net_revenue — Your actual earnings after Apple's 15-30% commission. Use this for "total revenue" or "earnings" questions.gross_revenue — What customers paid before Apple's cut. Only use when specifically asked about gross amounts.active_subscriptions — Peak concurrent subscribers (max across the period, NOT a sum).new_trials — Free trial starts, summed across the period.revenue_currency — ISO 4217 code. Null on days with no data.get_aso_keywords_tool — Get tracked ASO keywords with latest rankings, difficulty, popularity, and 7-day rank change.
app_id (string) — App ID, name, or bundle ID. Auto-selects if you have one app.country (string) — 2-letter country code to filter (e.g. "us", "gb", "de").rank — App Store search position. Lower is better. Null means no rank data.rank_change — Positive = improved (e.g. moved from #10 to #5 = +5). Negative = worsened.difficulty — How hard to rank (0-100).popularity — Search volume indicator (0-100).get_keyword_history — Get full ranking history for a specific tracked keyword over time.
keyword_id (string, required) — Keyword ID from get_aso_keywords_tool.app_id (string) — App ID, name, or bundle ID. Auto-selects if you have one app.get_aso_competitors_tool — Get tracked competitor apps with App Store metadata.
app_id (string) — App ID, name, or bundle ID. Auto-selects if you have one app.search_keyword — Search for an ASO keyword and get cached analysis.
keyword (string, required) — Keyword or phrase to search.country (string, default "us") — 2-letter country code.app_id (string) — App ID, name, or bundle ID. Auto-selects if you have one app.get_aso_score_tool — Check the ASO metadata optimization score for an app.
app_id (string) — App ID, name, or bundle ID. Auto-selects if you have one app.list_subscriptions — List Apple App Store subscription products for an app.
app_id (string) — App ID, name, or bundle ID. Auto-selects if you have one app.id — Internal database ID. Do NOT use with other subscription tools.apple_subscription_id — Apple's numeric ID (e.g. "6757696252"). Use THIS for all pricing tools.get_subscription_prices — Get subscription prices by territory with currency and pending changes.
subscription_id (string, required) — Apple's numeric subscription ID from list_subscriptions (the apple_subscription_id field).territory_code (string) — ISO 3166-1 alpha-3 (e.g. "USA", "GBR", "JPN").app_id (string) — App ID, name, or bundle ID. Auto-selects if you have one app.stage_price_change_tool — Stage a pending price change for a subscription in a specific territory.
subscription_id (string, required) — Apple's numeric subscription ID.territory_code (string, required) — Territory code (e.g. "USA", "GBR").new_price (float, required) — New price in the territory's local currency.app_id (string) — App ID, name, or bundle ID. Auto-selects if you have one app.push_price_changes — Push all staged price changes to App Store Connect.
subscription_id (string, required) — Apple's numeric subscription ID.app_id (string) — App ID, name, or bundle ID. Auto-selects if you have one app.The MCP tools above also have equivalent REST API endpoints at https://api.makepost.com/v1/. Full interactive docs at https://api.makepost.com.
Direct file upload (REST API only — not available via MCP):
POST https://api.makepost.com/v1/media/upload-file
Content-Type: multipart/form-data
Authorization: Bearer <MAKEPOST_API_KEY>
file: <binary> (required) Image or video file
type: "image"|"video"|"cover" (default "image")
title: string (optional)
app_id: string (optional)
REST API: Cover Image Upload — Upload a cover image without creating a media record.
POST /v1/media/upload-file with type: "cover" — returns {"url": "...", "type": "cover"} with no media_id.POST /v1/media/upload with type: "cover" — same, from a public URL.cover_image_url when uploading a video.TikTok, Instagram, YouTube, Facebook, X, LinkedIn, Threads, Pinterest, Bluesky