yt-dlp-exec-fork v2.0.2
YT-DLP
- I just changed the environment variables so it would work with yt-dlp instead of youtube-dl
A simple Node.js wrapper for youtube-dl.
Why
- Auto install the latest youtube-dlversion available.
- Executes any command in an efficient way.
- Promise & Stream interface support.
Install
$ npm install youtube-dl-exec --saveUsage
const youtubedl = require('youtube-dl-exec')
youtubedl('https://example.com', {
  dumpSingleJson: true,
  noWarnings: true,
  noCallHome: true,
  noCheckCertificate: true,
  preferFreeFormats: true,
  youtubeSkipDashManifest: true,
  referer: 'https://example.com'
})
  .then(output => console.log(output))It's equivalent to:
$ youtube-dl https://example.com --dump-single-json --no-warnings --no-call-home --no-check-certificate --prefer-free-formats --youtube-skip-dash-manifest --referer=https://example.comThe library will use the latest youtube-dl available that will downloaded on build time.
Alternatively, you can specify your own binary path using .create:
const { create: createYoutubeDl } = require('youtube-dl-exec')
const youtubedl = createYoutubeDl('/my/binary/path')You can combine it with YOUTUBE_DL_SKIP_DOWNLOAD. See environment variables to know more.
API
youtubedl(url, flags, options)
It execs any youtube-dl command, returning back the output.
url
Required
Type: string
The URL to target.
flags
Type: object
Any flag supported by youtube-dl.
options
Any option provided here will passed to execa#options.
youtubedl.exec(url, flags, options)
Similar to main method but instead of a parsed output, it will return the internal subprocess object
const youtubedl = require('youtube-dl-exec')
const fs = require('fs')
const subprocess = youtubedl.exec('https://example.com', { dumpSingleJson: true })
console.log(`Running subprocess as ${subprocess.pid}`)
subprocess.stdout.pipe(fs.createWriteStream('stdout.txt'))
subprocess.stderr.pipe(fs.createWriteStream('stderr.txt'))
setTimeout(subprocess.cancel, 30000)youtubedl.create(binaryPath)
It creates a youtube-dl using the binaryPath provided.
Environment variables
The environment variables are taken into account when you perform a npm install in a project that contains youtube-dl-exec dependency.
These environment variables can also be set through "npm config", for example npm install --YOUTUBE_DL_HOST="Some URL", or store it in .npmrc file.
They setup the download configuration for getting the youtube-dl binary file.
These variables can be
YOUTUBE_DL_HOST
It determines the remote URL for getting the youtube-dl binary file.
The default URL is ytdl-org/youtube-dl latest release.
YOUTUBE_DL_DIR
It determines the folder where to put the binary file.
The default folder is bin.
YOUTUBE_DL_FILENAME
It determines the binary filename.
The default binary file could be youtube-dl or youtube-dl.exe, depending of the YOUTUBE_DL_PLATFORM value.
YOUTUBE_DL_PLATFORM
It determines the architecture of the machine that will use the youtube-dl binary.
The default value will computed from process.platform, being 'unix' or 'win32'.
YOUTUBE_DL_SKIP_DOWNLOAD
When is present, it will skip the postinstall script for fetching the latest youtube-dl version.
That variable should be set before performing the installation command, such as:
YOUTUBE_DL_SKIP_DOWNLOAD=true npm installLicense
youtube-dl-exec © microlink.io, released under the MIT License. Authored and maintained by Kiko Beats with help from contributors.
microlink.io · GitHub microlink.io · Twitter @microlinkhq
4 years ago