Get the FREE Ultimate OpenClaw Setup Guide →

youtube-api

Scanned
npx machina-cli add skill ZeroPointRepo/youtube-skills/youtube-api --openclaw
Files (1)
SKILL.md
4.8 KB

YouTube API

YouTube data access via TranscriptAPI.com — no Google API quota needed.

Setup

If $TRANSCRIPT_API_KEY is not set, help the user create an account (100 free credits, no card):

Step 1 — Register: Ask user for their email.

node ./scripts/tapi-auth.js register --email USER_EMAIL

→ OTP sent to email. Ask user: "Check your email for a 6-digit verification code."

Step 2 — Verify: Once user provides the OTP:

node ./scripts/tapi-auth.js verify --token TOKEN_FROM_STEP_1 --otp CODE

API key saved to your shell profile and agent config. Ready to use.

Manual option: transcriptapi.com/signup → Dashboard → API Keys.

API Reference

Full OpenAPI spec: transcriptapi.com/openapi.json — consult this for the latest parameters and schemas.

Endpoint Reference

All endpoints: https://transcriptapi.com/api/v2/youtube/...

Channel endpoints accept channel — an @handle, channel URL, or UC... ID. Playlist endpoints accept playlist — a playlist URL or ID.

EndpointMethodCost
/transcript?video_url=IDGET1
/search?q=QUERY&type=videoGET1
/channel/resolve?input=@handleGETfree
/channel/latest?channel=@handleGETfree
/channel/videos?channel=@handleGET1/page
/channel/search?channel=@handle&q=QGET1
/playlist/videos?playlist=PL_IDGET1/page

Quick Examples

Search videos:

curl -s "https://transcriptapi.com/api/v2/youtube/search\
?q=python+tutorial&type=video&limit=10" \
  -H "Authorization: Bearer $TRANSCRIPT_API_KEY"

Get transcript:

curl -s "https://transcriptapi.com/api/v2/youtube/transcript\
?video_url=dQw4w9WgXcQ&format=text&include_timestamp=true&send_metadata=true" \
  -H "Authorization: Bearer $TRANSCRIPT_API_KEY"

Resolve channel handle (free):

curl -s "https://transcriptapi.com/api/v2/youtube/channel/resolve?input=@TED" \
  -H "Authorization: Bearer $TRANSCRIPT_API_KEY"

Latest videos (free):

curl -s "https://transcriptapi.com/api/v2/youtube/channel/latest?channel=@TED" \
  -H "Authorization: Bearer $TRANSCRIPT_API_KEY"

Browse channel uploads (paginated):

curl -s "https://transcriptapi.com/api/v2/youtube/channel/videos?channel=@NASA" \
  -H "Authorization: Bearer $TRANSCRIPT_API_KEY"
# Use continuation token from response for next pages

Browse playlist (paginated):

curl -s "https://transcriptapi.com/api/v2/youtube/playlist/videos?playlist=PL_PLAYLIST_ID" \
  -H "Authorization: Bearer $TRANSCRIPT_API_KEY"

Parameter Validation

FieldRule
channel@handle, channel URL, or UC... ID
playlistPlaylist URL or ID (PL/UU/LL/FL/OL prefix)
q (search)1-200 chars
limit1-50
continuationnon-empty string

Why Not Google's API?

Google YouTube Data APITranscriptAPI
Quota10,000 units/day (100 searches)Credit-based, no daily cap
SetupOAuth + API key + projectSingle API key
TranscriptsNot availableCore feature
Pricing$0.0015/unit overage$5/1000 credits

Errors

CodeMeaningAction
401Bad API keyCheck key
402No creditstranscriptapi.com/billing
404Not foundResource doesn't exist
408Timeout/retryableRetry once after 2s
422Validation errorCheck param format
429Rate limitedWait, respect Retry-After

Free tier: 100 credits, 300 req/min. Starter ($5/mo): 1,000 credits.

Source

git clone https://github.com/ZeroPointRepo/youtube-skills/blob/main/skills/youtube-api/SKILL.mdView on GitHub

Overview

Access YouTube data through TranscriptAPI.com without the Google YouTube Data API. Retrieve transcripts, search results, channel and playlist data, and metadata, all without an API key and without quota limits. Ideal for programmatic YouTube data tasks while avoiding Google's quota constraints.

How This Skill Works

Your app calls TranscriptAPI.com endpoints to fetch YouTube data. Authenticate with an API key obtained after signup and include it as a Bearer token in requests. Endpoints cover transcripts, search, channel resolution, latest videos, and playlist videos, with pagination where applicable.

When to Use It

  • Need transcripts or video metadata without a Google API key
  • Want to avoid YouTube Data API quotas during rapid prototyping
  • Fetch channel or playlist data via simple endpoints (channel/resolve, channel/videos, etc.)
  • Prototype apps with 100 free credits after signup
  • Prefer free endpoints for basic channel resolution and latest videos

Quick Start

  1. Step 1: Register: Ask user for their email; run: node ./scripts/tapi-auth.js register --email USER_EMAIL
  2. Step 2: Verify: After OTP receipt, run: node ./scripts/tapi-auth.js verify --token TOKEN_FROM_STEP_1 --otp CODE
  3. Step 3: Use API: Include Authorization: Bearer $TRANSCRIPT_API_KEY in requests to https://transcriptapi.com/api/v2/youtube/ (and consult the OpenAPI spec for parameters)

Best Practices

  • Use free endpoints (channel/resolve, channel/latest) when possible
  • Cache responses and reuse tokens; monitor and respect rate limits
  • Validate inputs: channel as @handle, URL, or UC… ID; playlist with proper prefixes
  • Paginate results with continuation tokens for channel/videos and playlist/videos
  • Combine search results with transcripts to build richer, data-driven features

Example Use Cases

  • Get a video transcript from a YouTube URL
  • Search for videos by keyword and type
  • Resolve a channel handle to a canonical channel ID
  • Retrieve the latest videos from a channel
  • List all videos within a playlist

Frequently Asked Questions

Add this skill to your agents
Sponsor this space

Reach thousands of developers