Home

Awesome

fs-xattr

Node.js module for manipulating extended attributes.

There are already some libraries for this, why use fs-xattr?

Installation

npm install --save fs-xattr

Usage

import { getAttribute, setAttribute } from 'fs-xattr'

await setAttribute('index.js', 'user.linusu.test', 'Hello, World!')

console.log(await getAttribute('index.js', 'user.linusu.test'))
//=> Hello, World!

API

getAttribute(path, attr)

Get extended attribute attr from file at path.

getAttributeSync(path, attr)

Synchronous version of getAttribute.

setAttribute(path, attr, value)

Set extended attribute attr to value on file at path.

setAttributeSync(path, attr, value)

Synchronous version of setAttribute.

removeAttribute(path, attr)

Remove extended attribute attr on file at path.

removeAttributeSync(path, attr)

Synchronous version of removeAttribute.

listAttributes(path)

List all attributes on file at path.

listAttributesSync(path)

Synchronous version of listAttributes.

Namespaces

For the large majority of Linux filesystem there are currently 4 supported namespaces (user, trusted, security, and system) you can use. Some other systems, like FreeBSD have only 2 (user and system).

Be sure to use a namespace that is appropriate for your supported platforms. You can read more about this in the "Extended File Attributes" Wikipedia article.

Using a namespace like com.linusu.test would work on macOS, but would give you the following error on Debian Linux:

Error [ENOTSUP]: The file system does not support extended attributes or has the feature disabled.