2006-07-21 15:51:34 +00:00
/*
Unix SMB / Netbios implementation .
VFS module to get and set posix acls
Copyright ( C ) Jim McDonough < jmcd @ us . ibm . com > 2006
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
2007-07-09 19:25:36 +00:00
the Free Software Foundation ; either version 3 of the License , or
2006-07-21 15:51:34 +00:00
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
2007-07-10 00:52:41 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2006-07-21 15:51:34 +00:00
*/
# include "includes.h"
2011-03-30 15:14:05 +02:00
# include "system/filesys.h"
2011-03-22 22:34:22 +01:00
# include "smbd/smbd.h"
2012-08-13 20:14:43 +10:00
# include "vfs_aixacl_util.h"
2006-07-21 15:51:34 +00:00
SMB_ACL_T aixacl_sys_acl_get_file ( vfs_handle_struct * handle ,
2017-05-23 17:11:18 -07:00
const struct smb_filename * smb_fname ,
2012-10-11 14:42:39 +11:00
SMB_ACL_TYPE_T type ,
TALLOC_CTX * mem_ctx )
2006-07-21 15:51:34 +00:00
{
2017-05-23 17:11:18 -07:00
const char * path_p = smb_fname - > base_name ;
2006-07-21 15:51:34 +00:00
struct acl * file_acl = ( struct acl * ) NULL ;
struct smb_acl_t * result = ( struct smb_acl_t * ) NULL ;
int rc = 0 ;
uid_t user_id ;
/* AIX has no DEFAULT */
if ( type = = SMB_ACL_TYPE_DEFAULT )
return NULL ;
/* Get the acl using statacl */
DEBUG ( 10 , ( " Entering AIX sys_acl_get_file \n " ) ) ;
DEBUG ( 10 , ( " path_p is %s \n " , path_p ) ) ;
file_acl = ( struct acl * ) SMB_MALLOC ( BUFSIZ ) ;
if ( file_acl = = NULL ) {
errno = ENOMEM ;
DEBUG ( 0 , ( " Error in AIX sys_acl_get_file: %d \n " , errno ) ) ;
return ( NULL ) ;
}
memset ( file_acl , 0 , BUFSIZ ) ;
rc = statacl ( ( char * ) path_p , 0 , file_acl , BUFSIZ ) ;
if ( ( rc = = - 1 ) & & ( errno = = ENOSPC ) ) {
struct acl * new_acl = SMB_MALLOC ( file_acl - > acl_len + sizeof ( struct acl ) ) ;
if ( new_acl = = NULL ) {
SAFE_FREE ( file_acl ) ;
errno = ENOMEM ;
return NULL ;
}
file_acl = new_acl ;
rc = statacl ( ( char * ) path_p , 0 , file_acl , file_acl - > acl_len + sizeof ( struct acl ) ) ;
if ( rc = = - 1 ) {
DEBUG ( 0 , ( " statacl returned %d with errno %d \n " , rc , errno ) ) ;
SAFE_FREE ( file_acl ) ;
return ( NULL ) ;
}
}
DEBUG ( 10 , ( " Got facl and returned it \n " ) ) ;
2012-10-11 14:42:39 +11:00
result = aixacl_to_smbacl ( file_acl , mem_ctx ) ;
2006-07-21 15:51:34 +00:00
SAFE_FREE ( file_acl ) ;
return result ;
/*errno = ENOTSUP;
return NULL ; */
}
SMB_ACL_T aixacl_sys_acl_get_fd ( vfs_handle_struct * handle ,
2012-10-11 14:42:39 +11:00
files_struct * fsp ,
TALLOC_CTX * mem_ctx )
2006-07-21 15:51:34 +00:00
{
struct acl * file_acl = ( struct acl * ) NULL ;
struct smb_acl_t * result = ( struct smb_acl_t * ) NULL ;
int rc = 0 ;
uid_t user_id ;
/* Get the acl using fstatacl */
DEBUG ( 10 , ( " Entering AIX sys_acl_get_fd \n " ) ) ;
2020-09-26 21:52:52 +02:00
DEBUG ( 10 , ( " fd is %d \n " , fsp_get_io_fd ( fsp ) ) ) ;
2006-07-21 15:51:34 +00:00
file_acl = ( struct acl * ) SMB_MALLOC ( BUFSIZ ) ;
if ( file_acl = = NULL ) {
errno = ENOMEM ;
DEBUG ( 0 , ( " Error in AIX sys_acl_get_fd is %d \n " , errno ) ) ;
return ( NULL ) ;
}
memset ( file_acl , 0 , BUFSIZ ) ;
2020-09-26 21:52:52 +02:00
rc = fstatacl ( fsp_get_io_fd ( fsp ) , 0 , file_acl , BUFSIZ ) ;
2006-07-21 15:51:34 +00:00
if ( ( rc = = - 1 ) & & ( errno = = ENOSPC ) ) {
struct acl * new_acl = SMB_MALLOC ( file_acl - > acl_len + sizeof ( struct acl ) ) ;
if ( new_acl = = NULL ) {
SAFE_FREE ( file_acl ) ;
errno = ENOMEM ;
return NULL ;
}
file_acl = new_acl ;
2020-09-26 21:52:52 +02:00
rc = fstatacl ( fsp_get_io_fd ( fsp ) , 0 , file_acl , file_acl - > acl_len + sizeof ( struct acl ) ) ;
2006-07-21 15:51:34 +00:00
if ( rc = = - 1 ) {
DEBUG ( 0 , ( " fstatacl returned %d with errno %d \n " , rc , errno ) ) ;
SAFE_FREE ( file_acl ) ;
return ( NULL ) ;
}
}
DEBUG ( 10 , ( " Got facl and returned it \n " ) ) ;
2012-10-11 14:42:39 +11:00
result = aixacl_to_smbacl ( file_acl , mem_ctx ) ;
2006-07-21 15:51:34 +00:00
SAFE_FREE ( file_acl ) ;
return result ;
/*errno = ENOTSUP;
return NULL ; */
}
2021-01-26 15:50:00 +01:00
int aixacl_sys_acl_set_file ( vfs_handle_struct * handle ,
const struct smb_filename * smb_fname ,
SMB_ACL_TYPE_T type ,
SMB_ACL_T theacl )
{
struct acl * file_acl = NULL ;
unsigned int rc ;
file_acl = aixacl_smb_to_aixacl ( type , theacl ) ;
if ( ! file_acl )
return - 1 ;
rc = chacl ( ( char * ) smb_fname - > base_name , file_acl , file_acl - > acl_len ) ;
DEBUG ( 10 , ( " errno is %d \n " , errno ) ) ;
DEBUG ( 10 , ( " return code is %d \n " , rc ) ) ;
SAFE_FREE ( file_acl ) ;
DEBUG ( 10 , ( " Exiting the aixacl_sys_acl_set_file \n " ) ) ;
return rc ;
}
2006-07-21 15:51:34 +00:00
int aixacl_sys_acl_set_fd ( vfs_handle_struct * handle ,
files_struct * fsp ,
2020-12-14 16:28:26 +01:00
SMB_ACL_TYPE_T type ,
2008-01-08 01:54:19 +01:00
SMB_ACL_T theacl )
2006-07-21 15:51:34 +00:00
{
struct acl * file_acl = NULL ;
2007-09-28 01:32:08 +00:00
unsigned int rc ;
2006-07-21 15:51:34 +00:00
2020-12-13 09:06:24 +01:00
file_acl = aixacl_smb_to_aixacl ( type , theacl ) ;
2006-07-21 15:51:34 +00:00
if ( ! file_acl )
return - 1 ;
2020-12-14 10:04:15 +01:00
if ( fsp - > fsp_flags . is_pathref ) {
/*
* This is no longer a handle based call .
*/
2021-01-26 10:55:42 +01:00
return chacl ( fsp - > fsp_name - > base_name ,
file_acl ,
file_acl - > acl_len ) ;
2020-12-14 10:04:15 +01:00
}
2020-09-26 21:52:52 +02:00
rc = fchacl ( fsp_get_io_fd ( fsp ) , file_acl , file_acl - > acl_len ) ;
2006-07-21 15:51:34 +00:00
DEBUG ( 10 , ( " errno is %d \n " , errno ) ) ;
DEBUG ( 10 , ( " return code is %d \n " , rc ) ) ;
SAFE_FREE ( file_acl ) ;
DEBUG ( 10 , ( " Exiting aixacl_sys_acl_set_fd \n " ) ) ;
return rc ;
}
2021-05-14 14:29:17 -07:00
int aixacl_sys_acl_delete_def_fd ( vfs_handle_struct * handle ,
files_struct * fsp )
{
return 0 ; /* otherwise you can't set acl at upper level */
}
2009-07-23 20:28:58 -04:00
static struct vfs_fn_pointers vfs_aixacl_fns = {
2011-12-03 20:45:04 -08:00
. sys_acl_get_file_fn = aixacl_sys_acl_get_file ,
. sys_acl_get_fd_fn = aixacl_sys_acl_get_fd ,
2012-10-10 16:52:02 +11:00
. sys_acl_blob_get_file_fn = posix_sys_acl_blob_get_file ,
. sys_acl_blob_get_fd_fn = posix_sys_acl_blob_get_fd ,
2011-12-03 20:45:04 -08:00
. sys_acl_set_fd_fn = aixacl_sys_acl_set_fd ,
2021-05-14 14:29:17 -07:00
. sys_acl_delete_def_fd_fn = aixacl_sys_acl_delete_def_fd ,
2006-07-21 15:51:34 +00:00
} ;
2017-12-15 15:32:12 -07:00
static_decl_vfs ;
2017-04-20 12:24:43 -07:00
NTSTATUS vfs_aixacl_init ( TALLOC_CTX * ctx )
2006-07-21 15:51:34 +00:00
{
return smb_register_vfs ( SMB_VFS_INTERFACE_VERSION , " aixacl " ,
2009-07-23 20:28:58 -04:00
& vfs_aixacl_fns ) ;
2006-07-21 15:51:34 +00:00
}