3.0.11 • Published 4 years ago

taglib3 v3.0.11

Weekly downloads
42
License
LGPL-2.1
Repository
github
Last release
4 years ago

node-taglib3

Build Status NPM Version

A rewrite of node-taglib2 for Node 10 to 13 and taglib 1.11.1 with support for non-standard properties, a non-blocking API and ID3 GEOB attributes.

Installation

OSX/Linux

You need to have installed a proper C/C++ compiler toolchain, like GCC (For OSX please download Xcode and Command Line Tools).

Windows

You need to have Visual C++ Build Environment setup, which you can download as a standalone Visual C++ Build Tools package or get it as part of Visual Studio 2015.

Usage

For example, with electron:

ELECTRON=1 npm install

Writing tags

Specify an object of tag names and tag entries to (over) write. Tag entries must be arrays of strings. Not all file formats support multiple entries. See the taglib documentation for details.

Reading tags

const taglib = require('taglib3')
// sync
const tags = taglib.readTagsSync('file.mp3')
// async
const tags = taglib.readTags('file.mp3', (error, data) => console.log(error, data))
{
  "ARTIST": ["Howlin' Wolf"],
  "TITLE": ["Howlin' Wolf"],
  "MY_OWN_SPECIAL_ATTRIBUTE": ["datadatadata"],
  "DELETE_THIS": ["delete me"]
}
const taglib = require('taglib3')

const props = {
  artist: ['Howlin\' Wolf'],
  title: ['Evil is goin\' on'],
  my_own_special_attribute: ['datadatadata'],
  delete_this: []
}

// sync
taglib.writeTagsSync('file.mp3', props)
// async
taglib.writeTags('file.mp3', props, (error, data) => console.log(error, data))

GEOB

The keys are used to identify duplicate frames by their description, duplicates will be deleted. Data is passed using base64, encoded as mimetype\x00filename\x00description\x00data in Latin1 encoding.

const taglib = require('taglib3')
console.log(taglib.readId3TagsSync('file.mp3'))
taglib.writeId3TagsSync('file.mp3', {
  'Another Binary Attribute': Buffer.from('application/octet-stream\x00\x00Another Binary Attribute\x00hello mp3').toString('base64'),
  'Delete this': '',
})
{
  "Binary Attribute": ["aGVsbG8gd29ybGQ="]
}

Audio Properties

const taglib = require('taglib3')
console.log(taglib.readAudioPropertiesSync('file.mp3'))
{
  "bitrate": "192",
  "channels": "2",
  "length": "90"
}
3.0.11

4 years ago

3.0.10

4 years ago

3.0.9

4 years ago

3.0.8

4 years ago

3.0.7

4 years ago

3.0.6

4 years ago

3.0.5

4 years ago

3.0.4

4 years ago

3.0.3

4 years ago

3.0.2

4 years ago

3.0.1

4 years ago

3.0.0

4 years ago