2003-06-04 13:13:41 +00:00
/*
2009-09-25 22:19:27 -07:00
* Skeleton VFS module . Implements dummy versions of all VFS
* functions .
2003-06-04 13:13:41 +00:00
*
* Copyright ( C ) Tim Potter , 1999 - 2000
* Copyright ( C ) Alexander Bokovoy , 2002
* Copyright ( C ) Stefan ( metze ) Metzmacher , 2003
2009-09-25 22:19:27 -07:00
* Copyright ( C ) Jeremy Allison 2009
2003-06-04 13:13:41 +00:00
*
* 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
2003-06-04 13:13:41 +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/>.
2003-06-04 13:13:41 +00:00
*/
2011-12-13 21:26:21 +01:00
# include "../source3/include/includes.h"
2003-06-04 13:13:41 +00:00
/* PLEASE,PLEASE READ THE VFS MODULES CHAPTER OF THE
SAMBA DEVELOPERS GUIDE ! ! ! ! ! !
*/
/* If you take this file as template for your module
2009-09-25 22:19:27 -07:00
* you must re - implement every function .
2007-03-08 17:06:16 +00:00
*/
2006-07-11 18:06:52 +00:00
static int skel_connect ( vfs_handle_struct * handle , const char * service , const char * user )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2009-09-25 22:19:27 -07:00
static void skel_disconnect ( vfs_handle_struct * handle )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
;
2003-06-04 13:13:41 +00:00
}
2009-02-05 17:27:53 +01:00
static uint64_t skel_disk_free ( vfs_handle_struct * handle , const char * path ,
bool small_query , uint64_t * bsize ,
uint64_t * dfree , uint64_t * dsize )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
* bsize = 0 ;
* dfree = 0 ;
* dsize = 0 ;
return 0 ;
2003-06-04 13:13:41 +00:00
}
2006-07-11 18:06:52 +00:00
static int skel_get_quota ( vfs_handle_struct * handle , enum SMB_QUOTA_TYPE qtype , unid_t id , SMB_DISK_QUOTA * dq )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2006-07-11 18:06:52 +00:00
static int skel_set_quota ( vfs_handle_struct * handle , enum SMB_QUOTA_TYPE qtype , unid_t id , SMB_DISK_QUOTA * dq )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2011-06-29 16:56:45 +02:00
static int skel_get_shadow_copy_data ( vfs_handle_struct * handle , files_struct * fsp , struct shadow_copy_data * shadow_copy_data , bool labels )
2003-08-07 21:49:01 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-08-07 21:49:01 +00:00
}
2009-09-25 22:19:27 -07:00
static int skel_statvfs ( struct vfs_handle_struct * handle , const char * path , struct vfs_statvfs_struct * statbuf )
2005-10-20 17:33:17 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
}
static uint32_t skel_fs_capabilities ( struct vfs_handle_struct * handle , enum timestamp_set_resolution * p_ts_res )
{
return 0 ;
2005-10-20 17:33:17 +00:00
}
2011-10-08 09:18:02 +02:00
static NTSTATUS skel_get_dfs_referrals ( struct vfs_handle_struct * handle ,
struct dfs_GetDFSReferral * r )
{
return NT_STATUS_NOT_IMPLEMENTED ;
}
2012-03-28 13:22:03 +11:00
static DIR * skel_opendir ( vfs_handle_struct * handle , const char * fname , const char * mask , uint32 attr )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
return NULL ;
2003-06-04 13:13:41 +00:00
}
2012-03-28 13:22:03 +11:00
static DIR * skel_fdopendir ( vfs_handle_struct * handle , files_struct * fsp , const char * mask , uint32 attr )
2011-02-08 15:07:48 -08:00
{
return NULL ;
}
2012-03-28 13:18:14 +11:00
static struct dirent * skel_readdir ( vfs_handle_struct * handle ,
2012-03-28 13:22:03 +11:00
DIR * dirp ,
2009-02-24 15:28:54 +01:00
SMB_STRUCT_STAT * sbuf )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
return NULL ;
2003-06-04 13:13:41 +00:00
}
2012-03-28 13:22:03 +11:00
static void skel_seekdir ( vfs_handle_struct * handle , DIR * dirp , long offset )
2004-11-09 23:55:04 +00:00
{
2009-09-25 22:19:27 -07:00
;
2004-11-09 23:55:04 +00:00
}
2012-03-28 13:22:03 +11:00
static long skel_telldir ( vfs_handle_struct * handle , DIR * dirp )
2004-11-09 23:55:04 +00:00
{
2009-09-25 22:19:27 -07:00
return ( long ) - 1 ;
2004-11-09 23:55:04 +00:00
}
2012-03-28 13:22:03 +11:00
static void skel_rewind_dir ( vfs_handle_struct * handle , DIR * dirp )
2004-11-09 23:55:04 +00:00
{
2009-09-25 22:19:27 -07:00
;
2004-11-09 23:55:04 +00:00
}
2006-07-11 18:06:52 +00:00
static int skel_mkdir ( vfs_handle_struct * handle , const char * path , mode_t mode )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2006-07-11 18:06:52 +00:00
static int skel_rmdir ( vfs_handle_struct * handle , const char * path )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2012-03-28 13:22:03 +11:00
static int skel_closedir ( vfs_handle_struct * handle , DIR * dir )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2012-03-28 13:22:03 +11:00
static void skel_init_search_op ( struct vfs_handle_struct * handle , DIR * dirp )
2009-09-25 22:19:27 -07:00
{
;
}
static int skel_open ( vfs_handle_struct * handle , struct smb_filename * smb_fname ,
2009-06-16 12:01:13 -07:00
files_struct * fsp , int flags , mode_t mode )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
}
static NTSTATUS skel_create_file ( struct vfs_handle_struct * handle ,
struct smb_request * req ,
uint16_t root_dir_fid ,
struct smb_filename * smb_fname ,
uint32_t access_mask ,
uint32_t share_access ,
uint32_t create_disposition ,
uint32_t create_options ,
uint32_t file_attributes ,
uint32_t oplock_request ,
uint64_t allocation_size ,
2010-03-05 15:10:30 -08:00
uint32_t private_flags ,
2009-09-25 22:19:27 -07:00
struct security_descriptor * sd ,
struct ea_list * ea_list ,
files_struct * * result ,
int * pinfo )
{
return NT_STATUS_NOT_IMPLEMENTED ;
2003-06-04 13:13:41 +00:00
}
2009-09-25 22:19:27 -07:00
static int skel_close_fn ( vfs_handle_struct * handle , files_struct * fsp )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2009-09-25 22:19:27 -07:00
static ssize_t skel_vfs_read ( vfs_handle_struct * handle , files_struct * fsp , void * data , size_t n )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2012-04-05 14:53:08 +10:00
static ssize_t skel_pread ( vfs_handle_struct * handle , files_struct * fsp , void * data , size_t n , off_t offset )
2004-01-06 01:22:14 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2004-01-06 01:22:14 +00:00
}
2012-07-09 17:17:25 +02:00
static struct tevent_req * skel_pread_send ( struct vfs_handle_struct * handle ,
TALLOC_CTX * mem_ctx ,
struct tevent_context * ev ,
struct files_struct * fsp ,
void * data , size_t n , off_t offset )
{
return NULL ;
}
static ssize_t skel_pread_recv ( struct tevent_req * req , int * err )
{
* err = ENOSYS ;
return - 1 ;
}
2008-01-10 15:49:35 +01:00
static ssize_t skel_write ( vfs_handle_struct * handle , files_struct * fsp , const void * data , size_t n )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2012-04-05 14:53:08 +10:00
static ssize_t skel_pwrite ( vfs_handle_struct * handle , files_struct * fsp , const void * data , size_t n , off_t offset )
2004-01-06 01:22:14 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2004-01-06 01:22:14 +00:00
}
2012-07-09 17:17:25 +02:00
static struct tevent_req * skel_pwrite_send ( struct vfs_handle_struct * handle ,
TALLOC_CTX * mem_ctx ,
struct tevent_context * ev ,
struct files_struct * fsp ,
const void * data ,
size_t n , off_t offset )
{
return NULL ;
}
static ssize_t skel_pwrite_recv ( struct tevent_req * req , int * err )
{
* err = ENOSYS ;
return - 1 ;
}
2012-04-05 14:53:08 +10:00
static off_t skel_lseek ( vfs_handle_struct * handle , files_struct * fsp , off_t offset , int whence )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
2012-04-05 14:53:08 +10:00
return ( off_t ) - 1 ;
2003-06-04 13:13:41 +00:00
}
2012-04-05 14:53:08 +10:00
static ssize_t skel_sendfile ( vfs_handle_struct * handle , int tofd , files_struct * fromfsp , const DATA_BLOB * hdr , off_t offset , size_t n )
2007-10-29 17:16:13 -07:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2007-10-29 17:16:13 -07:00
}
2012-04-05 14:53:08 +10:00
static ssize_t skel_recvfile ( vfs_handle_struct * handle , int fromfd , files_struct * tofsp , off_t offset , size_t n )
2007-10-29 17:16:13 -07:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2007-10-29 17:16:13 -07:00
}
2009-06-30 17:04:38 -07:00
static int skel_rename ( vfs_handle_struct * handle ,
2009-09-25 22:19:27 -07:00
const struct smb_filename * smb_fname_src ,
const struct smb_filename * smb_fname_dst )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2008-01-07 12:49:02 +01:00
static int skel_fsync ( vfs_handle_struct * handle , files_struct * fsp )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2012-07-13 10:22:25 +02:00
static struct tevent_req * skel_fsync_send ( struct vfs_handle_struct * handle ,
TALLOC_CTX * mem_ctx ,
struct tevent_context * ev ,
struct files_struct * fsp )
{
return NULL ;
}
static int skel_fsync_recv ( struct tevent_req * req , int * err )
{
* err = ENOSYS ;
return - 1 ;
}
2009-06-22 15:26:56 -07:00
static int skel_stat ( vfs_handle_struct * handle , struct smb_filename * smb_fname )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2008-01-07 13:21:26 +01:00
static int skel_fstat ( vfs_handle_struct * handle , files_struct * fsp , SMB_STRUCT_STAT * sbuf )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2009-06-22 15:26:56 -07:00
static int skel_lstat ( vfs_handle_struct * handle , struct smb_filename * smb_fname )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
}
static uint64_t skel_get_alloc_size ( struct vfs_handle_struct * handle , struct files_struct * fsp , const SMB_STRUCT_STAT * sbuf )
{
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2009-07-02 09:27:44 -07:00
static int skel_unlink ( vfs_handle_struct * handle ,
const struct smb_filename * smb_fname )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2006-07-11 18:06:52 +00:00
static int skel_chmod ( vfs_handle_struct * handle , const char * path , mode_t mode )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2008-01-07 13:44:37 +01:00
static int skel_fchmod ( vfs_handle_struct * handle , files_struct * fsp , mode_t mode )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2006-07-11 18:06:52 +00:00
static int skel_chown ( vfs_handle_struct * handle , const char * path , uid_t uid , gid_t gid )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2008-01-07 14:26:00 +01:00
static int skel_fchown ( vfs_handle_struct * handle , files_struct * fsp , uid_t uid , gid_t gid )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2007-05-23 23:55:12 +00:00
static int skel_lchown ( vfs_handle_struct * handle , const char * path , uid_t uid , gid_t gid )
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2007-05-23 23:55:12 +00:00
}
2006-07-11 18:06:52 +00:00
static int skel_chdir ( vfs_handle_struct * handle , const char * path )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2011-05-31 16:36:06 -07:00
static char * skel_getwd ( vfs_handle_struct * handle )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return NULL ;
2003-06-04 13:13:41 +00:00
}
2009-07-02 13:39:20 -07:00
static int skel_ntimes ( vfs_handle_struct * handle ,
const struct smb_filename * smb_fname ,
struct smb_file_time * ft )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2012-04-05 14:53:08 +10:00
static int skel_ftruncate ( vfs_handle_struct * handle , files_struct * fsp , off_t offset )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2010-12-17 23:08:01 -08:00
static int skel_fallocate ( vfs_handle_struct * handle , files_struct * fsp ,
enum vfs_fallocate_mode mode ,
2012-04-05 14:53:08 +10:00
off_t offset , off_t len )
2010-12-02 16:25:59 -08:00
{
errno = ENOSYS ;
return - 1 ;
}
2012-04-05 14:53:08 +10:00
static bool skel_lock ( vfs_handle_struct * handle , files_struct * fsp , int op , off_t offset , off_t count , int type )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return false ;
}
2009-12-07 10:15:49 +01:00
static int skel_kernel_flock ( struct vfs_handle_struct * handle , struct files_struct * fsp , uint32 share_mode , uint32 access_mask )
2009-09-25 22:19:27 -07:00
{
errno = ENOSYS ;
return - 1 ;
}
static int skel_linux_setlease ( struct vfs_handle_struct * handle , struct files_struct * fsp , int leasetype )
{
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2012-04-05 14:53:08 +10:00
static bool skel_getlock ( vfs_handle_struct * handle , files_struct * fsp , off_t * poffset , off_t * pcount , int * ptype , pid_t * ppid )
2006-04-10 15:33:04 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return false ;
2006-04-10 15:33:04 +00:00
}
2006-07-11 18:06:52 +00:00
static int skel_symlink ( vfs_handle_struct * handle , const char * oldpath , const char * newpath )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2009-09-25 22:19:27 -07:00
static int skel_vfs_readlink ( vfs_handle_struct * handle , const char * path , char * buf , size_t bufsiz )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2006-07-11 18:06:52 +00:00
static int skel_link ( vfs_handle_struct * handle , const char * oldpath , const char * newpath )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2006-07-11 18:06:52 +00:00
static int skel_mknod ( vfs_handle_struct * handle , const char * path , mode_t mode , SMB_DEV_T dev )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2010-11-19 16:29:26 -08:00
static char * skel_realpath ( vfs_handle_struct * handle , const char * path )
2003-06-04 13:13:41 +00:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return NULL ;
2003-06-04 13:13:41 +00:00
}
2007-03-08 17:06:16 +00:00
static NTSTATUS skel_notify_watch ( struct vfs_handle_struct * handle ,
2012-03-26 12:46:11 +02:00
struct sys_notify_context * ctx ,
const char * path ,
uint32_t * filter ,
uint32_t * subdir_filter ,
2007-03-08 17:06:16 +00:00
void ( * callback ) ( struct sys_notify_context * ctx , void * private_data , struct notify_event * ev ) ,
void * private_data , void * handle_p )
{
2009-09-25 22:19:27 -07:00
return NT_STATUS_NOT_IMPLEMENTED ;
2007-03-08 17:06:16 +00:00
}
static int skel_chflags ( vfs_handle_struct * handle , const char * path , uint flags )
{
errno = ENOSYS ;
return - 1 ;
}
2007-08-02 09:19:04 +00:00
static struct file_id skel_file_id_create ( vfs_handle_struct * handle ,
2009-02-15 23:38:53 -08:00
const SMB_STRUCT_STAT * sbuf )
2007-08-02 09:19:04 +00:00
{
2009-09-25 22:19:27 -07:00
struct file_id id ;
ZERO_STRUCT ( id ) ;
2007-08-02 09:19:04 +00:00
errno = ENOSYS ;
2009-09-25 22:19:27 -07:00
return id ;
2007-08-02 09:19:04 +00:00
}
2009-09-25 22:19:27 -07:00
static NTSTATUS skel_streaminfo ( struct vfs_handle_struct * handle ,
struct files_struct * fsp ,
const char * fname ,
TALLOC_CTX * mem_ctx ,
unsigned int * num_streams ,
struct stream_struct * * streams )
{
return NT_STATUS_NOT_IMPLEMENTED ;
}
static int skel_get_real_filename ( struct vfs_handle_struct * handle ,
const char * path ,
const char * name ,
TALLOC_CTX * mem_ctx ,
char * * found_name )
2003-06-04 13:13:41 +00:00
{
errno = ENOSYS ;
2009-09-25 22:19:27 -07:00
return - 1 ;
2003-06-04 13:13:41 +00:00
}
2009-09-25 22:19:27 -07:00
static const char * skel_connectpath ( struct vfs_handle_struct * handle ,
const char * filename )
2003-06-04 13:13:41 +00:00
{
errno = ENOSYS ;
2009-09-25 22:19:27 -07:00
return NULL ;
}
static NTSTATUS skel_brl_lock_windows ( struct vfs_handle_struct * handle ,
struct byte_range_lock * br_lck ,
struct lock_struct * plock ,
bool blocking_lock ,
struct blocking_lock_record * blr )
{
return NT_STATUS_NOT_IMPLEMENTED ;
}
static bool skel_brl_unlock_windows ( struct vfs_handle_struct * handle ,
struct messaging_context * msg_ctx ,
struct byte_range_lock * br_lck ,
const struct lock_struct * plock )
{
errno = ENOSYS ;
return false ;
}
static bool skel_brl_cancel_windows ( struct vfs_handle_struct * handle ,
struct byte_range_lock * br_lck ,
struct lock_struct * plock ,
struct blocking_lock_record * blr )
{
errno = ENOSYS ;
return false ;
}
static bool skel_strict_lock ( struct vfs_handle_struct * handle ,
struct files_struct * fsp ,
struct lock_struct * plock )
{
errno = ENOSYS ;
return false ;
}
static void skel_strict_unlock ( struct vfs_handle_struct * handle ,
struct files_struct * fsp ,
struct lock_struct * plock )
{
;
}
static NTSTATUS skel_translate_name ( struct vfs_handle_struct * handle ,
2009-12-07 10:15:49 +01:00
const char * mapped_name ,
enum vfs_translate_direction direction ,
TALLOC_CTX * mem_ctx ,
char * * pmapped_name )
2009-09-25 22:19:27 -07:00
{
return NT_STATUS_NOT_IMPLEMENTED ;
}
2011-10-11 09:18:46 -07:00
static NTSTATUS skel_fsctl ( struct vfs_handle_struct * handle ,
struct files_struct * fsp ,
TALLOC_CTX * ctx ,
uint32_t function ,
uint16_t req_flags , /* Needed for UNICODE ... */
const uint8_t * _in_data ,
uint32_t in_len ,
uint8_t * * _out_data ,
uint32_t max_out_len ,
uint32_t * out_len )
{
return NT_STATUS_NOT_IMPLEMENTED ;
}
2009-09-25 22:19:27 -07:00
static NTSTATUS skel_fget_nt_acl ( vfs_handle_struct * handle , files_struct * fsp ,
2012-10-10 11:50:27 +11:00
uint32 security_info ,
TALLOC_CTX * mem_ctx ,
struct security_descriptor * * ppdesc )
2009-09-25 22:19:27 -07:00
{
return NT_STATUS_NOT_IMPLEMENTED ;
}
static NTSTATUS skel_get_nt_acl ( vfs_handle_struct * handle ,
2012-10-10 11:50:27 +11:00
const char * name , uint32 security_info ,
TALLOC_CTX * mem_ctx ,
struct security_descriptor * * ppdesc )
2009-09-25 22:19:27 -07:00
{
return NT_STATUS_NOT_IMPLEMENTED ;
2003-06-04 13:13:41 +00:00
}
2008-01-07 00:21:12 +01:00
static NTSTATUS skel_fset_nt_acl ( vfs_handle_struct * handle , files_struct * fsp ,
2011-03-07 04:46:20 -08:00
uint32 security_info_sent , const struct security_descriptor * psd )
2003-06-04 13:13:41 +00:00
{
2007-06-26 22:49:10 +00:00
return NT_STATUS_NOT_IMPLEMENTED ;
2003-06-04 13:13:41 +00:00
}
2006-07-11 18:06:52 +00:00
static int skel_chmod_acl ( vfs_handle_struct * handle , const char * name , mode_t mode )
2003-06-04 13:13:41 +00:00
{
errno = ENOSYS ;
return - 1 ;
}
2008-01-08 22:13:25 +01:00
static int skel_fchmod_acl ( vfs_handle_struct * handle , files_struct * fsp , mode_t mode )
2003-06-04 13:13:41 +00:00
{
errno = ENOSYS ;
return - 1 ;
}
2012-10-10 10:18:32 +11:00
static SMB_ACL_T skel_sys_acl_get_file ( vfs_handle_struct * handle ,
const char * path_p ,
SMB_ACL_TYPE_T type ,
TALLOC_CTX * mem_ctx )
2003-06-04 13:13:41 +00:00
{
errno = ENOSYS ;
2009-09-25 22:19:27 -07:00
return ( SMB_ACL_T ) NULL ;
2003-06-04 13:13:41 +00:00
}
2012-10-10 10:18:32 +11:00
static SMB_ACL_T skel_sys_acl_get_fd ( vfs_handle_struct * handle ,
files_struct * fsp ,
TALLOC_CTX * mem_ctx )
2003-06-04 13:13:41 +00:00
{
errno = ENOSYS ;
2009-09-25 22:19:27 -07:00
return ( SMB_ACL_T ) NULL ;
2003-06-04 13:13:41 +00:00
}
2012-09-10 12:44:01 +10:00
static int skel_sys_acl_blob_get_file ( vfs_handle_struct * handle , const char * path_p , SMB_ACL_TYPE_T type , TALLOC_CTX * mem_ctx , char * * blob_description , DATA_BLOB * blob )
{
errno = ENOSYS ;
return - 1 ;
}
static int skel_sys_acl_blob_get_fd ( vfs_handle_struct * handle , files_struct * fsp , TALLOC_CTX * mem_ctx , char * * blob_description , DATA_BLOB * blob )
{
errno = ENOSYS ;
return - 1 ;
}
2006-07-11 18:06:52 +00:00
static int skel_sys_acl_set_file ( vfs_handle_struct * handle , const char * name , SMB_ACL_TYPE_T acltype , SMB_ACL_T theacl )
2003-06-04 13:13:41 +00:00
{
errno = ENOSYS ;
return - 1 ;
}
2008-01-08 22:13:25 +01:00
static int skel_sys_acl_set_fd ( vfs_handle_struct * handle , files_struct * fsp , SMB_ACL_T theacl )
2003-06-04 13:13:41 +00:00
{
errno = ENOSYS ;
return - 1 ;
}
2006-07-11 18:06:52 +00:00
static int skel_sys_acl_delete_def_file ( vfs_handle_struct * handle , const char * path )
2003-06-04 13:13:41 +00:00
{
errno = ENOSYS ;
return - 1 ;
}
2006-07-11 18:06:52 +00:00
static ssize_t skel_getxattr ( vfs_handle_struct * handle , const char * path , const char * name , void * value , size_t size )
2003-06-06 07:09:30 +00:00
{
errno = ENOSYS ;
return - 1 ;
}
2008-01-08 22:13:25 +01:00
static ssize_t skel_fgetxattr ( vfs_handle_struct * handle , struct files_struct * fsp , const char * name , void * value , size_t size )
2003-06-06 07:09:30 +00:00
{
errno = ENOSYS ;
return - 1 ;
}
2006-07-11 18:06:52 +00:00
static ssize_t skel_listxattr ( vfs_handle_struct * handle , const char * path , char * list , size_t size )
2003-06-06 07:09:30 +00:00
{
errno = ENOSYS ;
return - 1 ;
}
2008-01-08 22:13:25 +01:00
static ssize_t skel_flistxattr ( vfs_handle_struct * handle , struct files_struct * fsp , char * list , size_t size )
2003-06-06 07:09:30 +00:00
{
errno = ENOSYS ;
return - 1 ;
}
2006-07-11 18:06:52 +00:00
static int skel_removexattr ( vfs_handle_struct * handle , const char * path , const char * name )
2003-06-06 07:09:30 +00:00
{
errno = ENOSYS ;
return - 1 ;
}
2008-01-08 22:13:25 +01:00
static int skel_fremovexattr ( vfs_handle_struct * handle , struct files_struct * fsp , const char * name )
2003-06-06 07:09:30 +00:00
{
errno = ENOSYS ;
return - 1 ;
2009-09-25 22:19:27 -07:00
return SMB_VFS_NEXT_FREMOVEXATTR ( handle , fsp , name ) ;
2003-06-06 07:09:30 +00:00
}
2006-07-11 18:06:52 +00:00
static int skel_setxattr ( vfs_handle_struct * handle , const char * path , const char * name , const void * value , size_t size , int flags )
2003-06-06 07:09:30 +00:00
{
errno = ENOSYS ;
return - 1 ;
}
2008-01-08 22:13:25 +01:00
static int skel_fsetxattr ( vfs_handle_struct * handle , struct files_struct * fsp , const char * name , const void * value , size_t size , int flags )
2003-06-06 07:09:30 +00:00
{
errno = ENOSYS ;
return - 1 ;
}
2003-06-04 13:13:41 +00:00
2008-01-16 17:22:31 -08:00
static bool skel_aio_force ( struct vfs_handle_struct * handle , struct files_struct * fsp )
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return false ;
2008-01-16 17:22:31 -08:00
}
2011-03-07 03:53:11 -08:00
static bool skel_is_offline ( struct vfs_handle_struct * handle , const struct smb_filename * fname , SMB_STRUCT_STAT * sbuf )
2008-01-16 17:22:31 -08:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return false ;
2008-01-16 17:22:31 -08:00
}
2011-03-07 03:53:11 -08:00
static int skel_set_offline ( struct vfs_handle_struct * handle , const struct smb_filename * fname )
2008-01-16 17:22:31 -08:00
{
2009-09-25 22:19:27 -07:00
errno = ENOSYS ;
return - 1 ;
2008-01-16 17:22:31 -08:00
}
2003-06-04 13:13:41 +00:00
/* VFS operations structure */
2011-10-08 09:17:11 +02:00
struct vfs_fn_pointers skel_opaque_fns = {
2003-06-04 13:13:41 +00:00
/* Disk operations */
2009-09-25 22:19:27 -07:00
. connect_fn = skel_connect ,
2011-12-03 20:45:04 -08:00
. disconnect_fn = skel_disconnect ,
. disk_free_fn = skel_disk_free ,
. get_quota_fn = skel_get_quota ,
. set_quota_fn = skel_set_quota ,
. get_shadow_copy_data_fn = skel_get_shadow_copy_data ,
. statvfs_fn = skel_statvfs ,
. fs_capabilities_fn = skel_fs_capabilities ,
. get_dfs_referrals_fn = skel_get_dfs_referrals ,
2003-08-07 21:49:01 +00:00
2003-06-04 13:13:41 +00:00
/* Directory operations */
2011-12-03 20:45:04 -08:00
. opendir_fn = skel_opendir ,
. fdopendir_fn = skel_fdopendir ,
. readdir_fn = skel_readdir ,
. seekdir_fn = skel_seekdir ,
. telldir_fn = skel_telldir ,
. rewind_dir_fn = skel_rewind_dir ,
. mkdir_fn = skel_mkdir ,
. rmdir_fn = skel_rmdir ,
. closedir_fn = skel_closedir ,
. init_search_op_fn = skel_init_search_op ,
2003-06-04 13:13:41 +00:00
/* File operations */
2011-04-20 22:55:25 +02:00
. open_fn = skel_open ,
2011-12-03 20:45:04 -08:00
. create_file_fn = skel_create_file ,
2009-09-25 22:19:27 -07:00
. close_fn = skel_close_fn ,
2011-12-03 20:45:04 -08:00
. read_fn = skel_vfs_read ,
. pread_fn = skel_pread ,
2012-07-09 17:17:25 +02:00
. pread_send_fn = skel_pread_send ,
. pread_recv_fn = skel_pread_recv ,
2011-12-03 20:45:04 -08:00
. write_fn = skel_write ,
. pwrite_fn = skel_pwrite ,
2012-07-09 17:17:25 +02:00
. pwrite_send_fn = skel_pwrite_send ,
. pwrite_recv_fn = skel_pwrite_recv ,
2011-12-03 20:45:04 -08:00
. lseek_fn = skel_lseek ,
. sendfile_fn = skel_sendfile ,
. recvfile_fn = skel_recvfile ,
. rename_fn = skel_rename ,
. fsync_fn = skel_fsync ,
2012-07-13 10:22:25 +02:00
. fsync_send_fn = skel_fsync_send ,
. fsync_recv_fn = skel_fsync_recv ,
2011-12-03 20:45:04 -08:00
. stat_fn = skel_stat ,
. fstat_fn = skel_fstat ,
. lstat_fn = skel_lstat ,
. get_alloc_size_fn = skel_get_alloc_size ,
. unlink_fn = skel_unlink ,
. chmod_fn = skel_chmod ,
. fchmod_fn = skel_fchmod ,
. chown_fn = skel_chown ,
. fchown_fn = skel_fchown ,
. lchown_fn = skel_lchown ,
. chdir_fn = skel_chdir ,
. getwd_fn = skel_getwd ,
. ntimes_fn = skel_ntimes ,
. ftruncate_fn = skel_ftruncate ,
. fallocate_fn = skel_fallocate ,
. lock_fn = skel_lock ,
. kernel_flock_fn = skel_kernel_flock ,
. linux_setlease_fn = skel_linux_setlease ,
. getlock_fn = skel_getlock ,
. symlink_fn = skel_symlink ,
. readlink_fn = skel_vfs_readlink ,
. link_fn = skel_link ,
. mknod_fn = skel_mknod ,
. realpath_fn = skel_realpath ,
. notify_watch_fn = skel_notify_watch ,
. chflags_fn = skel_chflags ,
. file_id_create_fn = skel_file_id_create ,
. streaminfo_fn = skel_streaminfo ,
. get_real_filename_fn = skel_get_real_filename ,
. connectpath_fn = skel_connectpath ,
. brl_lock_windows_fn = skel_brl_lock_windows ,
. brl_unlock_windows_fn = skel_brl_unlock_windows ,
. brl_cancel_windows_fn = skel_brl_cancel_windows ,
. strict_lock_fn = skel_strict_lock ,
. strict_unlock_fn = skel_strict_unlock ,
. translate_name_fn = skel_translate_name ,
. fsctl_fn = skel_fsctl ,
2009-09-25 22:19:27 -07:00
/* NT ACL operations. */
2011-12-03 20:45:04 -08:00
. fget_nt_acl_fn = skel_fget_nt_acl ,
. get_nt_acl_fn = skel_get_nt_acl ,
. fset_nt_acl_fn = skel_fset_nt_acl ,
2009-09-25 22:19:27 -07:00
/* POSIX ACL operations. */
2011-12-03 20:45:04 -08:00
. chmod_acl_fn = skel_chmod_acl ,
. fchmod_acl_fn = skel_fchmod_acl ,
. sys_acl_get_file_fn = skel_sys_acl_get_file ,
. sys_acl_get_fd_fn = skel_sys_acl_get_fd ,
2012-09-10 12:44:01 +10:00
. sys_acl_blob_get_file_fn = skel_sys_acl_blob_get_file ,
. sys_acl_blob_get_fd_fn = skel_sys_acl_blob_get_fd ,
2011-12-03 20:45:04 -08:00
. sys_acl_set_file_fn = skel_sys_acl_set_file ,
. sys_acl_set_fd_fn = skel_sys_acl_set_fd ,
. sys_acl_delete_def_file_fn = skel_sys_acl_delete_def_file ,
2008-01-16 17:22:31 -08:00
2012-09-10 12:44:01 +10:00
2003-06-06 07:09:30 +00:00
/* EA operations. */
2011-12-03 20:45:04 -08:00
. getxattr_fn = skel_getxattr ,
. fgetxattr_fn = skel_fgetxattr ,
. listxattr_fn = skel_listxattr ,
. flistxattr_fn = skel_flistxattr ,
. removexattr_fn = skel_removexattr ,
. fremovexattr_fn = skel_fremovexattr ,
. setxattr_fn = skel_setxattr ,
. fsetxattr_fn = skel_fsetxattr ,
2009-09-25 22:19:27 -07:00
/* aio operations */
2011-12-03 20:45:04 -08:00
. aio_force_fn = skel_aio_force ,
2009-09-25 22:19:27 -07:00
/* offline operations */
2011-12-03 20:45:04 -08:00
. is_offline_fn = skel_is_offline ,
. set_offline_fn = skel_set_offline
2003-06-04 13:13:41 +00:00
} ;
2011-10-08 09:17:11 +02:00
NTSTATUS vfs_skel_opaque_init ( void )
2003-06-04 13:13:41 +00:00
{
2011-10-08 09:17:11 +02:00
return smb_register_vfs ( SMB_VFS_INTERFACE_VERSION , " skel_opaque " , & skel_opaque_fns ) ;
2003-06-04 13:13:41 +00:00
}