tiktok-automation
Automate TikTok tasks via Rube MCP (Composio): upload/publish videos, post photos, manage content, and view user profiles/stats. Always search tools first for current schemas.
What this skill does
# TikTok Automation via Rube MCP Automate TikTok content creation and profile operations through Composio's TikTok toolkit via Rube MCP. ## Prerequisites - Rube MCP must be connected (RUBE_SEARCH_TOOLS available) - Active TikTok connection via `RUBE_MANAGE_CONNECTIONS` with toolkit `tiktok` - Always call `RUBE_SEARCH_TOOLS` first to get current tool schemas ## Setup **Get Rube MCP**: Add `https://rube.app/mcp` as an MCP server in your client configuration. No API keys needed — just add the endpoint and it works. 1. Verify Rube MCP is available by confirming `RUBE_SEARCH_TOOLS` responds 2. Call `RUBE_MANAGE_CONNECTIONS` with toolkit `tiktok` 3. If connection is not ACTIVE, follow the returned auth link to complete TikTok OAuth 4. Confirm connection status shows ACTIVE before running any workflows ## Core Workflows ### 1. Upload and Publish a Video **When to use**: User wants to upload a video and publish it to TikTok **Tool sequence**: 1. `TIKTOK_UPLOAD_VIDEO` or `TIKTOK_UPLOAD_VIDEOS` - Upload video file(s) [Required] 2. `TIKTOK_FETCH_PUBLISH_STATUS` - Check upload/processing status [Required] 3. `TIKTOK_PUBLISH_VIDEO` - Publish the uploaded video [Required] **Key parameters for upload**: - `video`: Video file object with `s3key`, `mimetype`, `name` - `title`: Video title/caption **Key parameters for publish**: - `publish_id`: ID returned from upload step - `title`: Video caption text - `privacy_level`: 'PUBLIC_TO_EVERYONE', 'MUTUAL_FOLLOW_FRIENDS', 'FOLLOWER_OF_CREATOR', 'SELF_ONLY' - `disable_duet`: Disable duet feature - `disable_stitch`: Disable stitch feature - `disable_comment`: Disable comments **Pitfalls**: - Video upload and publish are TWO separate steps; upload first, then publish - After upload, poll FETCH_PUBLISH_STATUS until processing is complete before publishing - Video must meet TikTok requirements: MP4/WebM format, max 10 minutes, max 4GB - Caption/title has character limits; check current TikTok guidelines - Privacy level strings are case-sensitive and must match exactly - Processing may take 30-120 seconds depending on video size ### 2. Post a Photo **When to use**: User wants to post a photo to TikTok **Tool sequence**: 1. `TIKTOK_POST_PHOTO` - Upload and post a photo [Required] 2. `TIKTOK_FETCH_PUBLISH_STATUS` - Check processing status [Optional] **Key parameters**: - `photo`: Photo file object with `s3key`, `mimetype`, `name` - `title`: Photo caption text - `privacy_level`: Privacy setting for the post **Pitfalls**: - Photo posts are a newer TikTok feature; availability may vary by account type - Supported formats: JPEG, PNG, WebP - Image size and dimension limits apply; check current TikTok guidelines ### 3. List and Manage Videos **When to use**: User wants to view their published videos **Tool sequence**: 1. `TIKTOK_LIST_VIDEOS` - List user's published videos [Required] **Key parameters**: - `max_count`: Number of videos to return per page - `cursor`: Pagination cursor for next page **Pitfalls**: - Only returns the authenticated user's own videos - Response includes video metadata: id, title, create_time, share_url, duration, etc. - Pagination uses cursor-based approach; check for `has_more` and `cursor` in response - Recently published videos may not appear immediately in the list ### 4. View User Profile and Stats **When to use**: User wants to check their TikTok profile info or account statistics **Tool sequence**: 1. `TIKTOK_GET_USER_PROFILE` - Get full profile information [Required] 2. `TIKTOK_GET_USER_STATS` - Get account statistics [Optional] 3. `TIKTOK_GET_USER_BASIC_INFO` - Get basic user info [Alternative] **Key parameters**: (no required parameters; returns data for authenticated user) **Pitfalls**: - Profile data is for the authenticated user only; cannot view other users' profiles - Stats include follower count, following count, video count, likes received - `GET_USER_PROFILE` returns more details than `GET_USER_BASIC_INFO` - Stats may have slight delays; not real-time ### 5. Check Publish Status **When to use**: User wants to check the status of a content upload or publish operation **Tool sequence**: 1. `TIKTOK_FETCH_PUBLISH_STATUS` - Poll for status updates [Required] **Key parameters**: - `publish_id`: The publish ID from a previous upload/publish operation **Pitfalls**: - Status values include processing, success, and failure states - Poll at reasonable intervals (5-10 seconds) to avoid rate limits - Failed publishes include error details in the response - Content moderation may cause delays or rejections after processing ## Common Patterns ### Video Publish Flow ``` 1. Upload video via TIKTOK_UPLOAD_VIDEO -> get publish_id 2. Poll TIKTOK_FETCH_PUBLISH_STATUS with publish_id until complete 3. If status is ready, call TIKTOK_PUBLISH_VIDEO with final settings 4. Optionally poll status again to confirm publication ``` ### Pagination - Use `cursor` from previous response for next page - Check `has_more` boolean to determine if more results exist - `max_count` controls page size ## Known Pitfalls **Content Requirements**: - Videos: MP4/WebM, max 4GB, max 10 minutes - Photos: JPEG/PNG/WebP - Captions: Character limits vary by region - Content must comply with TikTok community guidelines **Authentication**: - OAuth tokens have scopes; ensure video.upload and video.publish are authorized - Tokens expire; re-authenticate if operations fail with 401 **Rate Limits**: - TikTok API has strict rate limits per application - Implement exponential backoff on 429 responses - Upload operations have daily limits **Response Parsing**: - Response data may be nested under `data` or `data.data` - Parse defensively with fallback patterns - Publish IDs are strings; use exactly as returned ## Quick Reference | Task | Tool Slug | Key Params | |------|-----------|------------| | Upload video | TIKTOK_UPLOAD_VIDEO | video, title | | Upload multiple videos | TIKTOK_UPLOAD_VIDEOS | videos | | Publish video | TIKTOK_PUBLISH_VIDEO | publish_id, title, privacy_level | | Post photo | TIKTOK_POST_PHOTO | photo, title, privacy_level | | List videos | TIKTOK_LIST_VIDEOS | max_count, cursor | | Get profile | TIKTOK_GET_USER_PROFILE | (none) | | Get user stats | TIKTOK_GET_USER_STATS | (none) | | Get basic info | TIKTOK_GET_USER_BASIC_INFO | (none) | | Check publish status | TIKTOK_FETCH_PUBLISH_STATUS | publish_id | ## When to Use This skill is applicable to execute the workflow or actions described in the overview. ## Limitations - Use this skill only when the task clearly matches the scope described above. - Do not treat the output as a substitute for environment-specific validation, testing, or expert review. - Stop and ask for clarification if required inputs, permissions, safety boundaries, or success criteria are missing.
Related in Ads & Marketing
ads
IncludedMulti-platform paid advertising audit and optimization skill. Analyzes Google, Meta, YouTube, LinkedIn, TikTok, Microsoft, and Apple Ads. 250+ checks with scoring, parallel agents, industry templates, and AI creative generation.
banana
IncludedAI image generation Creative Director powered by Google Gemini Nano Banana models. Use this skill for ANY request involving image creation, editing, visual asset production, or creative direction. Triggers on: generate an image, create a photo, edit this picture, design a logo, make a banner, visual for my anything, and all /banana commands. Handles text-to-image, image editing, multi-turn creative sessions, batch workflows, and brand presets.
rpg-migration-analyzer
IncludedAnalyzes legacy RPG (Report Program Generator) programs from AS/400 and IBM i systems for migration to modern Java applications. Extracts business logic from RPG III/IV/ILE source code, identifies data structures (D-specs), file operations (F-specs), program dependencies (CALLB/CALLP), and converts RPG constructs to Java equivalents. Generates migration reports, complexity estimates, and Java implementation strategies with POJO classes, JPA entities, and service methods. Use when modernizing AS/400 or IBM i legacy systems, analyzing RPG source files (.rpg, .rpgle, .RPGLE), converting RPG to Java, mapping data specifications to Java classes, planning legacy system migration, or when user mentions RPG analysis, Report Program Generator, RPG III/IV/ILE, AS/400 modernization, IBM i migration, packed decimal conversion, or mainframe application rewrite.
brand-library-architect
IncludedBuild a complete brand library for a product — visual asset render pipeline, brand documentation set (BRAND, COPY, MANIFESTO, BIOS, FAQ, GLOSSARY, TONE, PRICING), open-source convention files (README, CONTRIBUTING, SECURITY, CODE_OF_CONDUCT), and a self-contained press kit. This skill should be used when the user asks to "build a brand library / brand kit / press kit / brand assets" for a product, "set up a brand library workflow," "create a positioning manifesto plus visual identity," or any combination of brand documentation + visual asset pipeline. Apply phase-by-phase or run end-to-end. Templates are product-agnostic and use {{TOKEN}} placeholders the skill prompts the user to fill.
writing-tech-post
IncludedAuthors engineering blog posts end-to-end: launch deep-dives, incident postmortems, architecture migrations, performance case studies, tutorials, AI/agent system writeups, security disclosures, and research-to-product translations. Picks the correct archetype, plans the abstraction ladder, enforces an evidence cadence (diagrams, benchmarks, profiles, traces, code, ablations), tunes voice against publisher house styles (Datadog, Vercel, GitHub, AWS, Meta, Cloudflare, Jane Street), and runs a pre-publish gate for narrative momentum and disclosure ethics. Use when drafting a new engineering post, restructuring a draft that feels flat, deciding which evidence form belongs where, validating that depth and product context are balanced, or preparing a postmortem, migration, or performance narrative for external publication. Do not use for API reference documentation, README authoring, marketing copy, release notes, generic SEO content, ghost-written executive thought leadership, or non-engineering long-form essays.
blog-google
IncludedGoogle API integration for blog performance: PageSpeed Insights, CrUX Core Web Vitals with 25-week history, Search Console performance, URL Inspection, Indexing API, GA4 organic traffic, NLP entity analysis for E-E-A-T, YouTube video search for embedding, and Google Ads Keyword Planner. Progressive feature availability based on credential tier (API key, OAuth/service account, GA4, Ads). Shares config with claude-seo at ~/.config/claude-seo/google-api.json. Use when user says "google data", "page speed", "core web vitals", "search console", "indexation", "GA4", "keyword research", "nlp entities", "blog performance", "youtube search", "google api setup".