← Back to Skills Marketplace
peand-rover

How To Add Music To A Video

by peandrover adam · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ⚠ suspicious
70
Downloads
0
Stars
0
Active Installs
1
Versions
Install in OpenClaw
/install how-to-add-music-to-a-video
Description
Get music-backed videos ready to post, without touching a single slider. Upload your video and audio files (MP4, MOV, AVI, MP3, up to 500MB), say something l...
README (SKILL.md)

Getting Started

Share your video and audio files and I'll get started on AI audio merging. Or just tell me what you're thinking.

Try saying:

  • "add my video and audio files"
  • "export 1080p MP4"
  • "add this background music to my"

Quick Start Setup

This skill connects to a cloud processing backend. On first use, set up the connection automatically and let the user know ("Connecting...").

Token check: Look for NEMO_TOKEN in the environment. If found, skip to session creation. Otherwise:

  • Generate a UUID as client identifier
  • POST https://mega-api-prod.nemovideo.ai/api/auth/anonymous-token with X-Client-Id header
  • Extract data.token from the response — this is your NEMO_TOKEN (100 free credits, 7-day expiry)

Session: POST https://mega-api-prod.nemovideo.ai/api/tasks/me/with-session/nemo_agent with Bearer auth and body {"task_name":"project"}. Keep the returned session_id for all operations.

Let the user know with a brief "Ready!" when setup is complete. Don't expose tokens or raw API output.

How to Add Music to a Video — Merge Audio and Export Video

Send me your video and audio files and describe the result you want. The AI audio merging runs on remote GPU nodes — nothing to install on your machine.

A quick example: upload a 2-minute MP4 clip and an MP3 background track, type "add this background music to my video and fade it out at the end", and you'll get a 1080p MP4 back in roughly 20-40 seconds. All rendering happens server-side.

Worth noting: trim your audio to match the video length before uploading for cleaner results.

Matching Input to Actions

User prompts referencing how to add music to a video, aspect ratio, text overlays, or audio tracks get routed to the corresponding action via keyword and intent classification.

User says... Action Skip SSE?
"export" / "导出" / "download" / "send me the video" → §3.5 Export
"credits" / "积分" / "balance" / "余额" → §3.3 Credits
"status" / "状态" / "show tracks" → §3.4 State
"upload" / "上传" / user sends file → §3.2 Upload
Everything else (generate, edit, add BGM…) → §3.1 SSE

Cloud Render Pipeline Details

Each export job queues on a cloud GPU node that composites video layers, applies platform-spec compression (H.264, up to 1080x1920), and returns a download URL within 30-90 seconds. The session token carries render job IDs, so closing the tab before completion orphans the job.

All calls go to https://mega-api-prod.nemovideo.ai. The main endpoints:

  1. SessionPOST /api/tasks/me/with-session/nemo_agent with {"task_name":"project","language":"\x3Clang>"}. Gives you a session_id.
  2. Chat (SSE)POST /run_sse with session_id and your message in new_message.parts[0].text. Set Accept: text/event-stream. Up to 15 min.
  3. UploadPOST /api/upload-video/nemo_agent/me/\x3Csid> — multipart file or JSON with URLs.
  4. CreditsGET /api/credits/balance/simple — returns available, frozen, total.
  5. StateGET /api/state/nemo_agent/me/\x3Csid>/latest — current draft and media info.
  6. ExportPOST /api/render/proxy/lambda with render ID and draft JSON. Poll GET /api/render/proxy/lambda/\x3Cid> every 30s for completed status and download URL.

Formats: mp4, mov, avi, webm, mkv, jpg, png, gif, webp, mp3, wav, m4a, aac.

Skill attribution — read from this file's YAML frontmatter at runtime:

  • X-Skill-Source: how-to-add-music-to-a-video
  • X-Skill-Version: from frontmatter version
  • X-Skill-Platform: detect from install path (~/.clawhub/clawhub, ~/.cursor/skills/cursor, else unknown)

Include Authorization: Bearer \x3CNEMO_TOKEN> and all attribution headers on every request — omitting them triggers a 402 on export.

Draft field mapping: t=tracks, tt=track type (0=video, 1=audio, 7=text), sg=segments, d=duration(ms), m=metadata.

Timeline (3 tracks): 1. Video: city timelapse (0-10s) 2. BGM: Lo-fi (0-10s, 35%) 3. Title: "Urban Dreams" (0-3s)

Translating GUI Instructions

The backend responds as if there's a visual interface. Map its instructions to API calls:

  • "click" or "点击" → execute the action via the relevant endpoint
  • "open" or "打开" → query session state to get the data
  • "drag/drop" or "拖拽" → send the edit command through SSE
  • "preview in timeline" → show a text summary of current tracks
  • "Export" or "导出" → run the export workflow

SSE Event Handling

Event Action
Text response Apply GUI translation (§4), present to user
Tool call/result Process internally, don't forward
heartbeat / empty data: Keep waiting. Every 2 min: "⏳ Still working..."
Stream closes Process final response

~30% of editing operations return no text in the SSE stream. When this happens: poll session state to verify the edit was applied, then summarize changes to the user.

Error Handling

Code Meaning Action
0 Success Continue
1001 Bad/expired token Re-auth via anonymous-token (tokens expire after 7 days)
1002 Session not found New session §3.0
2001 No credits Anonymous: show registration URL with ?bind=\x3Cid> (get \x3Cid> from create-session or state response when needed). Registered: "Top up credits in your account"
4001 Unsupported file Show supported formats
4002 File too large Suggest compress/trim
400 Missing X-Client-Id Generate Client-Id and retry (see §1)
402 Free plan export blocked Subscription tier issue, NOT credits. "Register or upgrade your plan to unlock export."
429 Rate limit (1 token/client/7 days) Retry in 30s once

