--- name: "video-clip-extractor" description: "Processes videos to identify engaging moments, generate transcripts, and create highlight clips with artistic titles and custom cover images. Use when user needs to: extract highlights from long videos or livestreams, clip or cut best moments from videos, cut video highlights, process Bilibili/YouTube URLs or local video files, generate transcripts via Whisper, analyze content for engaging moments, create short-form clips with styled titles and covers, adjust cover text position and colors, find and export memorable scenes from recordings, burn subtitles into clips (with optional translation), guide clip selection with user intent, or identify speakers in multi-person conversations." allowed-tools: Bash(uv run python video_orchestrator.py*), Bash(git clone*), Bash(git -C*openclip*), Bash(cd ~/.local/share/openclip*), AskUserQuestion --- # Video Clip Extractor Skill Run the video orchestrator to process videos and extract engaging highlights. ## When Triggered 1. **Get the source** — if the user didn't provide a video URL or file path, ask for it. 2. **Clarify intent** (optional) — if the user wants clips focused on a specific topic, capture it for `--user-intent`. If unclear, ask: "Any specific topic or moments to focus on? (e.g. 'funny moments', 'key arguments')" 3. **Check environment** — does `video_orchestrator.py` exist in the current directory? If yes, run directly. Otherwise use the global install at `~/.local/share/openclip`. 4. **Verify prerequisites** — check ffmpeg is installed and at least one API key is set. Warn if missing before running. 5. **Run the command** and stream output to user. 6. **Report results** — after completion, list the generated clips with timestamps and titles. ## Setup (first use only) Before running, determine the execution context: 1. **Inside openclip repo** — if `video_orchestrator.py` exists in the current directory, skip setup and run directly. 2. **Global install** — if `~/.local/share/openclip` does not exist, run these steps: **Prerequisites:** `git` and `uv` must be installed. - Install uv if missing: macOS: `brew install uv` · Linux/Windows: `pip install uv` ```bash git clone https://github.com/linzzzzzz/openclip.git ~/.local/share/openclip cd ~/.local/share/openclip && uv sync ``` To update openclip later: ```bash git -C ~/.local/share/openclip pull && cd ~/.local/share/openclip && uv sync ``` ## Execution **If inside the openclip repo** (current directory contains `video_orchestrator.py`): ```bash uv run python video_orchestrator.py [options] ``` **If running globally** (from any other directory): ```bash cd ~/.local/share/openclip && uv run python video_orchestrator.py -o "$OLDPWD/processed_videos" [options] ``` `$OLDPWD` captures the user's original directory so clips are saved there, not inside the openclip install. Where `` is a video URL (Bilibili/YouTube) or local file path (MP4, WebM, AVI, MOV, MKV). For local files with existing subtitles, place the `.srt` file in the same directory with the same filename (e.g. `video.mp4` → `video.srt`). ## Preflight Checklist - **Inside openclip repo**: run from the repo root so relative paths (e.g. `references/`, `prompts/`) resolve correctly - **`ffmpeg` must be installed** (required for all clip generation): - macOS: `brew install ffmpeg` - Ubuntu: `sudo apt install ffmpeg` - Windows: download from [ffmpeg.org](https://ffmpeg.org) - If using `--burn-subtitles`: needs ffmpeg with `libass` (see README for details) - Set one API key: - `QWEN_API_KEY` (default provider: qwen), or - `OPENROUTER_API_KEY` (if `--llm-provider openrouter`), or - `GLM_API_KEY` (if `--llm-provider glm`), or - `MINIMAX_API_KEY` (if `--llm-provider minimax`) - If using `--speaker-references`: run `uv sync --extra speakers` and set `HUGGINGFACE_TOKEN` ## CLI Reference ### Required | Argument | Description | |---|---| | `source` | Video URL or local file path | ### Optional | Flag | Default | Description | |---|---|---| | `-o`, `--output ` | `processed_videos` | Output directory | | `--max-clips ` | `5` | Maximum number of highlight clips | | `--browser ` | `firefox` | Browser for cookies: `chrome`, `firefox`, `edge`, `safari` | | `--title-style