NAME

File::ExtAttr - Perl extension for accessing extended attributes of files

SYNOPSIS

use File::ExtAttr ':all';
use IO::File;

# Manipulate the extended attributes of files.
setfattr('foo.txt', 'user.colour', 'red') || die;
my $colour = getfattr('bar.txt', 'user.colour');
if (defined($colour))
{
    print $colour;
    delfattr('bar.txt', 'user.colour');
}

# Manipulate the extended attributes of a file via a file handle.
my $fh = new IO::File('<foo.txt') || die;
setfattr($fh, 'user.colour', 'red') || die;

$fh = new IO::File('<bar.txt') || die;
$colour = getfattr($fh, 'user.colour');
if (defined($colour))
{
    print $colour;
    delfattr($fh, 'user.colour');
}

DESCRIPTION

File::ExtAttr is a Perl module providing access to the extended attributes of files.

Extended attributes are metadata associated with a file. Examples are access control lists (ACLs) and other security parameters. But users can add their own key=value pairs.

Extended attributes may not be supported by your operating system. This module is aimed at Linux, Unix or Unix-like operating systems (e.g.: Mac OS X, FreeBSD, NetBSD, OpenBSD).

Extended attributes may also not be supported by your filesystem or require special options to be enabled for a particular filesystem (e.g. "mount -o user_xattr /dev/hda1 /some/path").

NOTE: The API is not stable. It may change as part of supporting multiple operating systems.

METHODS

getfattr([$filename | $filehandle], $attrname, [$flags])

Return the value of the attribute named $attrname for the file named $filename or referenced by the open filehandle $filehandle (which should be an IO::Handle).

$flags are currently unused.

If no attribute is found, returns undef. Otherwise gives a warning.

setfattr([$filename | $filehandle], $attrname, $attrval, [$flags])

Set the attribute named $attrname with the value $attrval for the file named $filename or referenced by the open filehandle $filehandle (which should be an IO::Handle).

$flags allows control of whether the attribute should be created or should replace an existing attribute's value. The value File::ExtAttr::XATTR_CREATE will cause setfattr to fail if the attribute already exists. The value File::ExtAttr::XATTR_REPLACE will cause setfattr to fail if the attribute does not already exist. If $flags is omitted, then the attribute will be created if necessary or silently replaced.

NOTE: XATTR_* are currently Linux-specific. A more portable set of flags is on the to-do list.

If the attribute could not be set, a warning is issued.

delfattr([$filename | $filehandle], $attrname, [$flags])

Delete the attribute named $attrname for the file named $filename or referenced by the open filehandle $filehandle (which should be an IO::Handle).

$flags are currently unused.

Returns true on success, otherwise false and a warning is issued.

listfattr([$filename | $filehandle], [$flags])

Return the attributes on the file named $filename or referenced by the open filehandle $filehandle (which should be an IO::Handle).

$flags are currently unused.

Returns undef on failure and $! will be set.

EXPORT

None by default.

You can request that getfattr, setfattr and delfattr be exported using the tag ":all".

Exportable constants

None

SEE ALSO

The latest version of this software should be available from its home page: http://sourceforge.net/projects/file-extattr/

OS2::ExtAttr provides access to extended attributes on OS/2.

Eiciel, http://rofi.pinchito.com/eiciel/, is an access control list (ACL) editor for GNOME; the ACLs are stored in extended attributes.

Various low-level APIs exist for manipulating extended attributes:

Linux

http://www.die.net/doc/linux/man/man2/getxattr.2.html

http://www.die.net/doc/linux/man/man5/attr.5.html

OpenBSD

OpenBSD > 3.8 supports extended attributes.

http://www.openbsd.org/cgi-bin/man.cgi?query=extattr_get_file&apropos=0&sektion=0&manpath=OpenBSD+Current&arch=i386&format=html

FreeBSD

FreeBSD >= 5.0 supports extended attributes.

http://www.freebsd.org/cgi/man.cgi?query=extattr&sektion=2&apropos=0&manpath=FreeBSD+6.0-RELEASE+and+Ports

NetBSD

NetBSD >= 3.0 supports extended attributes, but you'll need to use NetBSD >= 4.0 to have a filesystem that supports them.

http://netbsd.gw.com/cgi-bin/man-cgi?extattr_get_file+2+NetBSD-current

Mac OS X

http://developer.apple.com/documentation/Darwin/Reference/ManPages/man2/getxattr.2.html

http://arstechnica.com/reviews/os/macosx-10.4.ars/7

Solaris

http://docsun.cites.uiuc.edu/sun_docs/C/solaris_9/SUNWaman/hman3c/attropen.3c.html

http://docsun.cites.uiuc.edu/sun_docs/C/solaris_9/SUNWaman/hman5/fsattr.5.html

AUTHOR

Kevin M. Goess, <kgoess@ensenda.com>

Richard Dawe, <rich@phekda.gotadsl.co.uk>

COPYRIGHT AND LICENSE

Copyright (C) 2005 by Kevin M. Goess

Copyright (C) 2005, 2006 by Richard Dawe

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.5 or, at your option, any later version of Perl 5 you may have available.