技能详情(站内镜像,无评论)
许可证:MIT-0
MIT-0 ·免费使用、修改和重新分发。无需归因。
版本:v0.1.0
统计:⭐ 0 · 121 · 0 current installs · 0 all-time installs
⭐ 0
安装量(当前) 0
🛡 VirusTotal :良性 · OpenClaw :可疑
Package:0xfango/explainer-video
安全扫描(ClawHub)
- VirusTotal :良性
- OpenClaw :可疑
OpenClaw 评估
The skill largely matches its stated purpose (creates explainer videos using a backend API) but contains several inconsistencies and minor risks you should review before installing.
目的
The skill claims to create explainer videos and requires a LISTENHUB_API_KEY, which is coherent for a hosted video-generation service. However, the SKILL.md references endpoints at api.marswave.ai and a UI URL at listenhub.ai — the mismatch of domains is unexplained and should be clarified by the author.
说明范围
Instructions will write a config file ('.listenhub/explainer/config.json' or $HOME alternative) and perform network calls using curl and jq (polling loop). The skill's declared requirements list no required binaries, yet the runtime explicitly requires curl and jq. It also mandates reading shared/*.md resources (not included here) and persisting defaultSpeakers after generation. These steps are within the skill's goal but the missing declared …
安装机制
No install spec or code files are included — the skill is instruction-only and does not download or install external packages, which reduces installation risk.
证书
Only one environment variable is required (LISTENHUB_API_KEY), which is appropriate for a remote API. The SKILL.md shows that API key will be sent as a Bearer token to the service. Confirm the API key's scope/permissions before use.
持久
The skill writes/reads a local config under .listenhub/explainer and persists defaultSpeakers after generation. It does not request always:true or global privileges. Writing a config file is expected but you should confirm the exact location (current directory vs $HOME) and contents that will be stored.
安装(复制给龙虾 AI)
将下方整段复制到龙虾中文库对话中,由龙虾按 SKILL.md 完成安装。
请把本段交给龙虾中文库(龙虾 AI)执行:为本机安装 OpenClaw 技能「Explainer」。简介:Create explainer videos with narration and AI-generated visuals. Triggers on: "…。
请 fetch 以下地址读取 SKILL.md 并按文档完成安装:https://raw.githubusercontent.com/openclaw/skills/refs/heads/main/skills/0xfango/explainer-video/SKILL.md
(来源:yingzhi8.cn 技能库)
SKILL.md
---
name: explainer
description: |
Create explainer videos with narration and AI-generated visuals. Triggers on:
"解说视频", "explainer video", "explain this as a video", "tutorial video",
"introduce X (video)", "解释一下XX(视频形式)".
metadata:
openclaw:
emoji: "🎬"
requires:
env: ["LISTENHUB_API_KEY"]
primaryEnv: "LISTENHUB_API_KEY"
---
## When to Use
- User wants to create an explainer or tutorial video
- User asks to "explain" something in video form
- User wants narrated content with AI-generated visuals
- User says "explainer video", "解说视频", "tutorial video"
## When NOT to Use
- User wants audio-only content without visuals (use `/speech` or `/podcast`)
- User wants a podcast-style discussion (use `/podcast`)
- User wants to generate a standalone image (use `/image-gen`)
- User wants to read text aloud without video (use `/speech`)
## Purpose
Generate explainer videos that combine a single narrator's voiceover with AI-generated visuals. Ideal for product introductions, concept explanations, and tutorials. Supports text-only script generation or full text + video output.
## Hard Constraints
- No shell scripts. Construct curl commands from the API reference files listed in Resources
- Always read `shared/authentication.md` for API key and headers
- Follow `shared/common-patterns.md` for polling, errors, and interaction patterns
- Always read config following `shared/config-pattern.md` before any interaction
- Never hardcode speaker IDs — always fetch from the speakers API
- Never save files to `~/Downloads/` — use `.listenhub/explainer/` from config
- Explainer uses exactly 1 speaker
- Mode must be `info` (for Info style) or `story` (for Story style) — never `slides` (use `/slides` skill instead)
<HARD-GATE>
Use the AskUserQuestion tool for every multiple-choice step — do NOT print options as plain text. Ask one question at a time. Wait for the user's answer before proceeding to the next step. After all parameters are collected, summarize the choices and ask the user to confirm. Do NOT call any generation API until the user has explicitly confirmed.
</HARD-GATE>
## Step -1: API Key Check
Follow `shared/config-pattern.md` § API Key Check. If the key is missing, stop immediately.
## Step 0: Config Setup
Follow `shared/config-pattern.md` Step 0.
**If file doesn't exist** — ask location, then create immediately:
```bash
mkdir -p ".listenhub/explainer"
echo '{"outputDir":".listenhub","outputMode":"inline","language":null,"defaultStyle":null,"defaultSpeakers":{}}' > ".listenhub/explainer/config.json"
CONFIG_PATH=".listenhub/explainer/config.json"
# (or $HOME/.listenhub/explainer/config.json for global)
```
Then run **Setup Flow** below.
**If file exists** — read config, display summary, and confirm:
```
当前配置 (explainer):
输出方式:{inline / download / both}
语言偏好:{zh / en / 未设置}
默认风格:{info / story / 未设置}
默认主播:{speakerName / 未设置}
```
Ask: "使用已保存的配置?" → **确认,直接继续** / **重新配置**
### Setup Flow (first run or reconfigure)
Ask these questions in order, then save all answers to config at once:
1. **outputMode**: Follow `shared/output-mode.md` § Setup Flow Question.
2. **Language** (optional): "默认语言?"
- "中文 (zh)"
- "English (en)"
- "每次手动选择" → keep `null`
3. **Style** (optional): "默认风格?"
- "Info — 信息展示型"
- "Story — 故事叙述型"
- "每次手动选择" → keep `null`
After collecting answers, save immediately:
```bash
# Follow shared/output-mode.md § Save to Config
NEW_CONFIG=$(echo "$CONFIG" | jq --arg m "$OUTPUT_MODE" '. + {"outputMode": $m}')
echo "$NEW_CONFIG" > "$CONFIG_PATH"
CONFIG=$(cat "$CONFIG_PATH")
```
Note: `defaultSpeakers` are saved after generation (see After Successful Generation section).
## Interaction Flow
### Step 1: Topic / Content
Free text input. Ask the user:
> What would you like to explain or introduce?
Accept: topic description, text content, or concept to explain.
### Step 2: Language
If `config.language` is set, pre-fill and show in summary — skip this question.
Otherwise ask:
```
Question: "What language?"
Options:
- "Chinese (zh)" — Content in Mandarin Chinese
- "English (en)" — Content in English
```
### Step 3: Style
If `config.defaultStyle` is set, pre-fill and show in summary — skip this question.
Otherwise ask:
```
Question: "What style of explainer?"
Options:
- "Info" — Informational, factual presentation style
- "Story" — Narrative, storytelling approach
```
### Step 4: Speaker Selection
Follow `shared/speaker-selection.md` for the full selection flow, including:
- Default from `config.defaultSpeakers.{language}` (skip step if set)
- Text table + free-text input
- Input matching and re-prompt on no match
Only 1 speaker is supported for explainer videos.
### Step 5: Output Type
```
Question: "What output do you want?"
Options:
- "Text script only" — Generate narration script, no video
- "Text + Video" — Generate full explainer video with AI visuals
```
### Step 6: Confirm & Generate
Summarize all choices:
```
Ready to generate explainer:
Topic: {topic}
Language: {language}
Style: {info/story}
Speaker: {speaker name}
Output: {text only / text + video}
Proceed?
```
Wait for explicit confirmation before calling any API.
## Workflow
1. **Submit (foreground)**: `POST /storybook/episodes` with content, speaker, language, mode → extract `episodeId`
2. Tell the user the task is submitted
3. **Poll (background)**: Run the following **exact** bash command with `run_in_background: true` and `timeout: 600000`. Do NOT use python3, awk, or any other JSON parser — use `jq` as shown:
```bash
EPISODE_ID="<id-from-step-1>"
for i in $(seq 1 30); do
RESULT=$(curl -sS "https://api.marswave.ai/openapi/v1/storybook/episodes/$EPISODE_ID"
-H "Authorization: Bearer $LISTENHUB_API_KEY" 2>/dev/null)
STATUS=$(echo "$RESULT" | tr -d '