AI Skill
Review
Audit score 70

lipsync

agentspace-so/runcomfy-agent-skills

Sync audio to a face's mouth across multiple AI models via RunComfy CLI.

What is lipsync?

Lip-sync a face to an audio track by routing to the best model for your intent: Sync Labs for mouth-swap on existing video, OmniHuman for avatar-style talking heads from a portrait, Kling for text-to-video with synced speech, or Creatify. The skill picks the right endpoint and generates the exact runcomfy CLI command.

  • Route to Sync Labs sync v2/Pro for state-of-the-art mouth-swap on existing video
  • Generate talking-head avatars from a portrait + audio using ByteDance OmniHuman
  • Sync lips to video using Kling lipsync (audio-to-video or text-to-video modes)
  • Support Creatify lipsync as an alternative endpoint
  • Match audio length and quality to video for optimal sync results

How to install lipsync

npx skills add https://github.com/agentspace-so/runcomfy-agent-skills --skill lipsync
Prerequisites
  • RunComfy CLI installed (npm i -g @runcomfy/cli)
  • RunComfy account and authentication token (runcomfy login)
  • Source video URL and audio URL (for mouth-swap routes) or portrait URL (for avatar routes)
Claude Code
Cursor
Windsurf
Cline

How to use lipsync

  1. 1.Identify your intent: mouth-swap on existing video, avatar from portrait, or generate-and-sync from script
  2. 2.Choose the appropriate model: Sync Labs v2/Pro for video+audio, OmniHuman for portrait+audio, Kling text-to-video for script-only
  3. 3.Prepare your inputs: ensure audio quality is clean (voice-only, no music bed) and matches video duration
  4. 4.Run the runcomfy command with the model path and input URLs
  5. 5.Check output directory for the synced video result

Use cases

Good for
  • Dub foreign-language video with precise mouth sync for professional delivery
  • Create a virtual presenter or product demo by driving a portrait with voiceover audio
  • Generate a talking-head video from a script without pre-recorded audio
  • Batch lip-sync jobs across multiple videos at scale
  • Preserve original video framing and body motion while replacing only mouth movement
Who it's for
  • Video producers and dubbing specialists
  • Content creators making UGC or social media clips
  • Localization teams adding foreign-language voiceovers
  • Marketing teams creating product demos with virtual presenters
  • Developers integrating lip-sync into media pipelines

lipsync FAQ

Which model should I use for dubbing an existing video?

Use Sync Labs sync v2 Pro for hero-quality dubs with state-of-the-art mouth fidelity, or sync v2 for cost-sensitive batch jobs. Kling lipsync audio-to-video is an alternative if you're already in the Kling ecosystem.

How do I create a talking-head video from just a portrait?

Use OmniHuman (bytedance/omnihuman/api) with a portrait image URL and audio URL. The model derives all motion and gestures from the audio automatically.

What if I only have a script, not a pre-recorded audio file?

Use Kling lipsync text-to-video or HappyHorse 1.0 text-to-video, which generate speech audio in-pass from your script and sync it to the video.

How do I ensure good lip-sync quality?

Match audio length to video length, use clean voiceover audio (isolate voice stem if needed to remove music bed), and choose the right model tier for your quality requirements.

Can I use this to create deepfakes of real people?

The skill does not gate inputs, but you must refuse requests targeting real public figures without consent or aiming at defamatory or sexually explicit synthetic media. The responsibility rests with the operator.

Full instructions (SKILL.md)

Source of truth, from agentspace-so/runcomfy-agent-skills.


name: lipsync allowed-tools: Bash(runcomfy *) displayName: "Lipsync" description: > Lip-sync a face to a specific audio track on RunComfy via the runcomfy CLI. Routes across ByteDance OmniHuman (audio-driven full-body avatar from a portrait + audio), Sync Labs sync v2 / Pro (state-of-the-art mouth sync onto a video), Kling lipsync (audio-to- video and text-to-video with synced speech), and Creatify lipsync. The skill picks the right endpoint for the user's actual intent — portrait still + audio (avatar-style), source video + audio (mouth- swap on existing footage), or generate-and-sync from a script. Triggers on "lip sync", "lipsync", "make this video speak", "match audio to mouth", "dub video", "sync lips to voice", "Sync Labs", "voiceover sync", or any explicit ask to drive a face's mouth from an audio track. homepage: https://www.runcomfy.com license: MIT

