diff options
author | Jeremy Allison <jra@samba.org> | 2001-08-10 20:49:46 +0000 |
---|---|---|
committer | Jeremy Allison <jra@samba.org> | 2001-08-10 20:49:46 +0000 |
commit | 41837701e4f67d2f8e5436714a7083cb2688abbb (patch) | |
tree | 1b5eb99bb68bae9b9cb2f700bfba780ddd69f19c /source/lib/sysacls.c | |
parent | 9675de08c4a38f0be670918b8222b73ca2ca4ab1 (diff) | |
download | samba-41837701e4f67d2f8e5436714a7083cb2688abbb.tar.gz samba-41837701e4f67d2f8e5436714a7083cb2688abbb.tar.xz samba-41837701e4f67d2f8e5436714a7083cb2688abbb.zip |
Added Mike Davidsons Tru64 ACL patch.
Jeremy.
Diffstat (limited to 'source/lib/sysacls.c')
-rw-r--r-- | source/lib/sysacls.c | 36 |
1 files changed, 23 insertions, 13 deletions
diff --git a/source/lib/sysacls.c b/source/lib/sysacls.c index f151a772e07..0f488888a8f 100644 --- a/source/lib/sysacls.c +++ b/source/lib/sysacls.c @@ -191,8 +191,17 @@ int sys_acl_free_qualifier(void *qual, SMB_ACL_TAG_T tagtype) return acl_free(qual); } -#elif defined(HAVE_DRAFT13_POSIX_ACLS) - +#elif defined(HAVE_TRU64_ACLS) +/* + * The interface to DEC/Compaq Tru64 UNIX ACLs + * is based on Draft 13 of the POSIX spec which is + * slightly different from the Draft 16 interface. + * + * Also, some of the permset manipulation functions + * such as acl_clear_perm() and acl_add_perm() appear + * to be broken on Tru64 so we have to manipulate + * the permission bits in the permset directly. + */ int sys_acl_get_entry( SMB_ACL_T the_acl, int entry_id, SMB_ACL_ENTRY_T *entry_p) { SMB_ACL_ENTRY_T entry; @@ -237,25 +246,26 @@ SMB_ACL_T sys_acl_get_fd(int fd) int sys_acl_clear_perms(SMB_ACL_PERMSET_T permset) { - return acl_clear_perm(permset); + *permset = 0; /* acl_clear_perm() is broken on Tru64 */ + + return 0; } int sys_acl_add_perm( SMB_ACL_PERMSET_T permset, SMB_ACL_PERM_T perm) { - return acl_add_perm(permset, perm); + if (perm & ~(SMB_ACL_READ | SMB_ACL_WRITE | SMB_ACL_EXECUTE)) { + errno = EINVAL; + return -1; + } + + *permset |= perm; /* acl_add_perm() is broken on Tru64 */ + + return 0; } int sys_acl_get_perm( SMB_ACL_PERMSET_T permset, SMB_ACL_PERM_T perm) { -#if defined(HAVE_ACL_GET_PERM_NP) - return acl_get_perm_np(permset, perm); -#else - /* - * if we don't have an acl_get_perm() interface - * this will probably work for most implementations - */ - return *permset & perm; -#endif + return *permset & perm; /* Tru64 doesn't have acl_get_perm() */ } char *sys_acl_to_text( SMB_ACL_T the_acl, ssize_t *plen) |