node-ffprobe
Version:
NodeJS wrapper around ffprobe
126 lines (98 loc) • 3.29 kB
Markdown
in NodeJS
***This module requires ffmpeg to be installed before it can function***. The ffprobe utility comes bundled with ffmpeg. If you just need this to work under multiple configs consider using `@ffprobe-installer/ffprobe` as detailed in the usage example below
```sh
npm install --save node-ffprobe
npm install --save github:ListenerApproved/node-ffprobe
yarn add node-ffprobe
```
$ npm i
```js
const probe = require('node-ffprobe')
const ffprobeInstaller = require('@ffprobe-installer/ffprobe')
console.log(ffprobeInstaller.path, ffprobeInstaller.version)
ffprobe.FFPROBE_PATH = ffprobeInstaller.path
var track = '/path/to/media/file.mp3' // or video
probe(track).then(probeData => {
console.log(probeData)
})
```
FFPROBE_PATH is useful if you embed the lib in your app.
Calling probe will execute ffprobe and parse the data it sends to STDOUT. A sample object can be seen below.
Additionnally, you can set `ffprobe.SYNC` to `true` if you want for a particular reason to launch ffprobe synchronously (for example when used in batch processing of files to avoid too many spawns at once.)
The JSON returned by this utility is directly produced by ffprobe using the `-print_format json` flag
### Example Output
```js
{
"programs": [],
"streams": [
{
"index": 0,
"codec_name": "mp3",
"codec_long_name": "MP3 (MPEG audio layer 3)",
"codec_type": "audio",
"codec_time_base": "1/44100",
"codec_tag_string": "[0][0][0][0]",
"codec_tag": "0x0000",
"sample_fmt": "fltp",
"sample_rate": "44100",
"channels": 2,
"channel_layout": "stereo",
"bits_per_sample": 0,
"r_frame_rate": "0/0",
"avg_frame_rate": "0/0",
"time_base": "1/14112000",
"start_pts": 353600,
"start_time": "0.025057",
"duration_ts": 1865687040,
"duration": "132.205714",
"bit_rate": "320000",
"disposition": {
"default": 0,
"dub": 0,
"original": 0,
"comment": 0,
"lyrics": 0,
"karaoke": 0,
"forced": 0,
"hearing_impaired": 0,
"visual_impaired": 0,
"clean_effects": 0,
"attached_pic": 0,
"timed_thumbnails": 0
},
"tags": {
"encoder": "LAME3.99r"
}
}
],
"chapters": [],
"format": {
"filename": "/Users/im.a.little.teapot/Downloads/file_example_MP3_5MG.mp3",
"nb_streams": 1,
"nb_programs": 0,
"format_name": "mp3",
"format_long_name": "MP2/3 (MPEG audio layer 2/3)",
"start_time": "0.025057",
"duration": "132.205714",
"size": "5289384",
"bit_rate": "320069",
"probe_score": 51,
"tags": {
"genre": "Cinematic",
"album": "YouTube Audio Library",
"title": "Impact Moderato",
"artist": "Kevin MacLeod"
}
}
}
```
* Timeouts for async invocation
* move package to unified nodejs ffmpeg library
A simple sync wrapper around ffprobe written