Clip Media

Other

Extract media (videos, photos, GIFs, audio) from social media URLs using yt-dlp. Supports 1,872+ platforms including YouTube, TikTok, Instagram, X/Twitter, F...

Install

openclaw skills install clip-media

Clip

⚠️ Security warnings before use:

  • Files over 50 MB are uploaded to public third-party file hosts (tmpfiles.org, transfer.sh) — not private
  • Browser cookie access (--cookies-from-browser) exposes active session tokens for any platform you're logged into
  • Never use with private, paid, confidential, copyrighted, or regulated content unless you explicitly intend external transmission
  • Default behavior includes external upload — confirm before use

How It Works

  1. User shares a URL from any supported platform
  2. Run the extraction script
  3. Script downloads the media (or just analyzes it)
  4. Returns the file path (under 50 MB) or a cloud link (over 50 MB)
  5. Agent sends the media to the user

⚠️ Before any extraction: Confirm the content is not private, paid, or sensitive. If over 50 MB, warn the user that the file will be uploaded to a public host.

Command

node /home/jarvis/.openclaw/workspace/skills/clip/extract.js <url> [options]

Options

FlagDescription
--output-dir <dir>Save location (default: /tmp/media-share)
--titleReturn title/description only, no download
--infoReturn full metadata as JSON
--testValidate URL without downloading
--uploadForce cloud upload even for small files
--cloud=<provider>Cloud provider: tmpfiles or transfer
--no-direct-sendAlways return path, never auto-send
--list-sitesShow supported platforms
--list-typesShow what media a URL contains

Examples

# Download media (fastest path)
node /home/jarvis/.openclaw/workspace/skills/clip/extract.js "https://www.youtube.com/watch?v=dQw4w9WgXcQ"

# Get title only (no download, instant)
node /home/jarvis/.openclaw/workspace/skills/clip/extract.js "https://www.instagram.com/p/abc123/" --title

# Check what's in a URL before downloading
node /home/jarvis/.openclaw/workspace/skills/clip/extract.js "https://www.tiktok.com/@user/video/123" --list-types

# Show supported sites
node /home/jarvis/.openclaw/workspace/skills/clip/extract.js --list-sites

Supported Platforms

yt-dlp: 1,872 extractors — covers essentially every major media platform on the internet.

Quick reference (most common):

YouTube, TikTok, Instagram, X/Twitter, Facebook, Reddit, Twitch, Vimeo, Dailymotion, Rumble, Peertube, Bilibili, Niconico, SoundCloud, Bandcamp, Pinterest, Imgur, Tumblr, Flickr, Bluesky, Telegram, Kick, Odysee, CNN, BBC, Al Jazeera, TED, Khan Academy, Udemy, Crunchyroll, HiDive, and 1,800+ more.

File Size Handling

  • Under 50 MB → Returns local file path (agent sends via chat)
  • Over 50 MB → Auto-uploads to temp cloud storage, returns download link
  • Over 50 MB + --upload → Forces cloud upload even for smaller files

Cloud Providers

⚠️ Both providers are public and third-party. Uploaded files are accessible to anyone with the link.

ProviderMax SizeNotes
tmpfiles50 MBSimple, no signup, auto-delete
transferUnlimitedtransfer.sh, 30-day retention

Always warn the user before uploading to these providers.

Authentication

⚠️ Browser cookie access exposes active session tokens for every platform you're logged into.

Some platforms require cookies for full access:

PlatformNeeds cookies?
InstagramSometimes (private content, full resolution)
X / TwitterSometimes (rate limits, some content)
PatreonYes (paid content)
OnlyFansYes
Fanvue / FanslyYes
Netflix / HBO / Disney+Via browser cookies
YouTubeRarely (age-restricted content)

Before using --cookies-from-browser:

  • Confirm the user understands this exposes session tokens for ALL platforms in that browser
  • Warn that this could enable unauthorized account access if the machine is compromised
  • Prefer alternative auth methods (API keys, manual cookie paste) when available
  • Never use --cookies-from-browser with paid/sensitive platforms unless the user explicitly consents to the risk

How It Works (Under the Hood)

  1. Analyze: yt-dlp --dump-json detects the platform and media type
  2. Download: yt-dlp -o <path> grabs the highest quality version
  3. Route: Under 50 MB → return path. Over 50 MB → upload to cloud → return link
  4. Fallback: If download fails, returns title/description so the agent can inform the user

Dependencies

  • yt-dlp (installed) — 1,872 extractors
  • ffmpeg (installed) — format conversion
  • curl (installed) — cloud uploads

Error Handling

When a URL returns no media, the script returns the title/description. The agent should:

  • Inform the user what was found
  • Suggest trying --cookies-from-browser chrome if the platform may require auth
  • Note that geo-blocked content cannot be bypassed

Notes

  • Rate limits may apply on some platforms — add delays between calls
  • Some platforms (Instagram, X) work better with cookies
  • If a URL returns no media, return the title/description to the user instead
  • The generic extractor handles many embedded video players not explicitly listed