Skip to content

NodeJS app for ripping SHOUTcast/Icecast radio streams to individual audio files

License

Notifications You must be signed in to change notification settings

krizzdewizz/node-icy-rip

Repository files navigation

icy-rip

NodeJS CLI tool for ripping SHOUTcast/Icecast radio streams to individual audio files.

Installation

Install with npm:

$ npm install icy-rip -g

Recording

$ icy-rip <url> [optional output folder][-t]

Where url can be a SHOUTcast/Icecast stream, a PLS or M3U playlist. if optional output folder is missing, files will be placed in a recordings folder underneath the current directory. If -t is given, the raw audio data is written also to stdout, to be consumed by other programs such as mpg123.

$ icy-rip http://1.2.3.4:5678 -t | mpg123 -

To cancel recording, press ctrl+c.

ID3 tags

In order to add ID3 tags to the recorded files, ffmpeg must be present on the system path.

From where to get an url?

You may want to visit the SHOUTcast website, copy the Winamp (PLS) or M3U url to the clipboard and paste it to the shell window:

SHOUTcast directory

Settings

More settings can be configured by providing a JavaScript file/NodeJS module named .icy-rip.js at these locations:

  • current working directory.
  • user's home directory. See here for locations depending to your OS.

The module exports the settings object:

module.exports = {

    /**
     * Filter a track from recording.
     * @param track info about the track: { title: "track title" }
     * @return truthy to record the track, falsy to skip the track
     */
    filter: function(track) {
        return track.title.match(/prelude/i);
    }
};

About

NodeJS app for ripping SHOUTcast/Icecast radio streams to individual audio files

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published