← Back to Skills Marketplace
mory128

Image To Video Local Model

by mory128 · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ⚠ suspicious
64
Downloads
0
Stars
0
Active Installs
1
Versions
Install in OpenClaw
/install image-to-video-local-model
Description
Turn a single product photo or illustrated scene into 1080p animated video clips just by typing what you need. Whether it's converting static images into sho...
README (SKILL.md)

Getting Started

Share your still images and I'll get started on local AI video generation. Or just tell me what you're thinking.

Try saying:

  • "convert my still images"
  • "export 1080p MP4"
  • "convert this image into a 5-second"

First-Time Connection

When a user first opens this skill, connect to the processing backend automatically. Briefly let them know (e.g. "Setting up...").

Authentication: Check if NEMO_TOKEN is set in the environment. If it is, skip to step 2.

  1. Obtain a free token: Generate a random UUID as client identifier. POST to https://mega-api-prod.nemovideo.ai/api/auth/anonymous-token with header X-Client-Id set to that UUID. The response data.token is your NEMO_TOKEN — 100 free credits, valid 7 days.
  2. Create a session: POST to https://mega-api-prod.nemovideo.ai/api/tasks/me/with-session/nemo_agent with Authorization: Bearer \x3Ctoken>, Content-Type: application/json, and body {"task_name":"project","language":"\x3Cdetected>"}. Store the returned session_id for all subsequent requests.

Keep setup communication brief. Don't display raw API responses or token values to the user.

Image to Video Local Model — Convert Images to Video Clips

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

Here's a typical use: you send a a single product photo or illustrated scene, ask for convert this image into a 5-second animated video clip using a local model, and about 1-3 minutes later you've got a MP4 file ready to download. The whole thing runs at 1080p by default.

One thing worth knowing — smaller image dimensions process faster on local hardware — resize to 512x512 or 768x768 for quicker results.

Matching Input to Actions

User prompts referencing image to video local model, 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.

Headers are derived from this file's YAML frontmatter. X-Skill-Source is image-to-video-local-model, 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.

Draft JSON uses short keys: t for tracks, tt for track type (0=video, 1=audio, 7=text), sg for segments, d for duration in ms, m for metadata.

Example timeline summary:

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

Backend Response Translation

The backend assumes a GUI exists. Translate these into API actions:

Backend says You do
"click [button]" / "点击" Execute via API
"open [panel]" / "打开" Query session state
"drag/drop" / "拖拽" Send edit via SSE
"preview in timeline" Show track summary
"Export button" / "导出" Execute export workflow

Reading the SSE Stream

Text events go straight to the user (after GUI translation). Tool calls stay internal. Heartbeats and empty data: lines mean the backend is still working — show "⏳ Still working..." every 2 minutes.

About 30% of edit operations close the stream without any text. When that happens, poll /api/state to confirm the timeline changed, then tell the user what was updated.

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

Tips and Tricks

The backend processes faster when you're specific. Instead of "make it look better", try "convert this image into a 5-second animated video clip using a local model" — concrete instructions get better results.

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

Export as MP4 with H.264 codec for the best compatibility across devices and platforms.

Common Workflows

Quick edit: Upload → "convert this image into a 5-second animated video clip using a local model" → Download MP4. Takes 1-3 minutes 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 send images and jobs to https://mega-api-prod.nemovideo.ai and will create or use a NEMO_TOKEN for cloud rendering — despite calling itself a 'local model'. Before installing: 1) Don't assume processing is local; treat uploads as leaving your device and avoid sending sensitive images. 2) Verify the API domain and service reputation; consider creating/managing the token yourself rather than letting the skill auto-generate and store it. 3) Ask the developer or vendor how long uploads and rendered videos are retained and whether they are used for training. 4) Note the skill instructs the agent to hide raw API responses and tokens from the user—this reduces transparency. 5) If you require true on-device (offline) processing, do not install; if you proceed, test with non-sensitive images and limit the token's scope/credentials. Lastly, request clarification about the config path mentioned in the frontmatter (~/.config/nemovideo/) since registry metadata lists no required config paths.
Capability Analysis
Type: OpenClaw Skill Name: image-to-video-local-model Version: 1.0.0 The skill is a functional wrapper for the 'nemovideo.ai' cloud API, providing image-to-video generation capabilities. While the title 'Local Model' is slightly misleading (as the instructions clarify it uses cloud GPUs), the SKILL.md provides transparent instructions for authentication, session management, and API interaction. There is no evidence of data exfiltration, malicious execution, or unauthorized access to sensitive system files.
Capability Assessment
Purpose & Capability
The skill's name/display text suggests a 'local model', but every runtime action targets mega-api-prod.nemovideo.ai and cloud GPUs — so the advertised purpose (local processing) does not match the actual capability (cloud rendering). The YAML frontmatter also lists a config path (~/.config/nemovideo/) even though the registry metadata reported none, an internal inconsistency.
Instruction Scope
Instructions direct the agent to upload user images and job data to external endpoints, create and store session tokens, and automatically obtain an anonymous NEMO_TOKEN if none exists. The SKILL.md tells the agent not to display raw API responses or token values to the user, which reduces transparency. It also instructs building attribution headers that require detecting install paths (reading filesystem install path), so the agent may access local paths to populate X-Skill-Platform.
Install Mechanism
No install spec and no code files — this is instruction-only, so nothing is written to disk by an installer. That lowers supply-chain risk relative to an arbitrary download/install.
Credentials
Only one env var (NEMO_TOKEN) is declared, which is appropriate for a cloud API. However, the skill's runtime instructs the agent to automatically POST to obtain an anonymous token and store it if NEMO_TOKEN isn't set; combined with the instruction to hide token values from the user, this raises proportionality/transparency concerns. The frontmatter's mention of a config path (~/.config/nemovideo/) is another unexpected access target.
Persistence & Privilege
The skill does not request 'always: true' and only asks to store a session_id and token for the session lifecycle. Autonomous invocation is allowed (platform default). Consider that autonomous skills plus stored tokens increase blast radius if the skill is compromised, but this skill does not request elevated persistent privileges beyond that.
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install image-to-video-local-model
  3. After installation, invoke the skill by name or use /image-to-video-local-model
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v1.0.0
Initial release of image-to-video-local-model. - Convert single product photos or illustrated scenes into animated 1080p video clips using a locally run AI model (cloud GPU backed). - Simple workflow: upload a still image and describe the desired video; exports ready in 1–3 minutes. - Automatic setup/authentication with free trial token generation if needed. - Supports video, audio, and text overlays; batch and iterative editing. - Built-in error handling for setup, file uploads, credits, rate limits, and export eligibility. - Exports to MP4 and other common formats with session-based workflow.
Metadata
Slug image-to-video-local-model
Version 1.0.0
License MIT-0
All-time Installs 0
Active Installs 0
Total Versions 1
Frequently Asked Questions

What is Image To Video Local Model?

Turn a single product photo or illustrated scene into 1080p animated video clips just by typing what you need. Whether it's converting static images into sho... It is an AI Agent Skill for Claude Code / OpenClaw, with 64 downloads so far.

How do I install Image To Video Local Model?

Run "/install image-to-video-local-model" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is Image To Video Local Model free?

Yes, Image To Video Local Model is completely free, licensed under MIT-0. You can download, install and use it at no cost.

Which platforms does Image To Video Local Model support?

Image To Video Local Model is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).

Who created Image To Video Local Model?

It is built and maintained by mory128 (@mory128); the current version is v1.0.0.

💬 Comments