]>
git.saurik.com Git - apple/libc.git/blob - posix1e/acl_entry.c
2 * Copyright (c) 2004, 2011 Apple Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
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
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.
21 * @APPLE_LICENSE_HEADER_END@
24 #include <sys/appleapiopts.h>
25 #include <sys/types.h>
33 #if __DARWIN_ACL_EXTENDED_ALLOW != KAUTH_ACE_PERMIT
34 # error __DARWIN_ACL_EXTENDED_ALLOW != KAUTH_ACE_PERMIT
36 #if __DARWIN_ACL_EXTENDED_DENY != KAUTH_ACE_DENY
37 # error __DARWIN_ACL_EXTENDED_DENY != KAUTH_ACE_DENY
41 acl_copy_entry(acl_entry_t dest
, acl_entry_t src
)
43 /* validate arguments */
44 _ACL_VALIDATE_ENTRY(dest
);
45 _ACL_VALIDATE_ENTRY(src
);
50 bcopy(src
, dest
, sizeof(*src
));
55 acl_create_entry_np(acl_t
*acl_p
, acl_entry_t
*entry_p
, int index
)
57 struct _acl
*ap
= *acl_p
;
60 /* validate arguments */
61 _ACL_VALIDATE_ACL(ap
);
62 if (ap
->a_entries
>= ACL_MAX_ENTRIES
) {
66 if (index
== ACL_LAST_ENTRY
)
67 index
= ap
->a_entries
;
68 if (index
> ap
->a_entries
) {
73 /* move following entries out of the way */
74 for (i
= ap
->a_entries
; i
> index
; i
--)
75 ap
->a_ace
[i
] = ap
->a_ace
[i
- 1];
78 /* initialise new entry */
79 memset(&ap
->a_ace
[index
], 0, sizeof(ap
->a_ace
[index
]));
80 ap
->a_ace
[index
].ae_magic
= _ACL_ENTRY_MAGIC
;
81 ap
->a_ace
[index
].ae_tag
= ACL_UNDEFINED_TAG
;
83 *entry_p
= &ap
->a_ace
[index
];
88 acl_create_entry(acl_t
*acl_p
, acl_entry_t
*entry_p
)
90 return(acl_create_entry_np(acl_p
, entry_p
, ACL_LAST_ENTRY
));
94 acl_delete_entry(acl_t acl
, acl_entry_t entry
)
98 _ACL_VALIDATE_ACL(acl
);
99 _ACL_VALIDATE_ENTRY(entry
);
100 _ACL_VALIDATE_ENTRY_CONTAINED(acl
, entry
);
102 /* copy following entries down & invalidate last slot */
104 for (i
= entry
- &acl
->a_ace
[0]; i
< acl
->a_entries
; i
++)
105 acl
->a_ace
[i
] = acl
->a_ace
[i
+ 1];
106 acl
->a_ace
[acl
->a_entries
].ae_magic
= 0;
107 /* Sync up the iterator's position if necessary */
108 if (acl
->a_last_get
>= (entry
- &acl
->a_ace
[0]))
115 acl_get_entry(acl_t acl
, int entry_id
, acl_entry_t
*entry_p
)
118 _ACL_VALIDATE_ACL(acl
);
119 if ((entry_id
!= ACL_FIRST_ENTRY
) &&
120 (entry_id
!= ACL_NEXT_ENTRY
) &&
121 (entry_id
!= ACL_LAST_ENTRY
) &&
122 ((entry_id
< 0) || (entry_id
>= acl
->a_entries
))) {
126 if (entry_id
== ACL_FIRST_ENTRY
)
129 if (entry_id
== ACL_NEXT_ENTRY
) {
130 entry_id
= acl
->a_last_get
+ 1;
133 if (entry_id
== ACL_LAST_ENTRY
)
134 entry_id
= acl
->a_entries
- 1;
136 if (entry_id
>= acl
->a_entries
) {
141 *entry_p
= &acl
->a_ace
[entry_id
];
142 acl
->a_last_get
= entry_id
;
148 acl_get_qualifier(acl_entry_t entry
)
155 if (!_ACL_VALID_ENTRY(entry
)) {
157 } else if ((error
= acl_get_tag_type(entry
, &tag_type
)) != 0) {
158 /* errno is set by acl_get_tag_type */
161 case ACL_EXTENDED_ALLOW
:
162 case ACL_EXTENDED_DENY
:
163 if ((result
= malloc(sizeof(guid_t
))) != NULL
)
164 bcopy(&entry
->ae_applicable
, result
, sizeof(guid_t
));
175 acl_get_tag_type(acl_entry_t entry
, acl_tag_t
*tag_type_p
)
177 _ACL_VALIDATE_ENTRY(entry
);
179 *tag_type_p
= entry
->ae_tag
;
184 acl_set_qualifier(acl_entry_t entry
, const void *tag_qualifier_p
)
188 _ACL_VALIDATE_ENTRY(entry
);
189 if (acl_get_tag_type(entry
, &tag_type
) != 0)
193 case ACL_EXTENDED_ALLOW
:
194 case ACL_EXTENDED_DENY
:
195 bcopy(tag_qualifier_p
, &entry
->ae_applicable
, sizeof(guid_t
));
205 acl_set_tag_type(acl_entry_t entry
, acl_tag_t tag_type
)
207 _ACL_VALIDATE_ENTRY(entry
);
210 case ACL_EXTENDED_ALLOW
:
211 case ACL_EXTENDED_DENY
:
212 entry
->ae_tag
= tag_type
;