1515d7c92SRobert Watson /*- 22de14c39SRobert Watson * Copyright (c) 1999, 2000, 2001 Robert N. M. Watson 3515d7c92SRobert Watson * All rights reserved. 4515d7c92SRobert Watson * 5515d7c92SRobert Watson * Redistribution and use in source and binary forms, with or without 6515d7c92SRobert Watson * modification, are permitted provided that the following conditions 7515d7c92SRobert Watson * are met: 8515d7c92SRobert Watson * 1. Redistributions of source code must retain the above copyright 9515d7c92SRobert Watson * notice, this list of conditions and the following disclaimer. 10515d7c92SRobert Watson * 2. Redistributions in binary form must reproduce the above copyright 11515d7c92SRobert Watson * notice, this list of conditions and the following disclaimer in the 12515d7c92SRobert Watson * documentation and/or other materials provided with the distribution. 13515d7c92SRobert Watson * 14515d7c92SRobert Watson * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15515d7c92SRobert Watson * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16515d7c92SRobert Watson * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17515d7c92SRobert Watson * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18515d7c92SRobert Watson * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19515d7c92SRobert Watson * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20515d7c92SRobert Watson * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21515d7c92SRobert Watson * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22515d7c92SRobert Watson * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23515d7c92SRobert Watson * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24515d7c92SRobert Watson * SUCH DAMAGE. 25515d7c92SRobert Watson * 26515d7c92SRobert Watson * $FreeBSD$ 27515d7c92SRobert Watson */ 28515d7c92SRobert Watson /* 29515d7c92SRobert Watson * acl_get_file - syscall wrapper for retrieving ACL by filename 308f45e8c0SRobert Watson * acl_get_fd - syscall wrapper for retrieving access ACL by fd 318f45e8c0SRobert Watson * acl_get_fd_np - syscall wrapper for retrieving ACL by fd (non-POSIX) 324bf60dfaSChris D. Faulhaber * acl_get_permset() returns the permission set in the ACL entry 334bf60dfaSChris D. Faulhaber * acl_get_qualifier() retrieves the qualifier of the tag from the ACL entry 344bf60dfaSChris D. Faulhaber * acl_get_tag_type() returns the tag type for the ACL entry entry_d 35515d7c92SRobert Watson */ 36515d7c92SRobert Watson 37515d7c92SRobert Watson #include <sys/types.h> 387bd44e92SThomas Moestl #include "namespace.h" 39515d7c92SRobert Watson #include <sys/acl.h> 407bd44e92SThomas Moestl #include "un-namespace.h" 414bf60dfaSChris D. Faulhaber 424bf60dfaSChris D. Faulhaber #include <errno.h> 43515d7c92SRobert Watson #include <stdlib.h> 444bf60dfaSChris D. Faulhaber #include <string.h> 45515d7c92SRobert Watson 46515d7c92SRobert Watson acl_t 47515d7c92SRobert Watson acl_get_file(const char *path_p, acl_type_t type) 48515d7c92SRobert Watson { 49515d7c92SRobert Watson struct acl *aclp; 50515d7c92SRobert Watson int error; 51515d7c92SRobert Watson 52d3352316SRobert Watson aclp = acl_init(ACL_MAX_ENTRIES); 53515d7c92SRobert Watson if (!aclp) { 54f0078215SRobert Watson return (NULL); 55515d7c92SRobert Watson } 56515d7c92SRobert Watson 57d3352316SRobert Watson error = __acl_get_file(path_p, type, aclp); 58515d7c92SRobert Watson if (error) { 59515d7c92SRobert Watson acl_free(aclp); 60f0078215SRobert Watson return (NULL); 61515d7c92SRobert Watson } 62515d7c92SRobert Watson 63515d7c92SRobert Watson return (aclp); 64515d7c92SRobert Watson } 65515d7c92SRobert Watson 668f45e8c0SRobert Watson acl_t 678f45e8c0SRobert Watson acl_get_fd(int fd) 688f45e8c0SRobert Watson { 698f45e8c0SRobert Watson struct acl *aclp; 708f45e8c0SRobert Watson int error; 718f45e8c0SRobert Watson 728f45e8c0SRobert Watson aclp = acl_init(ACL_MAX_ENTRIES); 738f45e8c0SRobert Watson if (!aclp) { 74f0078215SRobert Watson return (NULL); 758f45e8c0SRobert Watson } 768f45e8c0SRobert Watson 777bd44e92SThomas Moestl error = ___acl_get_fd(fd, ACL_TYPE_ACCESS, aclp); 788f45e8c0SRobert Watson if (error) { 798f45e8c0SRobert Watson acl_free(aclp); 80f0078215SRobert Watson return (NULL); 818f45e8c0SRobert Watson } 828f45e8c0SRobert Watson 838f45e8c0SRobert Watson return (aclp); 848f45e8c0SRobert Watson } 85515d7c92SRobert Watson 86515d7c92SRobert Watson acl_t 878f45e8c0SRobert Watson acl_get_fd_np(int fd, acl_type_t type) 88515d7c92SRobert Watson { 89515d7c92SRobert Watson struct acl *aclp; 90515d7c92SRobert Watson int error; 91515d7c92SRobert Watson 92d3352316SRobert Watson aclp = acl_init(ACL_MAX_ENTRIES); 93515d7c92SRobert Watson if (!aclp) { 94f0078215SRobert Watson return (NULL); 95515d7c92SRobert Watson } 96515d7c92SRobert Watson 977bd44e92SThomas Moestl error = ___acl_get_fd(fd, type, aclp); 98515d7c92SRobert Watson if (error) { 99515d7c92SRobert Watson acl_free(aclp); 100f0078215SRobert Watson return (NULL); 101515d7c92SRobert Watson } 102515d7c92SRobert Watson 103515d7c92SRobert Watson return (aclp); 104515d7c92SRobert Watson } 1054bf60dfaSChris D. Faulhaber 1064bf60dfaSChris D. Faulhaber int 1074bf60dfaSChris D. Faulhaber acl_get_permset(acl_entry_t entry_d, acl_permset_t *permset_p) 1084bf60dfaSChris D. Faulhaber { 1094bf60dfaSChris D. Faulhaber 1104bf60dfaSChris D. Faulhaber if (!entry_d || !permset_p) { 1114bf60dfaSChris D. Faulhaber errno = EINVAL; 1124bf60dfaSChris D. Faulhaber return -1; 1134bf60dfaSChris D. Faulhaber } 1144bf60dfaSChris D. Faulhaber 1154bf60dfaSChris D. Faulhaber *permset_p = &entry_d->ae_perm; 1164bf60dfaSChris D. Faulhaber 1174bf60dfaSChris D. Faulhaber return 0; 1184bf60dfaSChris D. Faulhaber } 1194bf60dfaSChris D. Faulhaber 1204bf60dfaSChris D. Faulhaber void * 1214bf60dfaSChris D. Faulhaber acl_get_qualifier(acl_entry_t entry_d) 1224bf60dfaSChris D. Faulhaber { 1234bf60dfaSChris D. Faulhaber uid_t *retval; 1244bf60dfaSChris D. Faulhaber 1254bf60dfaSChris D. Faulhaber if (!entry_d) { 1264bf60dfaSChris D. Faulhaber errno = EINVAL; 1274bf60dfaSChris D. Faulhaber return NULL; 1284bf60dfaSChris D. Faulhaber } 1294bf60dfaSChris D. Faulhaber 1304bf60dfaSChris D. Faulhaber switch(entry_d->ae_tag) { 1314bf60dfaSChris D. Faulhaber case ACL_USER: 1324bf60dfaSChris D. Faulhaber case ACL_GROUP: 1334bf60dfaSChris D. Faulhaber retval = malloc(sizeof(uid_t)); 1344bf60dfaSChris D. Faulhaber if (retval) { 1354bf60dfaSChris D. Faulhaber *retval = entry_d->ae_id; 1364bf60dfaSChris D. Faulhaber return retval; 1374bf60dfaSChris D. Faulhaber } 1384bf60dfaSChris D. Faulhaber } 1394bf60dfaSChris D. Faulhaber 1404bf60dfaSChris D. Faulhaber errno = EINVAL; 1414bf60dfaSChris D. Faulhaber return NULL; 1424bf60dfaSChris D. Faulhaber } 1434bf60dfaSChris D. Faulhaber 1444bf60dfaSChris D. Faulhaber int 1454bf60dfaSChris D. Faulhaber acl_get_tag_type(acl_entry_t entry_d, acl_tag_t *tag_type_p) 1464bf60dfaSChris D. Faulhaber { 1474bf60dfaSChris D. Faulhaber 1484bf60dfaSChris D. Faulhaber if (!entry_d || !tag_type_p) { 1494bf60dfaSChris D. Faulhaber errno = EINVAL; 1504bf60dfaSChris D. Faulhaber return -1; 1514bf60dfaSChris D. Faulhaber } 1524bf60dfaSChris D. Faulhaber 1534bf60dfaSChris D. Faulhaber *tag_type_p = entry_d->ae_tag; 1544bf60dfaSChris D. Faulhaber 1554bf60dfaSChris D. Faulhaber return 0; 1564bf60dfaSChris D. Faulhaber } 157