2002-12-30 04:19:57 +00:00
/*
* Fake Perms VFS module . Implements passthrough operation of all VFS
* calls to disk functions , except for file permissions , which are now
* mode 0700 for the current uid / gid .
*
* Copyright ( C ) Tim Potter , 1999 - 2000
* Copyright ( C ) Alexander Bokovoy , 2002
* Copyright ( C ) Andrew Bartlett , 2002
*
* 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
2002-12-30 04:19:57 +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 05:23:25 +00:00
* along with this program ; if not , see < http : //www.gnu.org/licenses/>.
2002-12-30 04:19:57 +00:00
*/
2003-05-11 23:34:18 +00:00
# include "includes.h"
2011-03-22 22:34:22 +01:00
# include "smbd/smbd.h"
2011-02-25 23:20:06 +01:00
# include "system/filesys.h"
2011-03-24 14:15:54 +01:00
# include "auth.h"
2002-12-30 04:19:57 +00:00
2003-05-11 23:34:18 +00:00
# undef DBGC_CLASS
# define DBGC_CLASS DBGC_VFS
2002-12-30 04:19:57 +00:00
2009-06-22 15:26:56 -07:00
static int fake_perms_stat ( vfs_handle_struct * handle ,
struct smb_filename * smb_fname )
2002-12-30 04:19:57 +00:00
{
2013-04-09 21:07:23 +02:00
int ret ;
2003-05-11 23:34:18 +00:00
2009-06-22 15:26:56 -07:00
ret = SMB_VFS_NEXT_STAT ( handle , smb_fname ) ;
2013-04-09 21:07:23 +02:00
if ( ret ! = 0 ) {
return ret ;
2002-12-30 04:19:57 +00:00
}
2003-05-11 23:34:18 +00:00
2013-04-09 21:07:23 +02:00
if ( S_ISDIR ( smb_fname - > st . st_ex_mode ) ) {
smb_fname - > st . st_ex_mode = S_IFDIR | S_IRWXU ;
} else {
smb_fname - > st . st_ex_mode = S_IRWXU ;
}
2013-04-09 21:18:34 +02:00
if ( handle - > conn - > session_info ! = NULL ) {
struct security_unix_token * utok ;
utok = handle - > conn - > session_info - > unix_token ;
smb_fname - > st . st_ex_uid = utok - > uid ;
smb_fname - > st . st_ex_gid = utok - > gid ;
} else {
/*
* We have an artificial connection for dfs for example . It
* sucks , but the current uid / gid is the best we have .
*/
smb_fname - > st . st_ex_uid = geteuid ( ) ;
smb_fname - > st . st_ex_gid = getegid ( ) ;
}
2013-04-09 21:07:23 +02:00
2002-12-30 04:19:57 +00:00
return ret ;
}
2008-01-07 13:21:26 +01:00
static int fake_perms_fstat ( vfs_handle_struct * handle , files_struct * fsp , SMB_STRUCT_STAT * sbuf )
2002-12-30 04:19:57 +00:00
{
2013-04-09 21:07:23 +02:00
int ret ;
2003-05-11 23:34:18 +00:00
2008-01-07 13:21:26 +01:00
ret = SMB_VFS_NEXT_FSTAT ( handle , fsp , sbuf ) ;
2013-04-09 21:07:23 +02:00
if ( ret ! = 0 ) {
return ret ;
2003-03-03 09:12:40 +00:00
}
2013-04-09 21:07:23 +02:00
if ( S_ISDIR ( sbuf - > st_ex_mode ) ) {
sbuf - > st_ex_mode = S_IFDIR | S_IRWXU ;
} else {
sbuf - > st_ex_mode = S_IRWXU ;
}
2013-04-09 21:18:34 +02:00
if ( handle - > conn - > session_info ! = NULL ) {
struct security_unix_token * utok ;
utok = handle - > conn - > session_info - > unix_token ;
sbuf - > st_ex_uid = utok - > uid ;
sbuf - > st_ex_gid = utok - > gid ;
} else {
/*
* We have an artificial connection for dfs for example . It
* sucks , but the current uid / gid is the best we have .
*/
sbuf - > st_ex_uid = geteuid ( ) ;
sbuf - > st_ex_gid = getegid ( ) ;
}
2013-04-09 21:07:23 +02:00
2003-03-03 09:12:40 +00:00
return ret ;
2002-12-30 04:19:57 +00:00
}
2009-07-23 20:28:58 -04:00
static struct vfs_fn_pointers vfs_fake_perms_fns = {
2011-12-03 20:45:04 -08:00
. stat_fn = fake_perms_stat ,
. fstat_fn = fake_perms_fstat
2002-12-30 04:19:57 +00:00
} ;
2006-12-19 20:16:52 +00:00
NTSTATUS vfs_fake_perms_init ( void ) ;
2003-04-28 17:48:48 +00:00
NTSTATUS vfs_fake_perms_init ( void )
2002-12-30 04:19:57 +00:00
{
2009-07-23 20:28:58 -04:00
return smb_register_vfs ( SMB_VFS_INTERFACE_VERSION , " fake_perms " ,
& vfs_fake_perms_fns ) ;
2002-12-30 04:19:57 +00:00
}