]> arthur.barton.de Git - netatalk.git/blobdiff - include/atalk/acl.h
Configurable symlink behaviour
[netatalk.git] / include / atalk / acl.h
index 6b48e5522c1e365a187fb081f2275a81c2704c3d..810be707bfec96b9ee2a8366cd1e25b8a83ad28e 100644 (file)
 #include "config.h"
 #endif /* HAVE_CONFIG_H */
 
+#ifdef HAVE_ACLS
+
+#define O_NETATALK_ACL (O_NOFOLLOW << 1)
+
 #ifdef HAVE_SOLARIS_ACLS
 #include <sys/acl.h>
-#endif  /* HAVE_SOLARIS_ACLS */
 
-#ifdef HAVE_SOLARIS_ACLS
+#define chmod_acl nfsv4_chmod
+
 extern int get_nfsv4_acl(const char *name, ace_t **retAces);
-#endif /* HAVE_SOLARIS_ACLS */
+extern int strip_trivial_aces(ace_t **saces, int sacecount);
+extern int strip_nontrivial_aces(ace_t **saces, int sacecount);
+extern ace_t *concat_aces(ace_t *aces1, int ace1count, ace_t *aces2, int ace2count);
+extern int nfsv4_chmod(char *name, mode_t mode);
+
+#endif  /* HAVE_SOLARIS_ACLS */
+
+#ifdef HAVE_POSIX_ACLS
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <sys/acl.h>
+
+#define chmod_acl posix_chmod
+#define fchmod_acl posix_fchmod
+
+extern int posix_chmod(const char *name, mode_t mode);
+extern int posix_fchmod(int fd, mode_t mode);
+
+#endif /* HAVE_POSIX_ACLS */
 
 extern int remove_acl_vfs(const char *name);
 
-#endif  /* ATALK_ACL_H */
+#else /* HAVE_ACLS=no */
+
+#define O_NETATALK_ACL
+#define chmod_acl chmod
+
+#endif /* HAVE_ACLS */
+
+#endif /* ATALK_ACL_H */