Lipsync

Drive a face's mouth from an audio track. This skill routes across the lip-sync endpoints in the RunComfy catalog — OmniHuman, Sync Labs sync v2, Kling lipsync, Creatify — picking the right model for the user's actual intent and shipping the documented prompts + the exact runcomfy run invoke.

runcomfy.com · Sync Labs models · CLI docs

Powered by the RunComfy CLI

# 1. Install (see runcomfy-cli skill for details)
npm i -g @runcomfy/cli      # or:  npx -y @runcomfy/cli --version

# 2. Sign in
runcomfy login              # or in CI: export RUNCOMFY_TOKEN=<token>

# 3. Lipsync
runcomfy run <vendor>/<model> \
  --input '{"video_url": "...", "audio_url": "..."}' \
  --output-dir ./out

CLI deep dive: runcomfy-cli skill.

Consent

Driving a real person's mouth from a separate audio track is dual-use. Refuse user requests that target real public figures without consent, or that aim at defamatory or sexually explicit synthetic media. The skill itself does not gate inputs — the responsibility rests with the operator.


Pick the right model

Listed newest first within each subtype. The agent picks one route based on: input shape (portrait still + audio vs source video + audio vs script-only), quality tier, and budget.

Source video + audio → lip-synced video (mouth-swap on existing footage)

Sync Labs sync v2 Prosync/sync/lipsync/v2/pro (default for premium)

Sync Labs' premium lip-sync — state-of-the-art mouth motion onto an existing video. Preserves the rest of the frame untouched. Pick for: hero-quality dubs, lipsync on professionally-shot video, foreign-language dubbing where mouth fidelity matters most. Avoid for: cost-sensitive batch jobs — drop to sync v2.

Sync Labs sync v2sync/sync/lipsync/v2

Standard Sync Labs tier, same workflow as Pro. Pick for: scaled / batch lipsync jobs, drafts. Avoid for: hero delivery — use v2 Pro.

Kling Lipsync (audio-to-video)kling/lipsync/audio-to-video

Kling's lip-sync onto a source video, driven by an audio track. Pick for: Kling-pipeline integration; alternative to Sync Labs. Avoid for: top-tier mouth fidelity — Sync Labs Pro is the industry benchmark.

Creatify Lipsynccreatify/lipsync

Creatify's lipsync endpoint. Pick for: Creatify-ecosystem workflows. Avoid for: comparison shopping unless cost / latency favors it.

Portrait still + audio → talking-head video (avatar-style)

OmniHumanbytedance/omnihuman/api (default for avatar-style)

ByteDance's audio-driven full-body avatar. One portrait + one audio → video where the subject speaks / gestures naturally. Listed under RunComfy's /feature/lip-sync as the curated default. Pick for: UGC voiceover, virtual presenter, dubbed product demo from a single portrait. Avoid for: lip-sync onto an existing video (no portrait, want to preserve original motion) — use Sync Labs v2 instead.

Wan 2-7 with audio_urlwan-ai/wan-2-7/text-to-video

Open-weights t2v with audio_url field — prompt describes the scene, audio drives the mouth. Pick for: full scene control (not just a portrait) with a specific voiceover MP3 + open-weights pipeline. Avoid for: simplest "portrait talks" — use OmniHuman.

Generate-and-sync from a script (no audio file available)

Kling Lipsync (text-to-video)kling/lipsync/text-to-video

Generates speech audio in-pass from a script and syncs it to the resulting video. Pick for: "write a script → get a video with synced speech", no audio file needed. Avoid for: precise lip-sync to a specific MP3 (audio is regenerated each call, not locked).

HappyHorse 1.0happyhorse/happyhorse-1-0/text-to-video (also /image-to-video)

Arena #1 t2v / i2v with in-pass audio generated from prompt. Quote the spoken line inside the prompt with says clearly: "…". Pick for: written script, in-pass audio with strong overall quality, social/UGC clips. Avoid for: locking mouth to a pre-recorded voiceover.


Route 1: Sync Labs sync v2 / Pro — default for mouth-swap

Model: sync/sync/lipsync/v2/pro (or sync/sync/lipsync/v2) Catalog: sync v2 Pro · sync v2

Invoke

