Back to Skills
    šŸ¦ž

    youtube-api

    YouTube API access without the official API quota hassle

    By @therohitdas
    View on GitHub
    SKILL.md
    ---
    name: youtube-api
    description: YouTube API access without the official API quota hassle — transcripts, search, channels, playlists, and metadata with no Google API key needed. Use when the user needs YouTube data programmatically, wants to avoid Google API quotas, or asks for "youtube api", "get video data", "youtube without api key", "no quota youtube".
    homepage: https://transcriptapi.com
    metadata:
      {
        "moltbot":
          {
            "emoji": "⚔",
            "requires": { "env": ["TRANSCRIPT_API_KEY"] },
            "primaryEnv": "TRANSCRIPT_API_KEY",
          },
      }
    ---
    
    # YouTube API
    
    YouTube data access via [TranscriptAPI.com](https://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, generate a secure password.
    
    ```bash
    node ./scripts/tapi-auth.js register --email USER_EMAIL --password SECURE_PASS --json
    ```
    
    → OTP sent to email. Ask user: _"Check your email for a 6-digit verification code."_
    āš ļø **SAVE THE PASSWORD** — you need it again in Step 2!
    
    **Step 2 — Verify:** Once user provides the OTP (use SAME password from Step 1):
    
    ```bash
    node ./scripts/tapi-auth.js verify --email USER_EMAIL --password SECURE_PASS --otp CODE --json
    ```
    
    → Returns `api_key` (starts with `sk_`).
    
    **Step 3 — Save:** Store the key (auto-configures agent + shell):
    
    ```bash
    node ./scripts/tapi-auth.js save-key --key API_KEY --json
    ```
    
    → Ready to use. Agent runtime picks up the key automatically.
    
    Manual option: [transcriptapi.com/signup](https://transcriptapi.com/signup) → Dashboard → API Keys.
    
    ## Endpoint Reference
    
    All endpoints: `https://transcriptapi.com/api/v2/youtube/...`
    
    | Endpoint                               | Method | Cost     |
    | -------------------------------------- | ------ | -------- |
    | `/transcript?video_url=ID`             | GET    | 1        |
    | `/search?q=QUERY&type=video`           | GET    | 1        |
    | `/channel/resolve?input=@handle`       | GET    | **free** |
    | `/channel/latest?channel_id=UC_ID`     | GET    | **free** |
    | `/channel/videos?channel_id=UC_ID`     | GET    | 1/page   |
    | `/channel/search?channel_id=UC_ID&q=Q` | GET    | 1        |
    | `/playlist/videos?playlist_id=PL_ID`   | GET    | 1/page   |
    
    ## Quick Examples
    
    **Search videos:**
    
    ```bash
    curl -s "https://transcriptapi.com/api/v2/youtube/search\
    ?q=python+tutorial&type=video&limit=10" \
      -H "Authorization: Bearer $TRANSCRIPT_API_KEY"
    ```
    
    **Get transcript:**
    
    ```bash
    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):**
    
    ```bash
    curl -s "https://transcriptapi.com/api/v2/youtube/channel/resolve?input=@mkbhd" \
      -H "Authorization: Bearer $TRANSCRIPT_API_KEY"
    ```
    
    **Latest videos (free):**
    
    ```bash
    curl -s "https://transcriptapi.com/api/v2/youtube/channel/latest?channel_id=UC_CHANNEL_ID" \
      -H "Authorization: Bearer $TRANSCRIPT_API_KEY"
    ```
    
    **Browse channel uploads (paginated):**
    
    ```bash
    curl -s "https://transcriptapi.com/api/v2/youtube/channel/videos?channel_id=UC_CHANNEL_ID" \
      -H "Authorization: Bearer $TRANSCRIPT_API_KEY"
    # Use continuation token from response for next pages
    ```
    
    **Browse playlist (paginated):**
    
    ```bash
    curl -s "https://transcriptapi.com/api/v2/youtube/playlist/videos?playlist_id=PL_PLAYLIST_ID" \
      -H "Authorization: Bearer $TRANSCRIPT_API_KEY"
    ```
    
    ## Parameter Validation
    
    | Field          | Rule                                        |
    | -------------- | ------------------------------------------- |
    | `channel_id`   | `^UC[a-zA-Z0-9_-]{22}
    
      
        
        
        
        OpenClaw Resources Directory – Skills, Tools, Plugins & Guides | The Claw Guy
        
        
        
        
        
        
        
        
    
        
        
        
        
    
        
        
        
        
        
      
      
    
    
      
         (24 chars total)    |
    | `playlist_id`  | starts with `PL`, `UU`, `LL`, `FL`, or `OL` |
    | `q` (search)   | 1-200 chars                                 |
    | `limit`        | 1-50                                        |
    | `continuation` | non-empty string                            |
    
    ## Why Not Google's API?
    
    |             | Google YouTube Data API         | TranscriptAPI              |
    | ----------- | ------------------------------- | -------------------------- |
    | Quota       | 10,000 units/day (100 searches) | Credit-based, no daily cap |
    | Setup       | OAuth + API key + project       | Single API key             |
    | Transcripts | Not available                   | Core feature               |
    | Pricing     | $0.0015/unit overage            | $5/1000 credits            |
    
    ## Errors
    
    | Code | Meaning           | Action                    |
    | ---- | ----------------- | ------------------------- |
    | 401  | Bad API key       | Check key                 |
    | 402  | No credits        | transcriptapi.com/billing |
    | 404  | Not found         | Resource doesn't exist    |
    | 408  | Timeout/retryable | Retry once after 2s       |
    | 422  | Validation error  | Check param format        |
    | 429  | Rate limited      | Wait, respect Retry-After |
    
    Free tier: 100 credits, 300 req/min. Starter ($5/mo): 1,000 credits.
    (24 chars total) |\n| `playlist_id` | starts with `PL`, `UU`, `LL`, `FL`, or `OL` |\n| `q` (search) | 1-200 chars |\n| `limit` | 1-50 |\n| `continuation` | non-empty string |\n\n## Why Not Google's API?\n\n| | Google YouTube Data API | TranscriptAPI |\n| ----------- | ------------------------------- | -------------------------- |\n| Quota | 10,000 units/day (100 searches) | Credit-based, no daily cap |\n| Setup | OAuth + API key + project | Single API key |\n| Transcripts | Not available | Core feature |\n| Pricing | $0.0015/unit overage | $5/1000 credits |\n\n## Errors\n\n| Code | Meaning | Action |\n| ---- | ----------------- | ------------------------- |\n| 401 | Bad API key | Check key |\n| 402 | No credits | transcriptapi.com/billing |\n| 404 | Not found | Resource doesn't exist |\n| 408 | Timeout/retryable | Retry once after 2s |\n| 422 | Validation error | Check param format |\n| 429 | Rate limited | Wait, respect Retry-After |\n\nFree tier: 100 credits, 300 req/min. Starter ($5/mo): 1,000 credits.","Plugin_Install_Column":"","Plugin_Config_Column":"","Plugin_Readme_Column":""},"similar":[{"slug":"aisa-twitter-api-tqvcst","category":"Web","URL":"https://openclawdir.com/skills/aisa-twitter-api-tqvcst","Type":"Skill","Title":"aisa-twitter-api","Description":"Search X (Twitter) in real time, extract relevant posts","GitHub_Link":"https://github.com/aisapay"},{"slug":"backup-iq4jsc","category":"Web","URL":"https://openclawdir.com/skills/backup-iq4jsc","Type":"Skill","Title":"backup","Description":"Backup and restore openclaw configuration, skills, commands, and settings.","GitHub_Link":"https://github.com/jordanprater"},{"slug":"clawdbot-backup-1aikk1","category":"Web","URL":"https://openclawdir.com/skills/clawdbot-backup-1aikk1","Type":"Skill","Title":"clawdbot-backup","Description":"Backup and restore ClawdBot configuration, skills","GitHub_Link":"https://github.com/sebastian-buitrag0"},{"slug":"clankedin-rw0i87","category":"Web","URL":"https://openclawdir.com/skills/clankedin-rw0i87","Type":"Skill","Title":"clankedin","Description":"Use the ClankedIn API to register agents, post updates, connect","GitHub_Link":"https://github.com/hukifl1"}]}