]> git.saurik.com Git - apple/libc.git/blame - posix1e/acl_perm.c
Libc-1439.100.3.tar.gz
[apple/libc.git] / posix1e / acl_perm.c
CommitLineData
3d9156a7 1/*
1f2f436a 2 * Copyright (c) 2004-2010 Apple, Inc. All rights reserved.
3d9156a7
A
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
11 * file.
12 *
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
20 *
21 * @APPLE_LICENSE_HEADER_END@
22 */
23
24#include <sys/appleapiopts.h>
25#include <sys/types.h>
26#include <sys/acl.h>
27#include <errno.h>
28#include <stdlib.h>
29#include <string.h>
30
31#include "aclvar.h"
32
1f2f436a
A
33#if __DARWIN_ACL_READ_DATA != KAUTH_VNODE_READ_DATA
34# error __DARWIN_ACL_READ_DATA != KAUTH_VNODE_READ_DATA
35#endif
36#if __DARWIN_ACL_LIST_DIRECTORY != KAUTH_VNODE_LIST_DIRECTORY
37# error __DARWIN_ACL_LIST_DIRECTORY != KAUTH_VNODE_LIST_DIRECTORY
38#endif
39#if __DARWIN_ACL_WRITE_DATA != KAUTH_VNODE_WRITE_DATA
40# error __DARWIN_ACL_WRITE_DATA != KAUTH_VNODE_WRITE_DATA
41#endif
42#if __DARWIN_ACL_ADD_FILE != KAUTH_VNODE_ADD_FILE
43# error __DARWIN_ACL_ADD_FILE != KAUTH_VNODE_ADD_FILE
44#endif
45#if __DARWIN_ACL_EXECUTE != KAUTH_VNODE_EXECUTE
46# error __DARWIN_ACL_EXECUTE != KAUTH_VNODE_EXECUTE
47#endif
48#if __DARWIN_ACL_SEARCH != KAUTH_VNODE_SEARCH
49# error __DARWIN_ACL_SEARCH != KAUTH_VNODE_SEARCH
50#endif
51#if __DARWIN_ACL_DELETE != KAUTH_VNODE_DELETE
52# error __DARWIN_ACL_DELETE != KAUTH_VNODE_DELETE
53#endif
54#if __DARWIN_ACL_APPEND_DATA != KAUTH_VNODE_APPEND_DATA
55# error __DARWIN_ACL_APPEND_DATA != KAUTH_VNODE_APPEND_DATA
56#endif
57#if __DARWIN_ACL_ADD_SUBDIRECTORY != KAUTH_VNODE_ADD_SUBDIRECTORY
58# error __DARWIN_ACL_ADD_SUBDIRECTORY != KAUTH_VNODE_ADD_SUBDIRECTORY
59#endif
60#if __DARWIN_ACL_DELETE_CHILD != KAUTH_VNODE_DELETE_CHILD
61# error __DARWIN_ACL_DELETE_CHILD != KAUTH_VNODE_DELETE_CHILD
62#endif
63#if __DARWIN_ACL_READ_ATTRIBUTES != KAUTH_VNODE_READ_ATTRIBUTES
64# error __DARWIN_ACL_READ_ATTRIBUTES != KAUTH_VNODE_READ_ATTRIBUTES
65#endif
66#if __DARWIN_ACL_WRITE_ATTRIBUTES != KAUTH_VNODE_WRITE_ATTRIBUTES
67# error __DARWIN_ACL_WRITE_ATTRIBUTES != KAUTH_VNODE_WRITE_ATTRIBUTES
68#endif
69#if __DARWIN_ACL_READ_EXTATTRIBUTES != KAUTH_VNODE_READ_EXTATTRIBUTES
70# error __DARWIN_ACL_READ_EXTATTRIBUTES != KAUTH_VNODE_READ_EXTATTRIBUTES
71#endif
72#if __DARWIN_ACL_WRITE_EXTATTRIBUTES != KAUTH_VNODE_WRITE_EXTATTRIBUTES
73# error __DARWIN_ACL_WRITE_EXTATTRIBUTES != KAUTH_VNODE_WRITE_EXTATTRIBUTES
74#endif
75#if __DARWIN_ACL_READ_SECURITY != KAUTH_VNODE_READ_SECURITY
76# error __DARWIN_ACL_READ_SECURITY != KAUTH_VNODE_READ_SECURITY
77#endif
78#if __DARWIN_ACL_WRITE_SECURITY != KAUTH_VNODE_WRITE_SECURITY
79# error __DARWIN_ACL_WRITE_SECURITY != KAUTH_VNODE_WRITE_SECURITY
80#endif
81#if __DARWIN_ACL_CHANGE_OWNER != KAUTH_VNODE_CHANGE_OWNER
82# error __DARWIN_ACL_CHANGE_OWNER != KAUTH_VNODE_CHANGE_OWNER
83#endif
23e20b00
A
84#if __DARWIN_ACL_SYNCHRONIZE != KAUTH_VNODE_SYNCHRONIZE
85# error __DARWIN_ACL_SYNCHRONIZE != KAUTH_VNODE_SYNCHRONIZE
86#endif
1f2f436a 87
3d9156a7
A
88int
89acl_add_perm(acl_permset_t permset, acl_perm_t perm)
90{
91 /* XXX validate perms */
92 _ACL_VALIDATE_PERM(perm);
93
94 permset->ap_perms |= perm;
95 return(0);
96}
97
98int
99acl_clear_perms(acl_permset_t permset)
100{
101 /* XXX validate perms */
102
103 permset->ap_perms = 0;
104 return(0);
105}
106
107int
108acl_delete_perm(acl_permset_t permset, acl_perm_t perm)
109{
110 /* XXX validate perms */
111 _ACL_VALIDATE_PERM(perm);
112
113 permset->ap_perms &= ~perm;
114 return(0);
115}
116
117int
118acl_get_perm_np(acl_permset_t permset, acl_perm_t perm)
119{
120 _ACL_VALIDATE_PERM(perm);
121
122 return((perm & permset->ap_perms) ? 1 : 0);
123}
124
125int
126acl_get_permset(acl_entry_t entry, acl_permset_t *permset_p)
127{
128 _ACL_VALIDATE_ENTRY(entry);
129
130 *permset_p = (acl_permset_t)&entry->ae_perms;
131 return(0);
132}
133
134int
135acl_set_permset(acl_entry_t entry, acl_permset_t permset)
136{
137 _ACL_VALIDATE_ENTRY(entry);
138
139 entry->ae_perms = permset->ap_perms;
140 return(0);
141}
1f2f436a
A
142
143int
144acl_maximal_permset_mask_np(acl_permset_mask_t * mask_p)
145{
146 /* Bitwise or of all possible acl_perm_t values */
147 *mask_p = _ACL_PERMS_MASK;
148 return (0);
149}
150
151int
152acl_get_permset_mask_np(acl_entry_t entry, acl_permset_mask_t * mask_p)
153{
154 _ACL_VALIDATE_ENTRY(entry);
155
156 *mask_p = (acl_permset_mask_t)entry->ae_perms;
157 return (0);
158}
159
160int
161acl_set_permset_mask_np(acl_entry_t entry, acl_permset_mask_t mask)
162{
163 _ACL_VALIDATE_ENTRY(entry);
164 _ACL_VALIDATE_PERM(mask);
165
166 entry->ae_perms = mask;
167 return (0);
168}