ACL_STRIP(3SEC) File Access Control Library Functions ACL_STRIP(3SEC)

NAME


acl_strip - remove all ACLs from a file

SYNOPSIS


cc [ flag... ] file... -lsec [ library... ]
#include <sys/acl.h>

int acl_strip(const char *path, uid_t uid, gid_t gid, mode_t mode);


DESCRIPTION


The acl_strip() function removes all ACLs from a file and replaces
them with a trivial ACL based on the mode argument. After replacing
the ACL, the owner and group of the file are set to the values
specified by the uid and gid arguments.

RETURN VALUES


Upon successful completion, acl_strip() returns 0. Otherwise it
returns -1 and sets errno to indicate the error.

ERRORS


The acl_strip() function will fail if:

EACCES
Search permission is denied on a component of the
path prefix of path.


EFAULT
The path argument points to an illegal address.


EINVAL
The uid or gid argument is out of range.


EIO
A disk I/O error has occurred while storing or
retrieving the ACL.


ELOOP
A loop exists in symbolic links encountered during
the resolution of the path argument.


ENAMETOOLONG
The length of the path argument exceeds {PATH_MAX},
or the length of a path component exceeds {NAME_MAX}
while _POSIX_NO_TRUNC is in effect.


ENOENT
A component of path does not exist.


ENOTDIR
A component of the prefix of path is not a directory.


EPERM
The effective user ID does not match the owner of the
file and the process does not have appropriate
privileges.


EROFS
The file system is mounted read-only.


ATTRIBUTES


See attributes(7) for descriptions of the following attributes:


+--------------------+-----------------+
| ATTRIBUTE TYPE | ATTRIBUTE VALUE |
+--------------------+-----------------+
|Interface Stability | Evolving |
+--------------------+-----------------+
|MT-Level | MT-Safe |
+--------------------+-----------------+

SEE ALSO


acl_get(3SEC), acl_trivial(3SEC), acl(7), attributes(7)

October 6, 2005 ACL_STRIP(3SEC)

tribblix@gmail.com :: GitHub :: Privacy