summaryrefslogtreecommitdiffstats
path: root/lib/libc/posix1e/acl_valid.c
diff options
context:
space:
mode:
authorrwatson <rwatson@FreeBSD.org>2000-01-15 19:44:27 +0000
committerrwatson <rwatson@FreeBSD.org>2000-01-15 19:44:27 +0000
commit71ddc094786915d61c422e38dab1eb7a81e25daf (patch)
treed2c3c57d694153784a717bf58e4affc29c2fd4dc /lib/libc/posix1e/acl_valid.c
parent14487c9009d22779861e0407d8c028024af00311 (diff)
downloadFreeBSD-src-71ddc094786915d61c422e38dab1eb7a81e25daf.zip
FreeBSD-src-71ddc094786915d61c422e38dab1eb7a81e25daf.tar.gz
libposix1e provides userland library calls for the POSIX.1e security
interface. This commit introduces the library, as well as a modest subset of the ACL calls, with some modifications to support multiple ACL semantics. Reviewed by: eivind
Diffstat (limited to 'lib/libc/posix1e/acl_valid.c')
-rw-r--r--lib/libc/posix1e/acl_valid.c98
1 files changed, 98 insertions, 0 deletions
diff --git a/lib/libc/posix1e/acl_valid.c b/lib/libc/posix1e/acl_valid.c
new file mode 100644
index 0000000..683525e
--- /dev/null
+++ b/lib/libc/posix1e/acl_valid.c
@@ -0,0 +1,98 @@
+/*-
+ * Copyright (c) 1999 Robert N. M. Watson
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ *
+ * $FreeBSD$
+ */
+/*
+ * acl_valid -- POSIX.1e ACL check routine
+ */
+
+#include <sys/types.h>
+#include <sys/acl.h>
+#include <sys/errno.h>
+
+#include "acl_support.h"
+
+/*
+ * acl_valid: accepts an ACL, returns 0 on valid ACL, -1 for invalid,
+ * and errno set to EINVAL.
+ *
+ * Implemented by calling the acl_check routine in acl_support, which
+ * requires ordering. We call acl_support's acl_sort to make this
+ * true.
+ *
+ * POSIX.1e allows acl_valid() to reorder the ACL as it sees fit.
+ *
+ * This call is deprecated, as it doesn't ask whether the ACL is valid
+ * for a particular target.
+ */
+int
+acl_valid(acl_t acl)
+{
+ int error;
+
+ acl_sort(acl);
+ error = acl_check(acl);
+ if (error) {
+ errno = error;
+ return (-1);
+ } else {
+ return (0);
+ }
+}
+
+
+int
+acl_valid_file(const char *pathp, acl_type_t type, acl_t acl)
+{
+ int error;
+
+ if (acl_posix1e(acl)) {
+ error = acl_sort(acl);
+ if (error) {
+ errno = error;
+ return (-1);
+ }
+ }
+
+ return (acl_syscall_aclcheck_file(pathp, type, acl));
+}
+
+
+int
+acl_valid_fd(int fd, acl_type_t type, acl_t acl)
+{
+ int error;
+
+ if (acl_posix1e(acl)) {
+ error = acl_sort(acl);
+ if (error) {
+ errno = error;
+ return (-1);
+ }
+ }
+
+ return (acl_syscall_aclcheck_fd(fd, type, acl));
+}
OpenPOWER on IntegriCloud