tiktok-post
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
- Create account at publora.com/register (free)
- Connect TikTok via OAuth in Publora Dashboard
- Get API key at publora.com/settings/api
- 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
| Plan | Posts/month | Price |
|---|---|---|
| Starter | 15 | Free |
| Pro | 100/account | $2.99/account/month |
| Premium | 500/account | $9.99/account/month |
Platform Limits (API vs Native App)
Critical API limits that differ from native TikTok app:
Video Requirements
| Specification | API Limit | Native App |
|---|---|---|
| Max duration | 10 minutes | 60 minutes |
| Min duration | 3 seconds | 3 seconds |
| Max file size | 4 GB | 4 GB |
| Min frame rate | 23 FPS | 23 FPS |
| Formats | MP4, MOV, WebM | MP4, MOV, WebM |
Caption Limits
| Element | API Limit | Native App |
|---|---|---|
| Caption length | 2,200 characters | 4,000 characters |
| Hashtags | Included in caption count | Included in caption count |
Rate Limits
| Limit | Value |
|---|---|
| Posts per day | 15-20 |
| Videos per minute | Max 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 tofileName: Video file name (e.g., "video.mp4")contentType:video/mp4,video/quicktime, orvideo/webmtype:"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)
| Value | Description |
|---|---|
PUBLIC_TO_EVERYONE |
Anyone can view (default) |
MUTUAL_FOLLOW_FRIENDS |
Only mutual followers |
FOLLOWER_OF_CREATOR |
Only your followers |
SELF_ONLY |
Only you (draft-like) |
Interaction Settings
| Setting | Default | Description |
|---|---|---|
allowComments |
true |
Whether viewers can comment |
allowDuet |
false |
Whether viewers can create Duets |
allowStitch |
false |
Whether viewers can Stitch |
Commercial Content Settings
| Setting | Default | Description |
|---|---|---|
commercialContent |
false |
Is this commercial content? |
brandOrganic |
false |
Organic brand promotion |
brandedContent |
false |
Paid 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
| Format | Recommended | Notes |
|---|---|---|
| MP4 | Yes | Most reliable |
| MOV | Yes | Apple format |
| WebM | Yes | Web format |
| AVI | Accepted by Publora | May be rejected by TikTok |
| MKV | Accepted by Publora | May be rejected by TikTok |
Recommendation: Use MP4 for best compatibility.
Best Practices
Content
- Hook in first 3 seconds: Grab attention immediately
- Optimal length: 15-60 seconds for best engagement
- Trending sounds: Use trending audio when possible
- Hashtag strategy: 3-5 relevant hashtags
Technical
- Vertical video: 9:16 aspect ratio performs best
- High quality: At least 720p resolution
- 23+ FPS: Ensure smooth playback
- 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
| Error | Cause | Solution |
|---|---|---|
unaudited_client_can_only_post_to_private_accounts |
App not approved | Submit app for TikTok review or use SELF_ONLY |
spam_risk_too_many_posts |
Daily limit reached | Wait 24 hours |
duration_check_failed |
Video too long/short | Ensure 3 seconds to 10 minutes |
file_format_check_failed |
Wrong video format | Use MP4, MOV, or WebM |
| "23 FPS required" | Low frame rate | Re-encode video at 23+ FPS |
| "TikTok requires selecting who can view" | Missing viewerSetting | Always include viewerSetting in platformSettings |
More from publora/skills
instagram-post
Post to Instagram with images, carousels, Reels, and Stories via Publora MCP (Business account required)
65threads-post
Create and schedule Threads posts with auto-threading, image carousels, and reply control via Publora MCP
43social-post
Post to YouTube, Facebook Pages, and Mastodon via Publora MCP - unified skill for video and fediverse platforms
35telegram-post
Post to Telegram channels and groups with markdown formatting, media support, and message options via Publora MCP
35x-post
Post to X (Twitter) with auto-threading, images, and videos via Publora MCP
33linkedin-analytics
Analyze LinkedIn performance, track engagement metrics, and manage reactions/comments via Publora MCP
31