Common Workflows

Quick edit: Upload → "add this background music to my video and fade it out at the end" → Download MP4. Takes 20-40 seconds for a 30-second clip.

Batch style: Upload multiple files in one session. Process them one by one with different instructions. Each gets its own render.

Iterative: Start with a rough cut, preview the result, then refine. The session keeps your timeline state so you can keep tweaking.

Tips and Tricks

The backend processes faster when you're specific. Instead of "make it look better", try "add this background music to my video and fade it out at the end" — concrete instructions get better results.

Max file size is 500MB. Stick to MP4, MOV, AVI, MP3 for the smoothest experience.

Export as MP4 for widest compatibility across platforms.

Usage Guidance
This skill will upload any media you provide to mega-api-prod.nemovideo.ai for server-side processing and will include an Authorization Bearer token on requests. Before installing: 1) Confirm you trust nemovideo.ai with your files and any personal information in them (don’t upload sensitive content). 2) Clarify whether you must provide your own NEMO_TOKEN; the metadata says it’s required but the instructions show an anonymous-token flow — if you prefer account-level tracking, supply your token; otherwise anonymous tokens may be used but expire in 7 days. 3) Be aware the skill may inspect your home directory (~/.clawhub or ~/.cursor/skills) to set an X-Skill-Platform header. 4) If you need stronger guarantees (no uploads, local-only processing, or avoid creating remote tokens), do not install. If you want to proceed, consider asking the skill author to remove the misleading 'required env' claim or to document when a persistent token is actually needed.
Capability Analysis
Type: OpenClaw Skill Name: how-to-add-music-to-a-video Version: 1.0.0 The skill is a functional integration for a cloud-based video editing service (nemovideo.ai). It provides detailed instructions for the agent to handle authentication, session management, and API interactions for merging audio and video. While it includes logic for environment-based attribution and automated token retrieval, these actions are directly related to the service's operation and do not exhibit signs of malicious intent, unauthorized data exfiltration, or harmful prompt injection.
Capability Assessment
Purpose & Capability
The skill's name and description (merge audio into video on a cloud backend) match the SKILL.md instructions (upload files, create a session, export via nemovideo.ai APIs). However, the registry metadata lists NEMO_TOKEN as a required environment variable even though the instructions include an anonymous-token flow that generates a token if NEMO_TOKEN is not present. That discrepancy is unexplained and unnecessary for the stated purpose.
Instruction Scope
Runtime instructions stay within the stated purpose: they describe creating/using a session, uploading media, streaming edits via SSE, and polling render status. There are no instructions to read unrelated system files or exfiltrate data beyond the megapi endpoint. The skill does instruct detection of install paths (~/.clawhub/, ~/.cursor/skills/) to populate an X-Skill-Platform header, which requires inspecting the user's home directory; this is scope-adjacent but understandable for attribution.
Install Mechanism
There is no install specification and no code files — this is instruction-only. That minimizes disk-write and supply-chain risk.
Credentials
Metadata declares NEMO_TOKEN as required (primary credential) and includes a configPaths entry (~/.config/nemovideo/), but the instructions explicitly allow generating an anonymous token if NEMO_TOKEN is missing and do not reference the config path. Requesting a persistent credential while also supporting anonymous issuance is inconsistent. Requiring a named secret in metadata without a clear need is disproportionate and should be clarified.
Persistence & Privilege
The skill is not always-enabled and does not request elevated platform privileges. It will cause outbound network calls to nemovideo.ai and may read the user's home path to detect install location for attribution headers — both are reasonable for this skill's functionality but worth noting.
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install how-to-add-music-to-a-video
  3. After installation, invoke the skill by name or use /how-to-add-music-to-a-video
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v1.0.0
how-to-add-music-to-a-video v1.0.0 - Initial release: add music to videos quickly using cloud processing—no editing software required. - Upload video (MP4, MOV, AVI) and audio (MP3, etc.) files, describe edits, and export 1080p MP4s. - Easy cloud setup: automatic token management, session handling, and queueing on remote GPU nodes. - Supports file uploads, exporting, credit checks, status updates, and simple timeline edits via chat prompts. - Responds to plain language instructions (e.g., “add background music and fade out at end”). - Handles common errors (token, credits, file types/sizes) and provides helpful tips for best results.
Metadata
Slug how-to-add-music-to-a-video
Version 1.0.0
License MIT-0
All-time Installs 0
Active Installs 0
Total Versions 1
Frequently Asked Questions

What is How To Add Music To A Video?

Get music-backed videos ready to post, without touching a single slider. Upload your video and audio files (MP4, MOV, AVI, MP3, up to 500MB), say something l... It is an AI Agent Skill for Claude Code / OpenClaw, with 70 downloads so far.

How do I install How To Add Music To A Video?

Run "/install how-to-add-music-to-a-video" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is How To Add Music To A Video free?

Yes, How To Add Music To A Video is completely free, licensed under MIT-0. You can download, install and use it at no cost.

Which platforms does How To Add Music To A Video support?

How To Add Music To A Video is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).

Who created How To Add Music To A Video?

It is built and maintained by peandrover adam (@peand-rover); the current version is v1.0.0.

💬 Comments