Install
openclaw skills install video-adCreate scroll-stopping video ads with Pexo. Give it your product, brand, or a photo and Pexo writes the hook, sequences the shots, picks the best models, and delivers a finished ad with music — ready to run on Meta, TikTok, or YouTube. Use for advertising/promo video: "video ad", "make an ad", "product ad", "promo video", "commercial". NOT for explainer or tutorial content (use the explainer-video skill).
openclaw skills install video-adPexo: https://pexo.ai — get an API key, watch your project render, and buy credits there.
Produce a finished, ready-to-run video ad. You hand the user's product or brief to the hosted Pexo agent and deliver the result — Pexo writes the hook, sequences the shots, picks the models, and sets music and pacing built to convert.
Create a project, send the user's request verbatim, poll, deliver. Pexo's backend handles all creative work — scriptwriting, model choice, prompts, music. Adding your own direction (duration, style, models the user didn't ask for) overrides its judgment and produces worse videos.
~/.pexo/config:
PEXO_BASE_URL="https://pexo.ai"
PEXO_API_KEY="sk-<your-api-key>"
No account / first run → read references/SETUP-CHECKLIST.md and walk the user through it — it carries the signup flow with the invite code that grants new users bonus credits, plus how to create the config above. Config error → run scripts/pexo-doctor.sh and follow its output.
Scripts live in this skill's scripts/. Reply to the user in their language.
pexo-project-create.sh "<short brief>" → save the project_id.pexo-upload.sh <project_id> <path> → save asset_id,
reference it inline as <original-image>asset_id</original-image> (or <original-video> /
<original-audio>). Tags are required — a bare asset_id is ignored. Pexo can't crawl URLs —
download, then upload.pexo-chat.sh <project_id> "<user's exact words> <asset tags>".
Copy the user's words exactly; only add asset tags.https://pexo.ai/project/<project_id>.pexo-project-get.sh <project_id> and act on nextAction:
recentMessages: relay Pexo's text (wait for the
user's answer if it asked, then pexo-chat.sh their reply); for preview_video, run
pexo-asset-get.sh <project_id> <assetId> per option, show the URLs (A/B/C), let the user
pick, then pexo-chat.sh <project_id> "<choice>" --choice <assetId>; for a document
event, mention it to the user.pexo-asset-get.sh <project_id> <final assetId>, then send the user the
full asset URL as plain text — all ?… query params, never truncated or wrapped in
markdown — plus the project link.nextActionHint in plain terms and offer to retry.pexo-chat.sh <project_id> "continue", tell the user the connection
dropped and you're resuming, then keep polling.pexo-chat.sh during WAIT — it triggers duplicate production.https://pexo.ai/connect/openclaw) it's running long; ask whether to keep waiting or
stop. Don't poll forever.After delivery, the user's tweaks ("make it shorter", "new music", "different shot") reuse the
same project: pexo-chat.sh <project_id> "<their feedback>", then poll again (step 5). Never
create a new project for a revision — it throws away Pexo's server-side context.
If a script fails with "Credits balance" / "Insufficient credits": if the error carries a
purchase link, pass it to the user; otherwise tell them to add credits at https://pexo.ai/home
→ Credits → Buy Credits. Retry after they confirm.
User: "Make a 15-second video ad for our new running shoes."
pid=$(pexo-project-create.sh "running shoes ad")
pexo-chat.sh "$pid" "Make a 15-second video ad for our new running shoes."
# Tell the user: submitted, ~15–20 min, https://pexo.ai/project/$pid
# Poll pexo-project-get.sh "$pid" until nextAction is DELIVER, then deliver the asset URL.
| Script | Usage | Returns |
|---|---|---|
pexo-project-create.sh | "<brief>" | project_id |
pexo-upload.sh | <project_id> <file> | asset_id |
pexo-chat.sh | <project_id> "<message>" [--choice <id>] | ack (async) |
pexo-project-get.sh | <project_id> | JSON: nextAction, recentMessages |
pexo-asset-get.sh | <project_id> <asset_id> | JSON with url |
pexo-doctor.sh | — | setup diagnostic |
Error codes and edge cases → references/TROUBLESHOOTING.md.