← Back to Skills Marketplace
peand-rover

Caption Generator For Photo

by peandrover adam · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ⚠ suspicious
63
Downloads
0
Stars
0
Active Installs
1
Versions
Install in OpenClaw
/install caption-generator-for-photo
Description
Skip the learning curve of professional editing software. Describe what you want — add a caption to this photo and export it as a video — and get captioned p...
README (SKILL.md)

Getting Started

Share your photos or images and I'll get started on AI caption generation. Or just tell me what you're thinking.

Try saying:

  • "generate my photos or images"
  • "export 1080p MP4"
  • "add a caption to this photo"

Automatic Setup

On first interaction, connect to the processing API before doing anything else. Show a brief status like "Setting things up...".

Token: If NEMO_TOKEN environment variable is already set, use it and skip to Session below.

Free token: Generate a UUID as client identifier, then POST to https://mega-api-prod.nemovideo.ai/api/auth/anonymous-token with header X-Client-Id: \x3Cuuid>. The response field data.token becomes your NEMO_TOKEN (100 credits, 7-day expiry).

Session: POST to https://mega-api-prod.nemovideo.ai/api/tasks/me/with-session/nemo_agent with Bearer auth and body {"task_name":"project"}. Save session_id from the response.

Confirm to the user you're connected and ready. Don't print tokens or raw JSON.

Caption Generator for Photo — Add Captions to Photos

Drop your photos or images in the chat and tell me what you need. I'll handle the AI caption generation on cloud GPUs — you don't need anything installed locally.

Here's a typical use: you send a a single product photo or portrait image, ask for add a caption to this photo and export it as a video, and about 20-40 seconds later you've got a MP4 file ready to download. The whole thing runs at 1080p by default.

One thing worth knowing — square images work best for Instagram, vertical for Stories and Reels.

Matching Input to Actions

User prompts referencing caption generator for photo, 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.

Base URL: https://mega-api-prod.nemovideo.ai

Endpoint Method Purpose
/api/tasks/me/with-session/nemo_agent POST Start a new editing session. Body: {"task_name":"project","language":"\x3Clang>"}. Returns session_id.
/run_sse POST Send a user message. Body includes app_name, session_id, new_message. Stream response with Accept: text/event-stream. Timeout: 15 min.
/api/upload-video/nemo_agent/me/\x3Csid> POST Upload a file (multipart) or URL.
/api/credits/balance/simple GET Check remaining credits (available, frozen, total).
/api/state/nemo_agent/me/\x3Csid>/latest GET Fetch current timeline state (draft, video_infos, generated_media).
/api/render/proxy/lambda POST Start export. Body: {"id":"render_\x3Cts>","sessionId":"\x3Csid>","draft":\x3Cjson>,"output":{"format":"mp4","quality":"high"}}. Poll status every 30s.

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

Headers are derived from this file's YAML frontmatter. X-Skill-Source is caption-generator-for-photo, X-Skill-Version comes from the version field, and X-Skill-Platform is detected from the install path (~/.clawhub/ = clawhub, ~/.cursor/skills/ = cursor, otherwise unknown).

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

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

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.

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

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)

Tips and Tricks

The backend processes faster when you're specific. Instead of "make it look better", try "add a caption to this photo and export it as a video" — concrete instructions get better results.

Max file size is 200MB. Stick to JPG, PNG, WEBP, HEIC for the smoothest experience.

Export as MP4 for widest compatibility across all social platforms.

Common Workflows

Quick edit: Upload → "add a caption to this photo and export it as a video" → 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.

Usage Guidance
This skill will upload images and related data to an external service (mega-api-prod.nemovideo.ai) and requires a NEMO_TOKEN bearer token to operate. Before installing, confirm you are comfortable with your images being sent to that domain and review nemo's privacy/terms. Ask the publisher to clarify the apparent metadata mismatch: SKILL.md references storing config under ~/.config/nemovideo/ and detecting install paths, but the registry metadata lists no config paths — if you prefer tokens not be persisted to disk, ask whether the skill will write the anonymous token/session to your filesystem and where. Finally, verify the API hostname is legitimate (nemovideo.ai) and avoid sending sensitive or regulated images unless you trust that service.
Capability Analysis
Type: OpenClaw Skill Name: caption-generator-for-photo Version: 1.0.0 The skill bundle provides a legitimate integration with the nemovideo.ai API for generating captioned photo videos. It includes well-defined instructions for session management, file uploads, and rendering via the domain mega-api-prod.nemovideo.ai, with explicit safety instructions for the agent to avoid leaking tokens or raw JSON. No malicious patterns, data exfiltration, or harmful prompt injection behaviors were identified.
Capability Assessment
Purpose & Capability
Name/description match the actions in SKILL.md: the skill sends images to a remote nemo-video rendering API and returns MP4s. Requiring a NEMO_TOKEN for Bearer auth is proportionate. However the SKILL.md frontmatter also references a local config path (~/.config/nemovideo/) while the registry metadata lists no config paths — this mismatch is unexplained.
Instruction Scope
Instructions are largely limited to API calls (anonymous token generation, session creation, upload, SSE, render), which is expected. A few instructions imply local detection/writes: deriving X-Skill-Platform by checking install paths (~/.clawhub/, ~/.cursor/skills/) and references to a local config path suggest the agent may inspect the filesystem or persist session/token state. The skill does not ask to read arbitrary unrelated files or other env vars.
Install Mechanism
No install spec and no code files — instruction-only skill. This minimizes install-time risk; nothing is downloaded or written by an installer in the bundle itself.
Credentials
The only declared required env var is NEMO_TOKEN (primary credential), which is appropriate for an API-backed renderer. However the SKILL.md instructs generating and saving an anonymous token if none exists and the frontmatter mentions a local config path (~/.config/nemovideo/), implying token persistence to disk; that extra storage access is not reflected in the registry metadata and should be clarified.
Persistence & Privilege
always is false and the skill is user-invocable only. Nothing in the instructions asks the skill to change other skills or system-wide agent settings. The only persistence implied is saving session_id / token for reuse (normal for API clients).
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install caption-generator-for-photo
  3. After installation, invoke the skill by name or use /caption-generator-for-photo
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v1.0.0
Initial release of Caption Generator for Photo — Add Captions to Photos. - Quickly add AI-generated captions to photos and export as 1080p MP4 video. - Supports JPG, PNG, WEBP, HEIC up to 200MB; optimized for social media creators. - Fully cloud-based processing — no local setup or design tools required. - Simple onboarding with free, anonymous tokens and automated session management. - Includes robust status updates, error handling, and workflow for editing, uploading, previewing, and exporting. - User-friendly command mapping for common photo-to-caption-to-video tasks.
Metadata
Slug caption-generator-for-photo
Version 1.0.0
License MIT-0
All-time Installs 0
Active Installs 0
Total Versions 1
Frequently Asked Questions

What is Caption Generator For Photo?

Skip the learning curve of professional editing software. Describe what you want — add a caption to this photo and export it as a video — and get captioned p... It is an AI Agent Skill for Claude Code / OpenClaw, with 63 downloads so far.

How do I install Caption Generator For Photo?

Run "/install caption-generator-for-photo" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is Caption Generator For Photo free?

Yes, Caption Generator For Photo is completely free, licensed under MIT-0. You can download, install and use it at no cost.

Which platforms does Caption Generator For Photo support?

Caption Generator For Photo is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).

Who created Caption Generator For Photo?

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

💬 Comments