runcomfy run sync/sync/lipsync/v2/pro \
  --input '{
    "video_url": "https://your-cdn.example/source-video.mp4",
    "audio_url": "https://your-cdn.example/voiceover.mp3"
  }' \
  --output-dir ./out

Tips

  • Source video provides everything except the mouth — camera, lighting, background, body pose all preserved.
  • Audio quality drives mouth quality. Clean voiceover (no music bed) → cleaner sync. Isolate voice stem if needed.
  • Match audio length to video length. Significant audio/video duration mismatch leads to drift; trim audio or extend video first.
  • Schema details on the model page.

Route 2: OmniHuman — default for avatar from still

Model: bytedance/omnihuman/api Catalog: omnihuman

Invoke

runcomfy run bytedance/omnihuman/api \
  --input '{
    "image_url": "https://your-cdn.example/portrait.jpg",
    "audio_url": "https://your-cdn.example/voiceover.mp3"
  }' \
  --output-dir ./out

Tips

  • Portrait framing works best — head-and-shoulders or upper body.
  • No prompt — the model derives everything from image + audio. Don't fight that.
  • See the ai-avatar-video skill for the full avatar treatment.

Route 3: Kling Lipsync — Kling-ecosystem mouth sync

Model: kling/lipsync/audio-to-video (existing video + audio) or kling/lipsync/text-to-video (script-only) Catalog: Kling lipsync a2v · Kling lipsync t2v

Invoke (audio-to-video variant)

runcomfy run kling/lipsync/audio-to-video \
  --input '{
    "video_url": "https://your-cdn.example/source-video.mp4",
    "audio_url": "https://your-cdn.example/voiceover.mp3"
  }' \
  --output-dir ./out

Schema details on the model page.


Common patterns

Foreign-language dub of an existing brand video

  • Route 1 (Sync Labs sync v2 Pro) with the original video + translated voiceover MP3.

UGC ad creator from a portrait

  • Route 2 (OmniHuman) with the creator's portrait + product-pitch voiceover.

Multi-language launch (same identity, many languages)

  • Route 2 (OmniHuman) with one portrait + N different audio files. Same identity holds across all dubs.

"I have a script but no audio"

  • Kling Lipsync (text-to-video) or HappyHorse 1.0 t2v — both generate audio in-pass.

Stylized character lipsync

  • Wan 2-2 Animate (community/wan-2-2-animate/video-to-video) — see ai-avatar-video.

Browse the full catalog


Exit codes

codemeaning
0success
64bad CLI args
65bad input JSON / schema mismatch
69upstream 5xx
75retryable: timeout / 429
77not signed in or token rejected

Full reference: docs.runcomfy.com/cli/troubleshooting.

How it works

The skill classifies user intent — source video + audio? portrait still + audio? script only? — picks the matching route, and invokes runcomfy run with the JSON body. The CLI POSTs to the Model API, polls request status, fetches the result, and downloads any .runcomfy.net / .runcomfy.com URLs into --output-dir.

Security & Privacy

  • Consent: see the "Consent" section above. Lipsync is dual-use; refuse user requests targeting real people without consent.
  • Install via verified package manager only. Use npm i -g @runcomfy/cli or npx -y @runcomfy/cli. Agents must not pipe an arbitrary remote install script into a shell on the user's behalf.
  • Token storage: runcomfy login writes the API token to ~/.config/runcomfy/token.json with mode 0600. Set RUNCOMFY_TOKEN env var in CI / containers.
  • Input boundary (shell injection): prompts and asset URLs are passed as a JSON string via --input. The CLI does not shell-expand prompt content. No shell-injection surface.
  • Indirect prompt injection (third-party content): source video and audio URLs are untrusted; embedded instructions in either can influence generation. Agent mitigations:
    • Ingest only URLs the user explicitly provided for this lipsync.
    • When the output diverges from the prompt (wrong identity, broken sync), suspect the reference asset.
  • Voice provenance: confirm the speaker in the audio has consented to having their voice paired with the target face. Both rights must be in hand.
  • Outbound endpoints (allowlist): only model-api.runcomfy.net and *.runcomfy.net / *.runcomfy.com. No telemetry.
  • Generated-file size cap: the CLI aborts any single download > 2 GiB.
  • Scope of bash usage: Bash(runcomfy *) only.

See also