tiktok-post

Installation

$npx skills add publora/skills --skill tiktok-post

Summary

Enable agents to upload, schedule, and configure TikTok videos with granular control over privacy, comments, duets, stitches, and commercial content disclosure. Use this to post content to TikTok accounts connected via Publora, respecting platform limits (10 min videos, 2,200 char captions) and TikTok's auditing requirements.

SKILL.MD

TikTok Post

Upload and schedule videos to TikTok using the Publora MCP server. Supports privacy controls, interaction settings (comments, duet, stitch), and commercial content disclosure.

Prerequisites

Plans: Free Starter (15 posts/month), Pro, Premium

Getting Started

  1. Create account at publora.com/register (free)
  2. Connect TikTok via OAuth in Publora Dashboard
  3. Get API key at publora.com/settings/api
  4. Configure MCP in Claude Desktop (~/.claude/claude_desktop_config.json):
{
  "mcpServers": {
    "publora": {
      "type": "http",
      "url": "https://mcp.publora.com",
      "headers": {
        "Authorization": "Bearer YOUR_API_KEY"
      }
    }
  }
}

REST API Fallback

If the MCP server is unavailable or returns errors, use the REST API directly:

Base URL: https://api.publora.com/api/v1

Authentication: Use x-publora-key header (NOT Authorization: Bearer):

# Get your connected platforms
curl -X GET "https://api.publora.com/api/v1/platform-connections" \
  -H "x-publora-key: sk_your_api_key"

# Create a post
curl -X POST "https://api.publora.com/api/v1/create-post" \
  -H "x-publora-key: sk_your_api_key" \
  -H "Content-Type: application/json" \
  -d '{
    "platforms": ["tiktok-99887766"],
    "content": "Video caption here #hashtag",
    "scheduledTime": "2026-03-25T10:00:00Z",
    "platformSettings": {
      "tiktok": {
        "viewerSetting": "PUBLIC_TO_EVERYONE",
        "allowComments": true
      }
    }
  }'

Platform ID Format: tiktok-{id} where {id} is from /platform-connections response.

Example IDs: tiktok-99887766, tiktok-123456789

📖 Full API documentation: docs.publora.com

Plan Limits

PlanPosts/monthPrice
Starter15Free
Pro100/account$2.99/account/month
Premium500/account$9.99/account/month

Platform Limits (API vs Native App)

Critical API limits that differ from native TikTok app:

Video Requirements

SpecificationAPI LimitNative App
Max duration10 minutes60 minutes
Min duration3 seconds3 seconds
Max file size4 GB4 GB
Min frame rate23 FPS23 FPS
FormatsMP4, MOV, WebMMP4, MOV, WebM

Caption Limits

ElementAPI LimitNative App
Caption length2,200 characters4,000 characters
HashtagsIncluded in caption countIncluded in caption count

Rate Limits

LimitValue
Posts per day15-20
Videos per minuteMax 2

Available Tools

create_post

Create a new TikTok post.

Parameters:

  • platforms: Array with your TikTok connection ID (e.g., ["tiktok-99887766"])
  • content: Video caption (up to 2,200 characters)
  • scheduledTime: ISO 8601 datetime (required - for immediate posting, use current time + 1 minute)

get_upload_url

Get presigned URL for video upload.

Parameters:

  • postGroupId: Post ID to attach video to
  • fileName: Video file name (e.g., "video.mp4")
  • contentType: video/mp4, video/quicktime, or video/webm
  • type: "video"

list_posts / update_post / delete_post

Manage scheduled and draft posts.

Platform Settings (via REST API)

TikTok has 7 platform-specific settings controlled via platformSettings:

{
  "platformSettings": {
    "tiktok": {
      "viewerSetting": "PUBLIC_TO_EVERYONE",
      "allowComments": true,
      "allowDuet": false,
      "allowStitch": false,
      "commercialContent": false,
      "brandOrganic": false,
      "brandedContent": false
    }
  }
}

Viewer Settings (Required)

ValueDescription
PUBLIC_TO_EVERYONEAnyone can view (default)
MUTUAL_FOLLOW_FRIENDSOnly mutual followers
FOLLOWER_OF_CREATOROnly your followers
SELF_ONLYOnly you (draft-like)

Interaction Settings

SettingDefaultDescription
allowCommentstrueWhether viewers can comment
allowDuetfalseWhether viewers can create Duets
allowStitchfalseWhether viewers can Stitch

Commercial Content Settings

SettingDefaultDescription
commercialContentfalseIs this commercial content?
brandOrganicfalseOrganic brand promotion
brandedContentfalsePaid partnership/sponsored

Note: If commercialContent is true, at least one of brandOrganic or brandedContent must also be true.

Note: platformSettings is not available via MCP - use REST API for these settings.

Critical Restrictions

1. Unaudited Apps = PRIVATE Only

CRITICAL: If your TikTok app hasn't passed TikTok's review process, you can ONLY post PRIVATE videos (SELF_ONLY). All other viewerSetting values will be overridden to SELF_ONLY.

To post public videos, your app must be audited by TikTok.

2. Video Only Platform

TikTok does NOT support:

  • Text-only posts
  • Image posts
  • Photo carousels

Every post must include a video.

3. Minimum 23 FPS

Videos below 23 frames per second will be rejected by TikTok.

Examples

Basic Video Post

Post this video to TikTok:
"How we built our startup in 60 seconds #startup #tech #coding"

Private Draft (Testing)

Upload this video as a private draft to TikTok (only I can see it):
"Testing new content format"

Use viewerSetting: "SELF_ONLY" for testing before making public.

Branded Content

Post this sponsored video to TikTok with proper disclosure:
"Loving this new product from @brand! #ad #sponsored"

Set commercialContent: true and brandedContent: true for paid partnerships.

Scheduled Post

Schedule this TikTok video for tomorrow at 6 PM:
"Weekend vibes incoming! #weekend #fun"

Supported Video Formats

FormatRecommendedNotes
MP4YesMost reliable
MOVYesApple format
WebMYesWeb format
AVIAccepted by PubloraMay be rejected by TikTok
MKVAccepted by PubloraMay be rejected by TikTok

Recommendation: Use MP4 for best compatibility.

Best Practices

Content

  1. Hook in first 3 seconds: Grab attention immediately
  2. Optimal length: 15-60 seconds for best engagement
  3. Trending sounds: Use trending audio when possible
  4. Hashtag strategy: 3-5 relevant hashtags

Technical

  1. Vertical video: 9:16 aspect ratio performs best
  2. High quality: At least 720p resolution
  3. 23+ FPS: Ensure smooth playback
  4. MP4 format: Most reliable format

Timing

  • Best times: 7-9 AM, 12-3 PM, 7-11 PM in target timezone
  • Frequency: 1-3 posts per day for growth
  • Consistency: Regular posting schedule helps algorithm

Troubleshooting

ErrorCauseSolution
unaudited_client_can_only_post_to_private_accountsApp not approvedSubmit app for TikTok review or use SELF_ONLY
spam_risk_too_many_postsDaily limit reachedWait 24 hours
duration_check_failedVideo too long/shortEnsure 3 seconds to 10 minutes
file_format_check_failedWrong video formatUse MP4, MOV, or WebM
"23 FPS required"Low frame rateRe-encode video at 23+ FPS
"TikTok requires selecting who can view"Missing viewerSettingAlways include viewerSetting in platformSettings