Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@qodestack/dl-yt-playlist

Package Overview
Dependencies
Maintainers
1
Versions
67
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@qodestack/dl-yt-playlist

Download all videos (or audio only) from a YouTube playlist!

  • 4.6.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
94
increased by4600%
Maintainers
1
Weekly downloads
 
Created
Source

Download YouTube Playlist

Download all videos from a YouTube playlist. You can optionally download the audio and thumbnail images as well.

Prerequisites

You'll need a few things to use this project:

  • This project uses Bun! Get that installed or feel free to edit the source code to use Node instead (it'll only be a few adjustments).
  • You'll need a YouTube Data API key. Set that to the API_KEY env variable.
  • The yt-dlp command line tool needs to be present on your system. You can easily install it with a tool like Brew.

Usage

The type signature looks like this:

downloadYoutubePlaylist({
  // YouTube playlist id.
  playlistId: string

  // YouTube API key.
  apiKey: string

  // Full path to the directory where you want to save your data.
  directory: string

  /**
   * 'audio' - will only save videos as mp3 files and include json metadata
   * 'video' - will only save videos as mp4 files and incluide json metadata
   * 'both' - will save videos as mp3 and mp4 files and include json metadata
   * 'none' - will only save json metadata
   */
  downloadType: DownloadType

  /**
   * Optional - default value `false`
   *
   * Boolean indicating if the full playlist data get's fetched or not.
   *
   * `true`  - download all items in the playlist
   * `false` - download only the 50 most recent items in the playlist
   */
  includeFullData?: boolean

  /**
   * Optional - default value `Infinity`
   *
   * The maximum duration a playlist item can be to be downloaded.
   */
  maxDurationSeconds?: number

  /**
   * Optional - default value `false`
   *
   * Boolean indicating whether to download the video thumbnails as jpg files.
   */
  downloadThumbnails?: boolean

  /**
   * Optiona - default value `false`
   *
   * Boolean indicated whether to save the response data directly from the
   * YouTube API. This can be helpful for debugging. If set to `true`, two files
   * will be saved:
   *
   * - youtubePlaylistResponses.json
   * - youtubeVideoResponses.json
   */
  saveRawResponses?: boolean

  /**
   * Optional - default value `false`
   *
   * Boolean indicating wether to silence all internal console.log's. This will
   * not silence messages indicating missing `yt-dlp` or being offline.
   */
  silent?: boolean
}): Promise<{
  failures: {
    url: string // The url of failed resource.
    title: string // The video title.
    error: unknown

    /**
     * 'video' - the attempted download was a YouTube video.
     * 'thumbnail' - the attempted download was a thumbnail image.
     * 'ffmpeg' - ffmpeg failed to convert the downloaded video into an mp3 file.
     */
    type: 'video' | 'thumbnail' | 'ffmpeg'
  }[]
  failureCount: number
  date: string // new Date().toLocaleDateString()
  dateNum: number // Date.now()
  totalVideosDownloaded: number
  totalThumbnailsDownloaded: number
}>

Folder Structure

Downloads will be organized into the following folder structure:

directory-you-provided
  /<playlist name>
    /video
      <title> [<video id>].mp4
      ...
    /audio
      <title> [<video id>].mp3
      ...
    /thumbnails
      <video id>.jpg
      ...
    metadata.json
    youtubePlaylistResponses.json (only if `saveRawResponses` is true)
    youtubeVideoResponses.json (only if `saveRawResponses` is true)
/videoThis folder will contain all the mp4 video files
/audioThis folder will contain all the mp3 audio files
/thumbnailsThis folder will contain all the jpg thumbnail files
metadata.jsonThis file will contain an array of metadata on each video. See shape below
youtubePlaylistResponses.jsonThis file will contain an array of raw responses from YouTube's PlaylistItems: list api.
youtubeVideoResponses.jsonThis file will contain an array of raw responses from YouTube's Videos: list api.

Metadata Shape

Each video will have metadata stored in the metadata.json with the following shape:

{
  id: string
  title: string
  channelId: string
  channelName: string
  dateAddedToPlaylist: string
  durationInSeconds: number | null
  url: string
  thumbnaillUrl: string
  dateCreated: string

  /**
   * This value will be changed to `true` when future API calls are made and the
   * video is found to be unavailable. This will allow us to retain previously
   * fetch metadata.
   */
  isUnavailable?: boolean
}

Keywords

FAQs

Package last updated on 23 Mar 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc