2008-03-04 21:46:09 +01:00
/*
2006-01-13 21:22:25 +00:00
* Unix SMB / CIFS implementation .
2001-02-27 18:22:39 +00:00
* RPC Pipe client / server routines
* Copyright ( C ) Andrew Tridgell 1992 - 1997 ,
2006-01-23 14:34:26 +00:00
* Copyright ( C ) Jeremy Allison 2001.
* Copyright ( C ) Nigel Williams 2001.
2006-07-11 18:01:26 +00:00
* Copyright ( C ) Gerald ( Jerry ) Carter 2006.
2008-03-21 04:13:49 +01:00
* Copyright ( C ) Guenther Deschner 2008.
2008-03-04 21:46:09 +01:00
*
2001-02-27 18:22:39 +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
2001-02-27 18:22:39 +00:00
* ( at your option ) any later version .
2008-03-04 21:46:09 +01:00
*
2001-02-27 18:22:39 +00:00
* 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 .
2008-03-04 21:46:09 +01:00
*
2001-02-27 18:22:39 +00:00
* 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/>.
2001-02-27 18:22:39 +00:00
*/
/* This is the implementation of the srvsvc pipe. */
# include "includes.h"
2009-11-26 18:21:28 +01:00
# include "../librpc/gen_ndr/srv_srvsvc.h"
2010-05-05 01:39:16 +02:00
# include "librpc/gen_ndr/messaging.h"
2001-02-27 18:22:39 +00:00
2007-10-05 21:41:17 +00:00
extern const struct generic_mapping file_generic_mapping ;
2005-04-06 16:28:04 +00:00
2002-07-15 10:35:28 +00:00
# undef DBGC_CLASS
# define DBGC_CLASS DBGC_RPC_SRV
2008-03-21 03:56:54 +01:00
# define MAX_SERVER_DISK_ENTRIES 15
2006-07-11 18:01:26 +00:00
/* Use for enumerating connections, pipes, & files */
struct file_enum_count {
TALLOC_CTX * ctx ;
2007-10-03 18:37:57 +00:00
const char * username ;
2008-03-19 01:25:59 +01:00
struct srvsvc_NetFileCtr3 * ctr3 ;
2006-07-11 18:01:26 +00:00
} ;
struct sess_file_count {
2007-05-07 15:31:12 +00:00
struct server_id pid ;
2006-07-11 18:01:26 +00:00
uid_t uid ;
int count ;
} ;
/****************************************************************************
Count the entries belonging to a service in the connection db .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-05-28 11:38:42 +00:00
static int pipe_enum_fn ( struct db_record * rec , void * p )
2006-07-11 18:01:26 +00:00
{
struct pipe_open_rec prec ;
struct file_enum_count * fenum = ( struct file_enum_count * ) p ;
2008-03-19 01:25:59 +01:00
struct srvsvc_NetFileInfo3 * f ;
int i = fenum - > ctr3 - > count ;
2007-11-27 14:35:30 -08:00
char * fullpath = NULL ;
2007-10-03 18:37:57 +00:00
const char * username ;
2007-11-27 14:35:30 -08:00
2007-05-28 11:38:42 +00:00
if ( rec - > value . dsize ! = sizeof ( struct pipe_open_rec ) )
2006-07-11 18:01:26 +00:00
return 0 ;
2007-05-28 11:38:42 +00:00
memcpy ( & prec , rec - > value . dptr , sizeof ( struct pipe_open_rec ) ) ;
2007-11-27 14:35:30 -08:00
2007-10-03 18:37:57 +00:00
if ( ! process_exists ( prec . pid ) ) {
return 0 ;
}
username = uidtoname ( prec . uid ) ;
if ( ( fenum - > username ! = NULL )
& & ! strequal ( username , fenum - > username ) ) {
return 0 ;
}
2007-11-27 14:35:30 -08:00
fullpath = talloc_asprintf ( fenum - > ctx , " \\ PIPE \\ %s " , prec . name ) ;
if ( ! fullpath ) {
return 1 ;
}
2008-03-19 01:25:59 +01:00
f = TALLOC_REALLOC_ARRAY ( fenum - > ctx , fenum - > ctr3 - > array ,
struct srvsvc_NetFileInfo3 , i + 1 ) ;
2007-10-03 18:37:57 +00:00
if ( ! f ) {
DEBUG ( 0 , ( " conn_enum_fn: realloc failed for %d items \n " , i + 1 ) ) ;
return 1 ;
}
2008-03-19 01:25:59 +01:00
fenum - > ctr3 - > array = f ;
2007-11-27 14:35:30 -08:00
2008-12-08 13:39:32 +01:00
fenum - > ctr3 - > array [ i ] . fid =
( ( ( uint32_t ) ( procid_to_pid ( & prec . pid ) ) < < 16 ) | prec . pnum ) ;
fenum - > ctr3 - > array [ i ] . permissions =
( FILE_READ_DATA | FILE_WRITE_DATA ) ;
fenum - > ctr3 - > array [ i ] . num_locks = 0 ;
fenum - > ctr3 - > array [ i ] . path = fullpath ;
fenum - > ctr3 - > array [ i ] . user = username ;
2007-11-27 14:35:30 -08:00
2008-03-19 01:25:59 +01:00
fenum - > ctr3 - > count + + ;
2007-10-03 18:37:57 +00:00
2006-07-11 18:01:26 +00:00
return 0 ;
}
/*******************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-19 01:25:59 +01:00
static WERROR net_enum_pipes ( TALLOC_CTX * ctx ,
const char * username ,
struct srvsvc_NetFileCtr3 * * ctr3 ,
uint32_t resume )
2006-07-11 18:01:26 +00:00
{
struct file_enum_count fenum ;
2008-03-04 21:46:09 +01:00
2006-07-11 18:01:26 +00:00
fenum . ctx = ctx ;
2007-10-03 18:37:57 +00:00
fenum . username = username ;
2008-03-19 01:25:59 +01:00
fenum . ctr3 = * ctr3 ;
2006-07-11 18:01:26 +00:00
2007-05-08 13:44:36 +00:00
if ( connections_traverse ( pipe_enum_fn , & fenum ) = = - 1 ) {
DEBUG ( 0 , ( " net_enum_pipes: traverse of connections.tdb "
" failed \n " ) ) ;
2006-07-11 18:01:26 +00:00
return WERR_NOMEM ;
}
2007-11-27 14:35:30 -08:00
2008-03-19 01:25:59 +01:00
* ctr3 = fenum . ctr3 ;
2007-11-27 14:35:30 -08:00
2007-05-08 13:44:36 +00:00
return WERR_OK ;
}
2006-07-11 18:01:26 +00:00
/*******************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-11-27 14:35:30 -08:00
static void enum_file_fn ( const struct share_mode_entry * e ,
2006-07-21 14:13:30 +00:00
const char * sharepath , const char * fname ,
2007-05-28 11:38:42 +00:00
void * private_data )
2006-07-11 18:01:26 +00:00
{
2007-10-10 15:34:30 -05:00
struct file_enum_count * fenum =
( struct file_enum_count * ) private_data ;
2007-10-03 13:13:02 +00:00
2008-03-19 01:25:59 +01:00
struct srvsvc_NetFileInfo3 * f ;
int i = fenum - > ctr3 - > count ;
2007-10-03 13:13:02 +00:00
files_struct fsp ;
struct byte_range_lock * brl ;
int num_locks = 0 ;
2007-11-27 14:35:30 -08:00
char * fullpath = NULL ;
2007-10-03 13:13:02 +00:00
uint32 permissions ;
2007-10-03 18:37:57 +00:00
const char * username ;
2007-11-27 14:35:30 -08:00
2006-07-11 18:01:26 +00:00
/* If the pid was not found delete the entry from connections.tdb */
2007-10-10 15:34:30 -05:00
if ( ! process_exists ( e - > pid ) ) {
2007-10-03 13:13:02 +00:00
return ;
}
2007-10-03 18:37:57 +00:00
username = uidtoname ( e - > uid ) ;
if ( ( fenum - > username ! = NULL )
& & ! strequal ( username , fenum - > username ) ) {
return ;
}
2007-11-27 14:35:30 -08:00
2008-03-19 01:25:59 +01:00
f = TALLOC_REALLOC_ARRAY ( fenum - > ctx , fenum - > ctr3 - > array ,
struct srvsvc_NetFileInfo3 , i + 1 ) ;
2007-10-03 13:13:02 +00:00
if ( ! f ) {
DEBUG ( 0 , ( " conn_enum_fn: realloc failed for %d items \n " , i + 1 ) ) ;
return ;
}
2008-03-19 01:25:59 +01:00
fenum - > ctr3 - > array = f ;
2006-07-11 18:01:26 +00:00
2007-10-03 13:13:02 +00:00
/* need to count the number of locks on a file */
2007-11-27 14:35:30 -08:00
ZERO_STRUCT ( fsp ) ;
2007-10-03 13:13:02 +00:00
fsp . file_id = e - > id ;
2007-11-27 14:35:30 -08:00
2008-01-06 16:15:45 +01:00
if ( ( brl = brl_get_locks ( talloc_tos ( ) , & fsp ) ) ! = NULL ) {
2007-10-03 13:13:02 +00:00
num_locks = brl - > num_locks ;
2007-11-27 14:35:30 -08:00
TALLOC_FREE ( brl ) ;
2007-10-03 13:13:02 +00:00
}
2007-11-27 14:35:30 -08:00
2007-10-03 13:13:02 +00:00
if ( strcmp ( fname , " . " ) = = 0 ) {
2007-11-27 14:35:30 -08:00
fullpath = talloc_asprintf ( fenum - > ctx , " C:%s " , sharepath ) ;
2007-10-03 13:13:02 +00:00
} else {
2007-11-27 14:35:30 -08:00
fullpath = talloc_asprintf ( fenum - > ctx , " C:%s/%s " ,
sharepath , fname ) ;
}
if ( ! fullpath ) {
return ;
2007-10-03 13:13:02 +00:00
}
string_replace ( fullpath , ' / ' , ' \\ ' ) ;
2007-11-27 14:35:30 -08:00
2007-10-03 13:13:02 +00:00
/* mask out create (what ever that is) */
2008-05-22 14:28:13 -07:00
permissions = e - > access_mask & ( FILE_READ_DATA | FILE_WRITE_DATA ) ;
2007-10-03 13:13:02 +00:00
2008-03-19 01:25:59 +01:00
/* now fill in the srvsvc_NetFileInfo3 struct */
2008-12-08 13:39:53 +01:00
fenum - > ctr3 - > array [ i ] . fid =
( ( ( uint32_t ) ( procid_to_pid ( & e - > pid ) ) < < 16 ) | e - > share_file_id ) ;
fenum - > ctr3 - > array [ i ] . permissions = permissions ;
fenum - > ctr3 - > array [ i ] . num_locks = num_locks ;
fenum - > ctr3 - > array [ i ] . path = fullpath ;
fenum - > ctr3 - > array [ i ] . user = username ;
2008-03-19 01:25:59 +01:00
fenum - > ctr3 - > count + + ;
2006-07-11 18:01:26 +00:00
}
/*******************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-19 01:25:59 +01:00
static WERROR net_enum_files ( TALLOC_CTX * ctx ,
const char * username ,
struct srvsvc_NetFileCtr3 * * ctr3 ,
uint32_t resume )
2006-07-11 18:01:26 +00:00
{
2007-05-28 11:38:42 +00:00
struct file_enum_count f_enum_cnt ;
2006-07-11 18:01:26 +00:00
f_enum_cnt . ctx = ctx ;
2007-10-03 18:37:57 +00:00
f_enum_cnt . username = username ;
2008-03-19 01:25:59 +01:00
f_enum_cnt . ctr3 = * ctr3 ;
2008-03-04 21:46:09 +01:00
2007-05-28 11:38:42 +00:00
share_mode_forall ( enum_file_fn , ( void * ) & f_enum_cnt ) ;
2008-03-04 21:46:09 +01:00
2008-03-19 01:25:59 +01:00
* ctr3 = f_enum_cnt . ctr3 ;
2008-03-04 21:46:09 +01:00
2006-07-11 18:01:26 +00:00
return WERR_OK ;
}
2002-08-17 15:34:15 +00:00
/*******************************************************************
2007-10-10 15:34:30 -05:00
Utility function to get the ' type ' of a share from an snum .
2002-08-17 15:34:15 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-11-27 14:35:30 -08:00
static uint32 get_share_type ( int snum )
2002-08-17 15:34:15 +00:00
{
/* work out the share type */
uint32 type = STYPE_DISKTREE ;
2007-10-10 15:34:30 -05:00
if ( lp_print_ok ( snum ) )
2002-08-17 15:34:15 +00:00
type = STYPE_PRINTQ ;
2007-10-10 15:34:30 -05:00
if ( strequal ( lp_fstype ( snum ) , " IPC " ) )
2002-08-17 15:34:15 +00:00
type = STYPE_IPC ;
2008-02-28 14:06:11 +01:00
if ( lp_administrative_share ( snum ) )
2002-08-17 15:34:15 +00:00
type | = STYPE_HIDDEN ;
return type ;
}
2007-11-27 14:35:30 -08:00
2002-08-17 15:34:15 +00:00
/*******************************************************************
Fill in a share info level 0 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 16:19:43 +01:00
static void init_srv_share_info_0 ( pipes_struct * p , struct srvsvc_NetShareInfo0 * r , int snum )
2002-08-17 15:34:15 +00:00
{
2008-12-08 13:39:32 +01:00
r - > name = lp_servicename ( snum ) ;
2002-08-17 15:34:15 +00:00
}
2001-02-27 18:22:39 +00:00
/*******************************************************************
Fill in a share info level 1 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 16:19:43 +01:00
static void init_srv_share_info_1 ( pipes_struct * p , struct srvsvc_NetShareInfo1 * r , int snum )
2001-02-27 18:22:39 +00:00
{
2007-10-10 15:34:30 -05:00
char * net_name = lp_servicename ( snum ) ;
2007-11-27 14:35:30 -08:00
char * remark = talloc_strdup ( p - > mem_ctx , lp_comment ( snum ) ) ;
2001-02-27 18:22:39 +00:00
2007-11-27 14:35:30 -08:00
if ( remark ) {
2008-06-23 08:33:04 +02:00
remark = talloc_sub_advanced (
p - > mem_ctx , lp_servicename ( snum ) ,
get_current_username ( ) , lp_pathname ( snum ) ,
2008-11-23 23:48:17 +01:00
p - > server_info - > utok . uid , get_current_username ( ) ,
2008-06-23 08:33:04 +02:00
" " , remark ) ;
2007-11-27 14:35:30 -08:00
}
2008-12-08 13:39:32 +01:00
r - > name = net_name ;
r - > type = get_share_type ( snum ) ;
r - > comment = remark ? remark : " " ;
2001-02-27 18:22:39 +00:00
}
/*******************************************************************
Fill in a share info level 2 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 16:19:43 +01:00
static void init_srv_share_info_2 ( pipes_struct * p , struct srvsvc_NetShareInfo2 * r , int snum )
2001-02-27 18:22:39 +00:00
{
2007-11-27 14:35:30 -08:00
char * remark = NULL ;
char * path = NULL ;
2007-10-10 15:34:30 -05:00
int max_connections = lp_max_connections ( snum ) ;
2008-03-31 23:51:34 +02:00
uint32_t max_uses = max_connections ! = 0 ? max_connections : ( uint32_t ) - 1 ;
2007-10-10 15:34:30 -05:00
char * net_name = lp_servicename ( snum ) ;
2001-05-01 01:01:19 +00:00
2007-11-27 14:35:30 -08:00
remark = talloc_strdup ( p - > mem_ctx , lp_comment ( snum ) ) ;
if ( remark ) {
2008-06-23 08:33:04 +02:00
remark = talloc_sub_advanced (
p - > mem_ctx , lp_servicename ( snum ) ,
get_current_username ( ) , lp_pathname ( snum ) ,
2008-11-23 23:48:17 +01:00
p - > server_info - > utok . uid , get_current_username ( ) ,
2008-06-23 08:33:04 +02:00
" " , remark ) ;
2007-11-27 14:35:30 -08:00
}
path = talloc_asprintf ( p - > mem_ctx ,
" C:%s " , lp_pathname ( snum ) ) ;
if ( path ) {
/*
* Change / to \ \ so that win2k will see it as a valid path .
* This was added to enable use of browsing in win2k add
* share dialog .
*/
string_replace ( path , ' / ' , ' \\ ' ) ;
}
2008-12-08 13:39:32 +01:00
r - > name = net_name ;
r - > type = get_share_type ( snum ) ;
r - > comment = remark ? remark : " " ;
r - > permissions = 0 ;
r - > max_users = max_uses ;
r - > current_users = count_current_connections ( net_name , false ) ;
r - > path = path ? path : " " ;
r - > password = " " ;
2001-02-27 18:22:39 +00:00
}
2001-04-09 08:00:19 +00:00
/*******************************************************************
Map any generic bits to file specific bits .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2010-05-18 10:29:34 +02:00
static void map_generic_share_sd_bits ( struct security_descriptor * psd )
2001-04-09 08:00:19 +00:00
{
int i ;
2010-05-18 03:30:40 +02:00
struct security_acl * ps_dacl = NULL ;
2001-04-09 08:00:19 +00:00
if ( ! psd )
return ;
ps_dacl = psd - > dacl ;
if ( ! ps_dacl )
return ;
for ( i = 0 ; i < ps_dacl - > num_aces ; i + + ) {
2010-05-18 03:25:38 +02:00
struct security_ace * psa = & ps_dacl - > aces [ i ] ;
2006-09-20 22:23:12 +00:00
uint32 orig_mask = psa - > access_mask ;
2001-04-09 08:00:19 +00:00
2006-09-20 22:23:12 +00:00
se_map_generic ( & psa - > access_mask , & file_generic_mapping ) ;
psa - > access_mask | = orig_mask ;
2007-11-27 14:35:30 -08:00
}
2001-04-09 08:00:19 +00:00
}
2002-04-10 01:04:13 +00:00
/*******************************************************************
Fill in a share info level 501 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 16:19:43 +01:00
static void init_srv_share_info_501 ( pipes_struct * p , struct srvsvc_NetShareInfo501 * r , int snum )
2002-04-10 01:04:13 +00:00
{
2007-10-10 15:34:30 -05:00
const char * net_name = lp_servicename ( snum ) ;
2007-11-27 14:35:30 -08:00
char * remark = talloc_strdup ( p - > mem_ctx , lp_comment ( snum ) ) ;
2006-07-14 22:06:38 +00:00
2007-11-27 14:35:30 -08:00
if ( remark ) {
2008-06-23 08:33:04 +02:00
remark = talloc_sub_advanced (
p - > mem_ctx , lp_servicename ( snum ) ,
get_current_username ( ) , lp_pathname ( snum ) ,
2008-11-23 23:48:17 +01:00
p - > server_info - > utok . uid , get_current_username ( ) ,
2008-06-23 08:33:04 +02:00
" " , remark ) ;
2007-11-27 14:35:30 -08:00
}
2008-12-08 13:39:32 +01:00
r - > name = net_name ;
r - > type = get_share_type ( snum ) ;
r - > comment = remark ? remark : " " ;
r - > csc_policy = ( lp_csc_policy ( snum ) < < 4 ) ;
2002-04-10 01:04:13 +00:00
}
2001-04-04 23:42:17 +00:00
/*******************************************************************
Fill in a share info level 502 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 16:19:43 +01:00
static void init_srv_share_info_502 ( pipes_struct * p , struct srvsvc_NetShareInfo502 * r , int snum )
2001-04-04 23:42:17 +00:00
{
2007-11-27 14:35:30 -08:00
const char * net_name = lp_servicename ( snum ) ;
char * path = NULL ;
2010-05-18 10:29:34 +02:00
struct security_descriptor * sd = NULL ;
2008-04-01 00:02:48 +02:00
struct sec_desc_buf * sd_buf = NULL ;
2007-11-27 14:35:30 -08:00
size_t sd_size = 0 ;
2001-08-22 16:10:28 +00:00
TALLOC_CTX * ctx = p - > mem_ctx ;
2007-11-27 14:35:30 -08:00
char * remark = talloc_strdup ( ctx , lp_comment ( snum ) ) ; ;
2001-04-04 23:42:17 +00:00
2007-11-27 14:35:30 -08:00
if ( remark ) {
2008-06-23 08:33:04 +02:00
remark = talloc_sub_advanced (
p - > mem_ctx , lp_servicename ( snum ) ,
get_current_username ( ) , lp_pathname ( snum ) ,
2008-11-23 23:48:17 +01:00
p - > server_info - > utok . uid , get_current_username ( ) ,
2008-06-23 08:33:04 +02:00
" " , remark ) ;
2007-11-27 14:35:30 -08:00
}
path = talloc_asprintf ( ctx , " C:%s " , lp_pathname ( snum ) ) ;
if ( path ) {
/*
* Change / to \ \ so that win2k will see it as a valid path . This was added to
* enable use of browsing in win2k add share dialog .
*/
string_replace ( path , ' / ' , ' \\ ' ) ;
}
2007-10-10 15:34:30 -05:00
sd = get_share_security ( ctx , lp_servicename ( snum ) , & sd_size ) ;
2001-04-04 23:42:17 +00:00
2008-04-01 00:02:48 +02:00
sd_buf = make_sec_desc_buf ( p - > mem_ctx , sd_size , sd ) ;
2008-12-08 13:39:32 +01:00
r - > name = net_name ;
r - > type = get_share_type ( snum ) ;
r - > comment = remark ? remark : " " ;
r - > permissions = 0 ;
r - > max_users = ( uint32_t ) - 1 ;
r - > current_users = 1 ; /* ??? */
r - > path = path ? path : " " ;
r - > password = " " ;
r - > sd_buf = * sd_buf ;
2002-08-17 15:34:15 +00:00
}
/***************************************************************************
Fill in a share info level 1004 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 16:19:43 +01:00
static void init_srv_share_info_1004 ( pipes_struct * p , struct srvsvc_NetShareInfo1004 * r , int snum )
2002-08-17 15:34:15 +00:00
{
2007-11-27 14:35:30 -08:00
char * remark = talloc_strdup ( p - > mem_ctx , lp_comment ( snum ) ) ;
2002-08-17 15:34:15 +00:00
2007-11-27 14:35:30 -08:00
if ( remark ) {
2008-06-23 08:33:04 +02:00
remark = talloc_sub_advanced (
p - > mem_ctx , lp_servicename ( snum ) ,
get_current_username ( ) , lp_pathname ( snum ) ,
2008-11-23 23:48:17 +01:00
p - > server_info - > utok . uid , get_current_username ( ) ,
2008-06-23 08:33:04 +02:00
" " , remark ) ;
2007-11-27 14:35:30 -08:00
}
2002-08-17 15:34:15 +00:00
2008-12-08 13:39:32 +01:00
r - > comment = remark ? remark : " " ;
2001-04-04 23:42:17 +00:00
}
2001-02-27 18:22:39 +00:00
/***************************************************************************
Fill in a share info level 1005 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 16:19:43 +01:00
static void init_srv_share_info_1005 ( pipes_struct * p , struct srvsvc_NetShareInfo1005 * r , int snum )
2001-02-27 18:22:39 +00:00
{
2008-03-07 16:19:43 +01:00
uint32_t dfs_flags = 0 ;
if ( lp_host_msdfs ( ) & & lp_msdfs_root ( snum ) ) {
dfs_flags | = SHARE_1005_IN_DFS | SHARE_1005_DFS_ROOT ;
}
2001-02-27 18:22:39 +00:00
2008-03-07 16:19:43 +01:00
dfs_flags | = lp_csc_policy ( snum ) < < SHARE_1005_CSC_POLICY_SHIFT ;
2008-12-08 13:39:32 +01:00
r - > dfs_flags = dfs_flags ;
2001-02-27 18:22:39 +00:00
}
2008-03-07 16:19:43 +01:00
2002-08-17 15:34:15 +00:00
/***************************************************************************
Fill in a share info level 1006 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 16:19:43 +01:00
static void init_srv_share_info_1006 ( pipes_struct * p , struct srvsvc_NetShareInfo1006 * r , int snum )
2002-08-17 15:34:15 +00:00
{
2008-12-08 13:39:32 +01:00
r - > max_users = ( uint32_t ) - 1 ;
2002-08-17 15:34:15 +00:00
}
/***************************************************************************
Fill in a share info level 1007 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 16:19:43 +01:00
static void init_srv_share_info_1007 ( pipes_struct * p , struct srvsvc_NetShareInfo1007 * r , int snum )
2002-08-17 15:34:15 +00:00
{
2008-12-08 13:39:32 +01:00
r - > flags = 0 ;
r - > alternate_directory_name = " " ;
2002-08-17 15:34:15 +00:00
}
/*******************************************************************
Fill in a share info level 1501 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 16:19:43 +01:00
static void init_srv_share_info_1501 ( pipes_struct * p , struct sec_desc_buf * r , int snum )
2002-08-17 15:34:15 +00:00
{
2010-05-18 10:29:34 +02:00
struct security_descriptor * sd ;
2002-08-17 15:34:15 +00:00
size_t sd_size ;
TALLOC_CTX * ctx = p - > mem_ctx ;
2007-10-10 15:34:30 -05:00
sd = get_share_security ( ctx , lp_servicename ( snum ) , & sd_size ) ;
2002-08-17 15:34:15 +00:00
2008-03-07 16:19:43 +01:00
r = make_sec_desc_buf ( p - > mem_ctx , sd_size , sd ) ;
2002-08-17 15:34:15 +00:00
}
2001-02-27 18:22:39 +00:00
2001-04-06 01:39:12 +00:00
/*******************************************************************
True if it ends in ' $ ' .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-10-18 17:40:25 -07:00
static bool is_hidden_share ( int snum )
2001-04-06 01:39:12 +00:00
{
2007-10-10 15:34:30 -05:00
const char * net_name = lp_servicename ( snum ) ;
2001-04-06 01:39:12 +00:00
2007-10-10 15:34:30 -05:00
return ( net_name [ strlen ( net_name ) - 1 ] = = ' $ ' ) ? True : False ;
2001-04-06 01:39:12 +00:00
}
2008-12-04 11:33:32 -08:00
/*******************************************************************
Verify user is allowed to view share , access based enumeration
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static bool is_enumeration_allowed ( pipes_struct * p ,
int snum )
{
if ( ! lp_access_based_share_enum ( snum ) )
return true ;
return share_access_check ( p - > server_info - > ptok , lp_servicename ( snum ) ,
FILE_READ_DATA ) ;
}
2001-02-27 18:22:39 +00:00
/*******************************************************************
Fill in a share info structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 16:19:43 +01:00
static WERROR init_srv_share_info_ctr ( pipes_struct * p ,
struct srvsvc_NetShareInfoCtr * info_ctr ,
uint32_t * resume_handle_p ,
uint32_t * total_entries ,
bool all_shares )
2001-02-27 18:22:39 +00:00
{
2007-10-10 15:34:30 -05:00
int num_entries = 0 ;
2008-03-07 16:19:43 +01:00
int alloc_entries = 0 ;
2007-10-10 15:34:30 -05:00
int num_services = 0 ;
int snum ;
2001-08-22 16:10:28 +00:00
TALLOC_CTX * ctx = p - > mem_ctx ;
2008-03-07 16:19:43 +01:00
int i = 0 ;
int valid_share_count = 0 ;
2008-12-09 12:39:14 +01:00
bool * allowed = 0 ;
2008-03-07 16:19:43 +01:00
union srvsvc_NetShareCtr ctr ;
uint32_t resume_handle = resume_handle_p ? * resume_handle_p : 0 ;
2001-02-27 18:22:39 +00:00
DEBUG ( 5 , ( " init_srv_share_info_ctr \n " ) ) ;
2006-02-03 22:19:41 +00:00
/* Ensure all the usershares are loaded. */
become_root ( ) ;
2008-03-12 02:12:11 +01:00
load_usershare_shares ( ) ;
2006-11-30 07:38:40 +00:00
load_registry_shares ( ) ;
2008-03-12 02:12:11 +01:00
num_services = lp_numservices ( ) ;
2006-02-03 22:19:41 +00:00
unbecome_root ( ) ;
2008-12-09 12:39:14 +01:00
allowed = TALLOC_ZERO_ARRAY ( ctx , bool , num_services ) ;
2008-12-04 11:33:32 -08:00
W_ERROR_HAVE_NO_MEMORY ( allowed ) ;
/* Count the number of entries. */
for ( snum = 0 ; snum < num_services ; snum + + ) {
if ( lp_browseable ( snum ) & & lp_snum_ok ( snum ) & &
is_enumeration_allowed ( p , snum ) & &
( all_shares | | ! is_hidden_share ( snum ) ) ) {
2009-07-15 15:36:02 +08:00
DEBUG ( 10 , ( " counting service %s \n " ,
lp_servicename ( snum ) ? lp_servicename ( snum ) : " (null) " ) ) ;
2008-12-04 11:33:32 -08:00
allowed [ snum ] = true ;
num_entries + + ;
} else {
2009-07-15 15:36:02 +08:00
DEBUG ( 10 , ( " NOT counting service %s \n " ,
lp_servicename ( snum ) ? lp_servicename ( snum ) : " (null) " ) ) ;
2008-12-04 11:33:32 -08:00
}
}
2006-07-14 22:06:38 +00:00
2008-03-07 16:19:43 +01:00
if ( ! num_entries | | ( resume_handle > = num_entries ) ) {
return WERR_OK ;
}
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
/* Calculate alloc entries. */
alloc_entries = num_entries - resume_handle ;
switch ( info_ctr - > level ) {
2006-09-21 23:57:32 +00:00
case 0 :
2008-03-07 16:19:43 +01:00
ctr . ctr0 = TALLOC_ZERO_P ( ctx , struct srvsvc_NetShareCtr0 ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr0 ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
ctr . ctr0 - > count = alloc_entries ;
ctr . ctr0 - > array = TALLOC_ZERO_ARRAY ( ctx , struct srvsvc_NetShareInfo0 , alloc_entries ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr0 - > array ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
for ( snum = 0 ; snum < num_services ; snum + + ) {
2008-12-04 11:33:32 -08:00
if ( allowed [ snum ] & &
2008-03-07 16:19:43 +01:00
( resume_handle < = ( i + valid_share_count + + ) ) ) {
init_srv_share_info_0 ( p , & ctr . ctr0 - > array [ i + + ] , snum ) ;
2007-10-10 15:34:30 -05:00
}
}
2006-09-21 23:57:32 +00:00
break ;
2007-10-10 15:34:30 -05:00
2006-09-21 23:57:32 +00:00
case 1 :
2008-03-07 16:19:43 +01:00
ctr . ctr1 = TALLOC_ZERO_P ( ctx , struct srvsvc_NetShareCtr1 ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr1 ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
ctr . ctr1 - > count = alloc_entries ;
ctr . ctr1 - > array = TALLOC_ZERO_ARRAY ( ctx , struct srvsvc_NetShareInfo1 , alloc_entries ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr1 - > array ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
for ( snum = 0 ; snum < num_services ; snum + + ) {
2008-12-04 11:33:32 -08:00
if ( allowed [ snum ] & &
2008-03-07 16:19:43 +01:00
( resume_handle < = ( i + valid_share_count + + ) ) ) {
init_srv_share_info_1 ( p , & ctr . ctr1 - > array [ i + + ] , snum ) ;
2007-10-10 15:34:30 -05:00
}
2006-10-23 20:11:12 +00:00
}
2007-10-10 15:34:30 -05:00
2006-09-21 23:57:32 +00:00
break ;
2007-10-10 15:34:30 -05:00
2006-09-21 23:57:32 +00:00
case 2 :
2008-03-07 16:19:43 +01:00
ctr . ctr2 = TALLOC_ZERO_P ( ctx , struct srvsvc_NetShareCtr2 ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr2 ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
ctr . ctr2 - > count = alloc_entries ;
ctr . ctr2 - > array = TALLOC_ZERO_ARRAY ( ctx , struct srvsvc_NetShareInfo2 , alloc_entries ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr2 - > array ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
for ( snum = 0 ; snum < num_services ; snum + + ) {
2008-12-04 11:33:32 -08:00
if ( allowed [ snum ] & &
2008-03-07 16:19:43 +01:00
( resume_handle < = ( i + valid_share_count + + ) ) ) {
init_srv_share_info_2 ( p , & ctr . ctr2 - > array [ i + + ] , snum ) ;
2007-10-10 15:34:30 -05:00
}
}
2006-09-21 23:57:32 +00:00
break ;
2007-10-10 15:34:30 -05:00
2006-09-21 23:57:32 +00:00
case 501 :
2008-03-07 16:19:43 +01:00
ctr . ctr501 = TALLOC_ZERO_P ( ctx , struct srvsvc_NetShareCtr501 ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr501 ) ;
2008-03-04 21:46:09 +01:00
2008-03-07 16:19:43 +01:00
ctr . ctr501 - > count = alloc_entries ;
ctr . ctr501 - > array = TALLOC_ZERO_ARRAY ( ctx , struct srvsvc_NetShareInfo501 , alloc_entries ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr501 - > array ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
for ( snum = 0 ; snum < num_services ; snum + + ) {
2008-12-04 11:33:32 -08:00
if ( allowed [ snum ] & &
2008-03-07 16:19:43 +01:00
( resume_handle < = ( i + valid_share_count + + ) ) ) {
init_srv_share_info_501 ( p , & ctr . ctr501 - > array [ i + + ] , snum ) ;
2007-10-10 15:34:30 -05:00
}
2006-10-23 20:11:12 +00:00
}
2008-03-04 21:46:09 +01:00
2006-09-21 23:57:32 +00:00
break ;
2007-10-10 15:34:30 -05:00
2006-09-21 23:57:32 +00:00
case 502 :
2008-03-07 16:19:43 +01:00
ctr . ctr502 = TALLOC_ZERO_P ( ctx , struct srvsvc_NetShareCtr502 ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr502 ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
ctr . ctr502 - > count = alloc_entries ;
ctr . ctr502 - > array = TALLOC_ZERO_ARRAY ( ctx , struct srvsvc_NetShareInfo502 , alloc_entries ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr502 - > array ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
for ( snum = 0 ; snum < num_services ; snum + + ) {
2008-12-04 11:33:32 -08:00
if ( allowed [ snum ] & &
2008-03-07 16:19:43 +01:00
( resume_handle < = ( i + valid_share_count + + ) ) ) {
init_srv_share_info_502 ( p , & ctr . ctr502 - > array [ i + + ] , snum ) ;
2007-10-10 15:34:30 -05:00
}
}
2006-09-21 23:57:32 +00:00
break ;
2008-03-04 21:46:09 +01:00
2006-09-21 23:57:32 +00:00
case 1004 :
2008-03-07 16:19:43 +01:00
ctr . ctr1004 = TALLOC_ZERO_P ( ctx , struct srvsvc_NetShareCtr1004 ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr1004 ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
ctr . ctr1004 - > count = alloc_entries ;
ctr . ctr1004 - > array = TALLOC_ZERO_ARRAY ( ctx , struct srvsvc_NetShareInfo1004 , alloc_entries ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr1004 - > array ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
for ( snum = 0 ; snum < num_services ; snum + + ) {
2008-12-04 11:33:32 -08:00
if ( allowed [ snum ] & &
2008-03-07 16:19:43 +01:00
( resume_handle < = ( i + valid_share_count + + ) ) ) {
init_srv_share_info_1004 ( p , & ctr . ctr1004 - > array [ i + + ] , snum ) ;
2007-10-10 15:34:30 -05:00
}
2006-10-23 20:11:12 +00:00
}
2007-10-10 15:34:30 -05:00
2006-09-21 23:57:32 +00:00
break ;
2007-10-10 15:34:30 -05:00
2006-09-21 23:57:32 +00:00
case 1005 :
2008-03-07 16:19:43 +01:00
ctr . ctr1005 = TALLOC_ZERO_P ( ctx , struct srvsvc_NetShareCtr1005 ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr1005 ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
ctr . ctr1005 - > count = alloc_entries ;
ctr . ctr1005 - > array = TALLOC_ZERO_ARRAY ( ctx , struct srvsvc_NetShareInfo1005 , alloc_entries ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr1005 - > array ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
for ( snum = 0 ; snum < num_services ; snum + + ) {
2008-12-04 11:33:32 -08:00
if ( allowed [ snum ] & &
2008-03-07 16:19:43 +01:00
( resume_handle < = ( i + valid_share_count + + ) ) ) {
init_srv_share_info_1005 ( p , & ctr . ctr1005 - > array [ i + + ] , snum ) ;
2007-10-10 15:34:30 -05:00
}
}
2006-09-21 23:57:32 +00:00
break ;
2007-10-10 15:34:30 -05:00
2006-09-21 23:57:32 +00:00
case 1006 :
2008-03-07 16:19:43 +01:00
ctr . ctr1006 = TALLOC_ZERO_P ( ctx , struct srvsvc_NetShareCtr1006 ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr1006 ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
ctr . ctr1006 - > count = alloc_entries ;
ctr . ctr1006 - > array = TALLOC_ZERO_ARRAY ( ctx , struct srvsvc_NetShareInfo1006 , alloc_entries ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr1006 - > array ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
for ( snum = 0 ; snum < num_services ; snum + + ) {
2008-12-04 11:33:32 -08:00
if ( allowed [ snum ] & &
2008-03-07 16:19:43 +01:00
( resume_handle < = ( i + valid_share_count + + ) ) ) {
init_srv_share_info_1006 ( p , & ctr . ctr1006 - > array [ i + + ] , snum ) ;
2007-10-10 15:34:30 -05:00
}
}
2006-09-21 23:57:32 +00:00
break ;
2007-10-10 15:34:30 -05:00
2006-09-21 23:57:32 +00:00
case 1007 :
2008-03-07 16:19:43 +01:00
ctr . ctr1007 = TALLOC_ZERO_P ( ctx , struct srvsvc_NetShareCtr1007 ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr1007 ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
ctr . ctr1007 - > count = alloc_entries ;
ctr . ctr1007 - > array = TALLOC_ZERO_ARRAY ( ctx , struct srvsvc_NetShareInfo1007 , alloc_entries ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr1007 - > array ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
for ( snum = 0 ; snum < num_services ; snum + + ) {
2008-12-04 11:33:32 -08:00
if ( allowed [ snum ] & &
2008-03-07 16:19:43 +01:00
( resume_handle < = ( i + valid_share_count + + ) ) ) {
init_srv_share_info_1007 ( p , & ctr . ctr1007 - > array [ i + + ] , snum ) ;
2007-10-10 15:34:30 -05:00
}
2006-10-23 20:11:12 +00:00
}
2007-10-10 15:34:30 -05:00
2006-09-21 23:57:32 +00:00
break ;
2007-10-10 15:34:30 -05:00
2006-09-21 23:57:32 +00:00
case 1501 :
2008-03-07 16:19:43 +01:00
ctr . ctr1501 = TALLOC_ZERO_P ( ctx , struct srvsvc_NetShareCtr1501 ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr1501 ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
ctr . ctr1501 - > count = alloc_entries ;
ctr . ctr1501 - > array = TALLOC_ZERO_ARRAY ( ctx , struct sec_desc_buf , alloc_entries ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr . ctr1501 - > array ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
for ( snum = 0 ; snum < num_services ; snum + + ) {
2008-12-04 11:33:32 -08:00
if ( allowed [ snum ] & &
2008-03-07 16:19:43 +01:00
( resume_handle < = ( i + valid_share_count + + ) ) ) {
init_srv_share_info_1501 ( p , & ctr . ctr1501 - > array [ i + + ] , snum ) ;
2007-10-10 15:34:30 -05:00
}
}
2006-09-21 23:57:32 +00:00
break ;
2008-03-07 16:19:43 +01:00
2006-09-21 23:57:32 +00:00
default :
2008-03-07 16:19:43 +01:00
DEBUG ( 5 , ( " init_srv_share_info_ctr: unsupported switch value %d \n " ,
info_ctr - > level ) ) ;
return WERR_UNKNOWN_LEVEL ;
2006-09-21 23:57:32 +00:00
}
2008-03-07 16:19:43 +01:00
* total_entries = alloc_entries ;
if ( resume_handle_p ) {
2008-03-11 11:30:55 +01:00
if ( all_shares ) {
* resume_handle_p = ( num_entries = = 0 ) ? * resume_handle_p : 0 ;
} else {
* resume_handle_p = num_entries ;
}
2007-10-10 15:34:30 -05:00
}
2008-03-07 16:19:43 +01:00
info_ctr - > ctr = ctr ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
return WERR_OK ;
2001-02-27 18:22:39 +00:00
}
/*******************************************************************
fill in a sess info level 0 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-21 03:51:37 +01:00
static WERROR init_srv_sess_info_0 ( pipes_struct * p ,
struct srvsvc_NetSessCtr0 * ctr0 ,
uint32_t * resume_handle_p ,
uint32_t * total_entries )
2001-02-27 18:22:39 +00:00
{
2002-07-15 10:35:28 +00:00
struct sessionid * session_list ;
2008-03-21 03:51:37 +01:00
uint32_t num_entries = 0 ;
uint32_t resume_handle = resume_handle_p ? * resume_handle_p : 0 ;
* total_entries = list_sessions ( p - > mem_ctx , & session_list ) ;
2001-02-27 18:22:39 +00:00
2008-03-21 03:51:37 +01:00
DEBUG ( 5 , ( " init_srv_sess_info_0 \n " ) ) ;
if ( ctr0 = = NULL ) {
if ( resume_handle_p ) {
* resume_handle_p = 0 ;
2006-08-28 04:52:36 +00:00
}
2008-03-21 03:51:37 +01:00
return WERR_OK ;
2001-02-27 18:22:39 +00:00
}
2008-05-22 16:23:07 -07:00
for ( ; resume_handle < * total_entries ; resume_handle + + ) {
2001-02-27 18:22:39 +00:00
2008-03-21 03:51:37 +01:00
ctr0 - > array = TALLOC_REALLOC_ARRAY ( p - > mem_ctx ,
ctr0 - > array ,
struct srvsvc_NetSessInfo0 ,
num_entries + 1 ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr0 - > array ) ;
2001-02-27 18:22:39 +00:00
2008-12-08 13:39:32 +01:00
ctr0 - > array [ num_entries ] . client =
session_list [ resume_handle ] . remote_machine ;
2008-03-21 03:51:37 +01:00
num_entries + + ;
}
2008-03-04 21:46:09 +01:00
2008-03-21 03:51:37 +01:00
ctr0 - > count = num_entries ;
2001-02-27 18:22:39 +00:00
2008-03-21 03:51:37 +01:00
if ( resume_handle_p ) {
if ( * resume_handle_p > = * total_entries ) {
* resume_handle_p = 0 ;
} else {
* resume_handle_p = resume_handle ;
}
2001-02-27 18:22:39 +00:00
}
2008-03-21 03:51:37 +01:00
return WERR_OK ;
2001-02-27 18:22:39 +00:00
}
/*******************************************************************
2006-07-11 18:01:26 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2001-02-27 18:22:39 +00:00
2008-03-04 21:46:09 +01:00
static void sess_file_fn ( const struct share_mode_entry * e ,
2007-12-27 21:30:15 +01:00
const char * sharepath , const char * fname ,
void * data )
2001-02-27 18:22:39 +00:00
{
2007-12-27 21:30:15 +01:00
struct sess_file_count * sess = ( struct sess_file_count * ) data ;
2008-03-04 21:46:09 +01:00
2007-05-07 15:31:12 +00:00
if ( procid_equal ( & e - > pid , & sess - > pid ) & & ( sess - > uid = = e - > uid ) ) {
2006-07-11 18:01:26 +00:00
sess - > count + + ;
}
2008-03-04 21:46:09 +01:00
2006-07-11 18:01:26 +00:00
return ;
}
/*******************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-05-07 15:31:12 +00:00
static int net_count_files ( uid_t uid , struct server_id pid )
2006-07-11 18:01:26 +00:00
{
2007-12-27 21:30:15 +01:00
struct sess_file_count s_file_cnt ;
2006-07-11 18:01:26 +00:00
s_file_cnt . count = 0 ;
s_file_cnt . uid = uid ;
s_file_cnt . pid = pid ;
2008-03-04 21:46:09 +01:00
2007-12-27 21:30:15 +01:00
share_mode_forall ( sess_file_fn , & s_file_cnt ) ;
2008-03-04 21:46:09 +01:00
2006-07-11 18:01:26 +00:00
return s_file_cnt . count ;
2001-02-27 18:22:39 +00:00
}
/*******************************************************************
fill in a sess info level 1 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-21 03:51:37 +01:00
static WERROR init_srv_sess_info_1 ( pipes_struct * p ,
struct srvsvc_NetSessCtr1 * ctr1 ,
uint32_t * resume_handle_p ,
uint32_t * total_entries )
2001-02-27 18:22:39 +00:00
{
2002-07-15 10:35:28 +00:00
struct sessionid * session_list ;
2008-03-21 03:51:37 +01:00
uint32_t num_entries = 0 ;
2006-07-11 18:01:26 +00:00
time_t now = time ( NULL ) ;
2008-03-21 03:51:37 +01:00
uint32_t resume_handle = resume_handle_p ? * resume_handle_p : 0 ;
2001-02-27 18:22:39 +00:00
2008-03-21 03:51:37 +01:00
ZERO_STRUCTP ( ctr1 ) ;
2008-03-04 21:46:09 +01:00
2008-03-21 03:51:37 +01:00
if ( ctr1 = = NULL ) {
if ( resume_handle_p ) {
* resume_handle_p = 0 ;
}
return WERR_OK ;
2001-02-27 18:22:39 +00:00
}
2008-03-21 03:51:37 +01:00
* total_entries = list_sessions ( p - > mem_ctx , & session_list ) ;
2008-03-04 21:46:09 +01:00
2008-05-22 16:23:07 -07:00
for ( ; resume_handle < * total_entries ; resume_handle + + ) {
2006-07-11 18:01:26 +00:00
uint32 num_files ;
uint32 connect_time ;
2008-03-21 03:51:37 +01:00
struct passwd * pw = sys_getpwnam ( session_list [ resume_handle ] . username ) ;
2007-10-18 17:40:25 -07:00
bool guest ;
2008-03-04 21:46:09 +01:00
2006-07-11 18:01:26 +00:00
if ( ! pw ) {
DEBUG ( 10 , ( " init_srv_sess_info_1: failed to find owner: %s \n " ,
2008-03-21 03:51:37 +01:00
session_list [ resume_handle ] . username ) ) ;
2006-07-11 18:01:26 +00:00
continue ;
2001-02-27 18:22:39 +00:00
}
2008-03-04 21:46:09 +01:00
2008-03-21 03:51:37 +01:00
connect_time = ( uint32_t ) ( now - session_list [ resume_handle ] . connect_start ) ;
num_files = net_count_files ( pw - > pw_uid , session_list [ resume_handle ] . pid ) ;
guest = strequal ( session_list [ resume_handle ] . username , lp_guestaccount ( ) ) ;
2008-03-04 21:46:09 +01:00
2008-03-21 03:51:37 +01:00
ctr1 - > array = TALLOC_REALLOC_ARRAY ( p - > mem_ctx ,
ctr1 - > array ,
struct srvsvc_NetSessInfo1 ,
num_entries + 1 ) ;
W_ERROR_HAVE_NO_MEMORY ( ctr1 - > array ) ;
2008-12-08 13:39:32 +01:00
ctr1 - > array [ num_entries ] . client = session_list [ resume_handle ] . remote_machine ;
ctr1 - > array [ num_entries ] . user = session_list [ resume_handle ] . username ;
ctr1 - > array [ num_entries ] . num_open = num_files ;
ctr1 - > array [ num_entries ] . time = connect_time ;
ctr1 - > array [ num_entries ] . idle_time = 0 ;
ctr1 - > array [ num_entries ] . user_flags = guest ;
2006-07-11 18:01:26 +00:00
num_entries + + ;
}
2008-03-21 03:51:37 +01:00
ctr1 - > count = num_entries ;
2007-10-10 15:34:30 -05:00
2008-03-21 03:51:37 +01:00
if ( resume_handle_p ) {
if ( * resume_handle_p > = * total_entries ) {
* resume_handle_p = 0 ;
} else {
* resume_handle_p = resume_handle ;
}
2001-02-27 18:22:39 +00:00
}
2008-03-21 03:51:37 +01:00
return WERR_OK ;
2007-10-10 15:34:30 -05:00
}
2001-02-27 18:22:39 +00:00
/*******************************************************************
fill in a conn info level 0 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-21 01:58:43 +01:00
static WERROR init_srv_conn_info_0 ( struct srvsvc_NetConnCtr0 * ctr0 ,
uint32_t * resume_handle_p ,
uint32_t * total_entries )
2001-02-27 18:22:39 +00:00
{
2008-03-21 01:58:43 +01:00
uint32_t num_entries = 0 ;
uint32_t resume_handle = resume_handle_p ? * resume_handle_p : 0 ;
2001-02-27 18:22:39 +00:00
2008-03-21 01:58:43 +01:00
DEBUG ( 5 , ( " init_srv_conn_info_0 \n " ) ) ;
if ( ctr0 = = NULL ) {
if ( resume_handle_p ) {
* resume_handle_p = 0 ;
}
return WERR_OK ;
2001-02-27 18:22:39 +00:00
}
2008-03-21 01:58:43 +01:00
* total_entries = 1 ;
2001-02-27 18:22:39 +00:00
2008-03-21 01:58:43 +01:00
ZERO_STRUCTP ( ctr0 ) ;
2001-02-27 18:22:39 +00:00
2008-05-22 16:23:07 -07:00
for ( ; resume_handle < * total_entries ; resume_handle + + ) {
2001-02-27 18:22:39 +00:00
2008-03-21 01:58:43 +01:00
ctr0 - > array = TALLOC_REALLOC_ARRAY ( talloc_tos ( ) ,
ctr0 - > array ,
struct srvsvc_NetConnInfo0 ,
num_entries + 1 ) ;
if ( ! ctr0 - > array ) {
return WERR_NOMEM ;
2001-02-27 18:22:39 +00:00
}
2008-12-08 13:39:32 +01:00
ctr0 - > array [ num_entries ] . conn_id = * total_entries ;
2008-03-04 21:46:09 +01:00
2008-03-21 01:58:43 +01:00
/* move on to creating next connection */
num_entries + + ;
}
2001-02-27 18:22:39 +00:00
2008-03-21 01:58:43 +01:00
ctr0 - > count = num_entries ;
* total_entries = num_entries ;
2001-02-27 18:22:39 +00:00
2008-03-21 01:58:43 +01:00
if ( resume_handle_p ) {
if ( * resume_handle_p > = * total_entries ) {
* resume_handle_p = 0 ;
} else {
* resume_handle_p = resume_handle ;
}
2001-02-27 18:22:39 +00:00
}
2008-03-21 01:58:43 +01:00
return WERR_OK ;
2007-10-10 15:34:30 -05:00
}
/*******************************************************************
fill in a conn info level 1 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-21 01:58:43 +01:00
static WERROR init_srv_conn_info_1 ( struct srvsvc_NetConnCtr1 * ctr1 ,
uint32_t * resume_handle_p ,
uint32_t * total_entries )
2001-02-27 18:22:39 +00:00
{
2008-03-21 01:58:43 +01:00
uint32_t num_entries = 0 ;
uint32_t resume_handle = resume_handle_p ? * resume_handle_p : 0 ;
2001-02-27 18:22:39 +00:00
2008-03-21 01:58:43 +01:00
DEBUG ( 5 , ( " init_srv_conn_info_1 \n " ) ) ;
2001-02-27 18:22:39 +00:00
2008-03-21 01:58:43 +01:00
if ( ctr1 = = NULL ) {
if ( resume_handle_p ) {
* resume_handle_p = 0 ;
2001-02-27 18:22:39 +00:00
}
2008-03-21 01:58:43 +01:00
return WERR_OK ;
}
2001-02-27 18:22:39 +00:00
2008-03-21 01:58:43 +01:00
* total_entries = 1 ;
2008-03-04 21:46:09 +01:00
2008-03-21 01:58:43 +01:00
ZERO_STRUCTP ( ctr1 ) ;
2001-02-27 18:22:39 +00:00
2008-05-22 16:23:07 -07:00
for ( ; resume_handle < * total_entries ; resume_handle + + ) {
2008-03-21 01:58:43 +01:00
ctr1 - > array = TALLOC_REALLOC_ARRAY ( talloc_tos ( ) ,
ctr1 - > array ,
struct srvsvc_NetConnInfo1 ,
num_entries + 1 ) ;
if ( ! ctr1 - > array ) {
return WERR_NOMEM ;
2001-02-27 18:22:39 +00:00
}
2008-12-08 13:39:32 +01:00
ctr1 - > array [ num_entries ] . conn_id = * total_entries ;
ctr1 - > array [ num_entries ] . conn_type = 0x3 ;
ctr1 - > array [ num_entries ] . num_open = 1 ;
ctr1 - > array [ num_entries ] . num_users = 1 ;
ctr1 - > array [ num_entries ] . conn_time = 3 ;
ctr1 - > array [ num_entries ] . user = " dummy_user " ;
ctr1 - > array [ num_entries ] . share = " IPC$ " ;
2008-03-04 21:46:09 +01:00
2008-03-21 01:58:43 +01:00
/* move on to creating next connection */
num_entries + + ;
2001-02-27 18:22:39 +00:00
}
2008-03-21 01:58:43 +01:00
ctr1 - > count = num_entries ;
* total_entries = num_entries ;
2001-02-27 18:22:39 +00:00
2008-03-21 01:58:43 +01:00
if ( resume_handle_p ) {
if ( * resume_handle_p > = * total_entries ) {
* resume_handle_p = 0 ;
} else {
* resume_handle_p = resume_handle ;
}
2001-02-27 18:22:39 +00:00
}
2008-03-21 01:58:43 +01:00
return WERR_OK ;
2007-10-10 15:34:30 -05:00
}
2001-02-27 18:22:39 +00:00
/*******************************************************************
2008-03-19 01:25:59 +01:00
_srvsvc_NetFileEnum
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2001-02-27 18:22:39 +00:00
2008-03-19 01:25:59 +01:00
WERROR _srvsvc_NetFileEnum ( pipes_struct * p ,
struct srvsvc_NetFileEnum * r )
2001-02-27 18:22:39 +00:00
{
2008-03-19 01:25:59 +01:00
TALLOC_CTX * ctx = NULL ;
struct srvsvc_NetFileCtr3 * ctr3 ;
uint32_t resume_hnd = 0 ;
WERROR werr ;
switch ( r - > in . info_ctr - > level ) {
case 3 :
break ;
default :
return WERR_UNKNOWN_LEVEL ;
}
2010-01-07 11:47:09 +01:00
if ( ! nt_token_check_sid ( & global_sid_Builtin_Administrators ,
p - > server_info - > ptok ) ) {
DEBUG ( 1 , ( " Enumerating files only allowed for "
" administrators \n " ) ) ;
return WERR_ACCESS_DENIED ;
}
2008-03-19 01:25:59 +01:00
ctx = talloc_tos ( ) ;
ctr3 = r - > in . info_ctr - > ctr . ctr3 ;
if ( ! ctr3 ) {
2008-03-20 16:15:38 +01:00
werr = WERR_INVALID_PARAM ;
2008-03-19 01:25:59 +01:00
goto done ;
}
2001-02-27 18:22:39 +00:00
2008-03-04 21:46:09 +01:00
/* TODO -- Windows enumerates
2006-07-11 18:01:26 +00:00
( b ) active pipes
( c ) open directories and files */
2008-03-19 01:25:59 +01:00
werr = net_enum_files ( ctx , r - > in . user , & ctr3 , resume_hnd ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
2007-10-10 15:34:30 -05:00
goto done ;
2008-03-19 01:25:59 +01:00
}
2008-03-04 21:46:09 +01:00
2008-03-19 01:25:59 +01:00
werr = net_enum_pipes ( ctx , r - > in . user , & ctr3 , resume_hnd ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
2007-10-10 15:34:30 -05:00
goto done ;
2008-03-19 01:25:59 +01:00
}
2008-03-04 21:46:09 +01:00
2008-03-19 01:25:59 +01:00
* r - > out . totalentries = ctr3 - > count ;
r - > out . info_ctr - > ctr . ctr3 - > array = ctr3 - > array ;
r - > out . info_ctr - > ctr . ctr3 - > count = ctr3 - > count ;
2007-10-10 15:34:30 -05:00
2008-03-19 01:25:59 +01:00
werr = WERR_OK ;
2008-03-04 21:46:09 +01:00
2008-03-19 01:25:59 +01:00
done :
return werr ;
2001-02-27 18:22:39 +00:00
}
/*******************************************************************
2008-03-04 23:07:45 +01:00
_srvsvc_NetSrvGetInfo
2001-02-27 18:22:39 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-04 23:07:45 +01:00
WERROR _srvsvc_NetSrvGetInfo ( pipes_struct * p ,
struct srvsvc_NetSrvGetInfo * r )
2001-02-27 18:22:39 +00:00
{
2002-03-05 02:12:00 +00:00
WERROR status = WERR_OK ;
2001-02-27 18:22:39 +00:00
2008-03-04 23:07:45 +01:00
DEBUG ( 5 , ( " _srvsvc_NetSrvGetInfo: %d \n " , __LINE__ ) ) ;
2001-02-27 18:22:39 +00:00
2002-07-15 10:35:28 +00:00
if ( ! pipe_access_check ( p ) ) {
2008-03-04 23:07:45 +01:00
DEBUG ( 3 , ( " access denied to _srvsvc_NetSrvGetInfo \n " ) ) ;
2002-07-15 10:35:28 +00:00
return WERR_ACCESS_DENIED ;
}
2008-03-04 23:07:45 +01:00
switch ( r - > in . level ) {
2002-07-15 10:35:28 +00:00
/* Technically level 102 should only be available to
Administrators but there isn ' t anything super - secret
here , as most of it is made up . */
2008-03-04 23:07:45 +01:00
case 102 : {
struct srvsvc_NetSrvInfo102 * info102 ;
info102 = TALLOC_P ( p - > mem_ctx , struct srvsvc_NetSrvInfo102 ) ;
if ( ! info102 ) {
return WERR_NOMEM ;
}
2008-12-08 13:39:32 +01:00
info102 - > platform_id = PLATFORM_ID_NT ;
info102 - > server_name = global_myname ( ) ;
info102 - > version_major = lp_major_announce_version ( ) ;
info102 - > version_minor = lp_minor_announce_version ( ) ;
info102 - > server_type = lp_default_server_announce ( ) ;
info102 - > comment = string_truncate ( lp_serverstring ( ) ,
MAX_SERVER_STRING_LENGTH ) ;
info102 - > users = 0xffffffff ;
info102 - > disc = 0xf ;
info102 - > hidden = 0 ;
info102 - > announce = 240 ;
info102 - > anndelta = 3000 ;
info102 - > licenses = 100000 ;
info102 - > userpath = " C: \\ " ;
2008-03-04 23:07:45 +01:00
r - > out . info - > info102 = info102 ;
2001-02-27 18:22:39 +00:00
break ;
2008-03-04 23:07:45 +01:00
}
case 101 : {
struct srvsvc_NetSrvInfo101 * info101 ;
info101 = TALLOC_P ( p - > mem_ctx , struct srvsvc_NetSrvInfo101 ) ;
if ( ! info101 ) {
return WERR_NOMEM ;
}
2008-12-08 13:39:32 +01:00
info101 - > platform_id = PLATFORM_ID_NT ;
info101 - > server_name = global_myname ( ) ;
info101 - > version_major = lp_major_announce_version ( ) ;
info101 - > version_minor = lp_minor_announce_version ( ) ;
info101 - > server_type = lp_default_server_announce ( ) ;
info101 - > comment = string_truncate ( lp_serverstring ( ) ,
MAX_SERVER_STRING_LENGTH ) ;
2008-03-04 23:07:45 +01:00
r - > out . info - > info101 = info101 ;
2001-02-27 18:22:39 +00:00
break ;
2008-03-04 23:07:45 +01:00
}
case 100 : {
struct srvsvc_NetSrvInfo100 * info100 ;
info100 = TALLOC_P ( p - > mem_ctx , struct srvsvc_NetSrvInfo100 ) ;
if ( ! info100 ) {
return WERR_NOMEM ;
}
2008-12-08 13:39:32 +01:00
info100 - > platform_id = PLATFORM_ID_NT ;
info100 - > server_name = global_myname ( ) ;
2008-03-04 23:07:45 +01:00
r - > out . info - > info100 = info100 ;
2001-03-11 00:32:10 +00:00
break ;
2008-03-04 23:07:45 +01:00
}
2001-02-27 18:22:39 +00:00
default :
2007-10-10 15:34:30 -05:00
status = WERR_UNKNOWN_LEVEL ;
2001-02-27 18:22:39 +00:00
break ;
}
2008-03-04 23:07:45 +01:00
DEBUG ( 5 , ( " _srvsvc_NetSrvGetInfo: %d \n " , __LINE__ ) ) ;
2001-02-27 18:22:39 +00:00
2008-03-04 23:07:45 +01:00
return status ;
2001-02-27 18:22:39 +00:00
}
2001-06-25 06:13:27 +00:00
/*******************************************************************
2008-03-04 23:40:25 +01:00
_srvsvc_NetSrvSetInfo
2001-06-25 06:13:27 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-04 23:40:25 +01:00
WERROR _srvsvc_NetSrvSetInfo ( pipes_struct * p ,
struct srvsvc_NetSrvSetInfo * r )
2001-06-25 06:13:27 +00:00
{
2007-10-10 15:34:30 -05:00
WERROR status = WERR_OK ;
2008-03-04 23:40:25 +01:00
DEBUG ( 5 , ( " _srvsvc_NetSrvSetInfo: %d \n " , __LINE__ ) ) ;
2007-10-10 15:34:30 -05:00
2001-06-25 06:13:27 +00:00
/* Set up the net server set info structure. */
2007-10-10 15:34:30 -05:00
2008-03-04 23:40:25 +01:00
DEBUG ( 5 , ( " _srvsvc_NetSrvSetInfo: %d \n " , __LINE__ ) ) ;
2007-10-10 15:34:30 -05:00
2008-03-04 23:40:25 +01:00
return status ;
2001-06-25 06:13:27 +00:00
}
2001-02-27 18:22:39 +00:00
/*******************************************************************
2008-03-21 01:58:43 +01:00
_srvsvc_NetConnEnum
2001-02-27 18:22:39 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-21 01:58:43 +01:00
WERROR _srvsvc_NetConnEnum ( pipes_struct * p ,
struct srvsvc_NetConnEnum * r )
2001-02-27 18:22:39 +00:00
{
2008-03-21 01:58:43 +01:00
WERROR werr ;
2007-10-10 15:34:30 -05:00
2008-03-21 01:58:43 +01:00
DEBUG ( 5 , ( " _srvsvc_NetConnEnum: %d \n " , __LINE__ ) ) ;
2001-02-27 18:22:39 +00:00
2010-01-07 11:47:09 +01:00
if ( ! nt_token_check_sid ( & global_sid_Builtin_Administrators ,
p - > server_info - > ptok ) ) {
DEBUG ( 1 , ( " Enumerating connections only allowed for "
" administrators \n " ) ) ;
return WERR_ACCESS_DENIED ;
}
2008-03-21 01:58:43 +01:00
switch ( r - > in . info_ctr - > level ) {
case 0 :
werr = init_srv_conn_info_0 ( r - > in . info_ctr - > ctr . ctr0 ,
r - > in . resume_handle ,
r - > out . totalentries ) ;
break ;
case 1 :
werr = init_srv_conn_info_1 ( r - > in . info_ctr - > ctr . ctr1 ,
r - > in . resume_handle ,
r - > out . totalentries ) ;
break ;
default :
return WERR_UNKNOWN_LEVEL ;
}
2007-10-10 15:34:30 -05:00
2008-03-21 01:58:43 +01:00
DEBUG ( 5 , ( " _srvsvc_NetConnEnum: %d \n " , __LINE__ ) ) ;
2007-10-10 15:34:30 -05:00
2008-03-21 01:58:43 +01:00
return werr ;
2001-02-27 18:22:39 +00:00
}
/*******************************************************************
2008-03-21 03:51:37 +01:00
_srvsvc_NetSessEnum
2001-02-27 18:22:39 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-21 03:51:37 +01:00
WERROR _srvsvc_NetSessEnum ( pipes_struct * p ,
struct srvsvc_NetSessEnum * r )
2001-02-27 18:22:39 +00:00
{
2008-03-21 03:51:37 +01:00
WERROR werr ;
2007-10-10 15:34:30 -05:00
2008-03-21 03:51:37 +01:00
DEBUG ( 5 , ( " _srvsvc_NetSessEnum: %d \n " , __LINE__ ) ) ;
2001-02-27 18:22:39 +00:00
2010-01-07 11:47:09 +01:00
if ( ! nt_token_check_sid ( & global_sid_Builtin_Administrators ,
p - > server_info - > ptok ) ) {
DEBUG ( 1 , ( " Enumerating sessions only allowed for "
" administrators \n " ) ) ;
return WERR_ACCESS_DENIED ;
}
2008-03-21 03:51:37 +01:00
switch ( r - > in . info_ctr - > level ) {
case 0 :
werr = init_srv_sess_info_0 ( p ,
r - > in . info_ctr - > ctr . ctr0 ,
r - > in . resume_handle ,
r - > out . totalentries ) ;
break ;
case 1 :
werr = init_srv_sess_info_1 ( p ,
r - > in . info_ctr - > ctr . ctr1 ,
r - > in . resume_handle ,
r - > out . totalentries ) ;
break ;
default :
return WERR_UNKNOWN_LEVEL ;
}
2007-10-10 15:34:30 -05:00
2008-03-21 03:51:37 +01:00
DEBUG ( 5 , ( " _srvsvc_NetSessEnum: %d \n " , __LINE__ ) ) ;
2007-10-10 15:34:30 -05:00
2008-03-21 03:51:37 +01:00
return werr ;
2005-03-23 20:57:03 +00:00
}
/*******************************************************************
2008-03-09 18:01:52 +01:00
_srvsvc_NetSessDel
2005-03-23 20:57:03 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-09 18:01:52 +01:00
WERROR _srvsvc_NetSessDel ( pipes_struct * p ,
struct srvsvc_NetSessDel * r )
2005-03-23 20:57:03 +00:00
{
struct sessionid * session_list ;
2005-07-19 03:54:01 +00:00
int num_sessions , snum ;
2008-03-09 18:01:52 +01:00
const char * username ;
const char * machine ;
2007-10-18 17:40:25 -07:00
bool not_root = False ;
2008-03-09 18:01:52 +01:00
WERROR werr ;
2005-03-23 20:57:03 +00:00
2008-03-09 18:01:52 +01:00
username = r - > in . user ;
machine = r - > in . client ;
2005-03-23 20:57:03 +00:00
/* strip leading backslashes if any */
2008-03-09 18:01:52 +01:00
if ( machine & & machine [ 0 ] = = ' \\ ' & & machine [ 1 ] = = ' \\ ' ) {
machine + = 2 ;
2005-03-23 20:57:03 +00:00
}
2007-04-28 18:16:33 +00:00
num_sessions = list_sessions ( p - > mem_ctx , & session_list ) ;
2005-03-23 20:57:03 +00:00
2008-03-09 18:01:52 +01:00
DEBUG ( 5 , ( " _srvsvc_NetSessDel: %d \n " , __LINE__ ) ) ;
2005-03-23 20:57:03 +00:00
2008-03-09 18:01:52 +01:00
werr = WERR_ACCESS_DENIED ;
2007-10-10 15:34:30 -05:00
2005-03-24 14:40:35 +00:00
/* fail out now if you are not root or not a domain admin */
2008-11-23 23:48:17 +01:00
if ( ( p - > server_info - > utok . uid ! = sec_initial_uid ( ) ) & &
( ! nt_token_check_domain_rid ( p - > server_info - > ptok ,
2010-05-17 22:04:24 +02:00
DOMAIN_RID_ADMINS ) ) ) {
2005-03-24 00:01:56 +00:00
goto done ;
}
2005-03-23 20:57:03 +00:00
for ( snum = 0 ; snum < num_sessions ; snum + + ) {
2007-10-10 15:34:30 -05:00
if ( ( strequal ( session_list [ snum ] . username , username ) | | username [ 0 ] = = ' \0 ' ) & &
strequal ( session_list [ snum ] . remote_machine , machine ) ) {
2007-05-15 10:50:44 +00:00
NTSTATUS ntstat ;
2008-03-04 21:46:09 +01:00
2008-11-23 23:48:17 +01:00
if ( p - > server_info - > utok . uid ! = sec_initial_uid ( ) ) {
2007-10-10 15:34:30 -05:00
not_root = True ;
become_root ( ) ;
}
2007-05-15 10:50:44 +00:00
ntstat = messaging_send ( smbd_messaging_context ( ) ,
session_list [ snum ] . pid ,
MSG_SHUTDOWN , & data_blob_null ) ;
2008-03-04 21:46:09 +01:00
2007-05-15 10:50:44 +00:00
if ( NT_STATUS_IS_OK ( ntstat ) )
2008-03-09 18:01:52 +01:00
werr = WERR_OK ;
2007-10-10 15:34:30 -05:00
2008-03-04 21:46:09 +01:00
if ( not_root )
2007-10-10 15:34:30 -05:00
unbecome_root ( ) ;
2005-03-23 20:57:03 +00:00
}
}
2008-03-09 18:01:52 +01:00
DEBUG ( 5 , ( " _srvsvc_NetSessDel: %d \n " , __LINE__ ) ) ;
2007-10-10 15:34:30 -05:00
2005-03-24 00:01:56 +00:00
done :
2007-10-10 15:34:30 -05:00
2008-03-09 18:01:52 +01:00
return werr ;
2001-02-27 18:22:39 +00:00
}
2001-04-06 01:39:12 +00:00
/*******************************************************************
2008-03-07 16:19:43 +01:00
_srvsvc_NetShareEnumAll
2001-04-06 01:39:12 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 16:19:43 +01:00
WERROR _srvsvc_NetShareEnumAll ( pipes_struct * p ,
struct srvsvc_NetShareEnumAll * r )
2001-04-06 01:39:12 +00:00
{
2008-03-07 16:19:43 +01:00
WERROR werr ;
DEBUG ( 5 , ( " _srvsvc_NetShareEnumAll: %d \n " , __LINE__ ) ) ;
2001-04-06 01:39:12 +00:00
2002-07-15 10:35:28 +00:00
if ( ! pipe_access_check ( p ) ) {
2008-03-07 16:19:43 +01:00
DEBUG ( 3 , ( " access denied to _srvsvc_NetShareEnumAll \n " ) ) ;
2002-07-15 10:35:28 +00:00
return WERR_ACCESS_DENIED ;
}
2001-04-06 01:39:12 +00:00
/* Create the list of shares for the response. */
2008-03-07 16:19:43 +01:00
werr = init_srv_share_info_ctr ( p ,
r - > in . info_ctr ,
r - > in . resume_handle ,
r - > out . totalentries ,
true ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
DEBUG ( 5 , ( " _srvsvc_NetShareEnumAll: %d \n " , __LINE__ ) ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
return werr ;
2001-04-06 01:39:12 +00:00
}
2001-02-27 18:22:39 +00:00
/*******************************************************************
2008-03-07 16:19:43 +01:00
_srvsvc_NetShareEnum
2001-02-27 18:22:39 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 16:19:43 +01:00
WERROR _srvsvc_NetShareEnum ( pipes_struct * p ,
struct srvsvc_NetShareEnum * r )
2001-02-27 18:22:39 +00:00
{
2008-03-07 16:19:43 +01:00
WERROR werr ;
DEBUG ( 5 , ( " _srvsvc_NetShareEnum: %d \n " , __LINE__ ) ) ;
2001-02-27 18:22:39 +00:00
2002-07-15 10:35:28 +00:00
if ( ! pipe_access_check ( p ) ) {
2008-03-07 16:19:43 +01:00
DEBUG ( 3 , ( " access denied to _srvsvc_NetShareEnum \n " ) ) ;
2002-07-15 10:35:28 +00:00
return WERR_ACCESS_DENIED ;
}
2001-02-27 18:22:39 +00:00
/* Create the list of shares for the response. */
2008-03-07 16:19:43 +01:00
werr = init_srv_share_info_ctr ( p ,
r - > in . info_ctr ,
r - > in . resume_handle ,
r - > out . totalentries ,
false ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
DEBUG ( 5 , ( " _srvsvc_NetShareEnum: %d \n " , __LINE__ ) ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 16:19:43 +01:00
return werr ;
2001-02-27 18:22:39 +00:00
}
/*******************************************************************
2008-03-07 16:19:43 +01:00
_srvsvc_NetShareGetInfo
2001-02-27 18:22:39 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 16:19:43 +01:00
WERROR _srvsvc_NetShareGetInfo ( pipes_struct * p ,
struct srvsvc_NetShareGetInfo * r )
2001-02-27 18:22:39 +00:00
{
2008-03-07 16:19:43 +01:00
WERROR status = WERR_OK ;
2007-10-10 15:34:30 -05:00
fstring share_name ;
2008-03-07 16:19:43 +01:00
int snum ;
union srvsvc_NetShareInfo * info = r - > out . info ;
2001-02-27 18:22:39 +00:00
2008-03-07 16:19:43 +01:00
DEBUG ( 5 , ( " _srvsvc_NetShareGetInfo: %d \n " , __LINE__ ) ) ;
2001-02-27 18:22:39 +00:00
2008-03-07 16:19:43 +01:00
fstrcpy ( share_name , r - > in . share_name ) ;
2006-09-21 23:57:32 +00:00
2008-03-07 16:19:43 +01:00
snum = find_service ( share_name ) ;
if ( snum < 0 ) {
return WERR_INVALID_NAME ;
}
2001-02-27 18:22:39 +00:00
2008-03-07 16:19:43 +01:00
switch ( r - > in . level ) {
case 0 :
info - > info0 = TALLOC_P ( p - > mem_ctx , struct srvsvc_NetShareInfo0 ) ;
W_ERROR_HAVE_NO_MEMORY ( info - > info0 ) ;
init_srv_share_info_0 ( p , info - > info0 , snum ) ;
break ;
case 1 :
info - > info1 = TALLOC_P ( p - > mem_ctx , struct srvsvc_NetShareInfo1 ) ;
W_ERROR_HAVE_NO_MEMORY ( info - > info1 ) ;
init_srv_share_info_1 ( p , info - > info1 , snum ) ;
break ;
case 2 :
info - > info2 = TALLOC_P ( p - > mem_ctx , struct srvsvc_NetShareInfo2 ) ;
W_ERROR_HAVE_NO_MEMORY ( info - > info2 ) ;
init_srv_share_info_2 ( p , info - > info2 , snum ) ;
break ;
case 501 :
info - > info501 = TALLOC_P ( p - > mem_ctx , struct srvsvc_NetShareInfo501 ) ;
W_ERROR_HAVE_NO_MEMORY ( info - > info501 ) ;
init_srv_share_info_501 ( p , info - > info501 , snum ) ;
break ;
case 502 :
info - > info502 = TALLOC_P ( p - > mem_ctx , struct srvsvc_NetShareInfo502 ) ;
W_ERROR_HAVE_NO_MEMORY ( info - > info502 ) ;
init_srv_share_info_502 ( p , info - > info502 , snum ) ;
break ;
case 1004 :
info - > info1004 = TALLOC_P ( p - > mem_ctx , struct srvsvc_NetShareInfo1004 ) ;
W_ERROR_HAVE_NO_MEMORY ( info - > info1004 ) ;
init_srv_share_info_1004 ( p , info - > info1004 , snum ) ;
break ;
case 1005 :
info - > info1005 = TALLOC_P ( p - > mem_ctx , struct srvsvc_NetShareInfo1005 ) ;
W_ERROR_HAVE_NO_MEMORY ( info - > info1005 ) ;
init_srv_share_info_1005 ( p , info - > info1005 , snum ) ;
break ;
case 1006 :
info - > info1006 = TALLOC_P ( p - > mem_ctx , struct srvsvc_NetShareInfo1006 ) ;
W_ERROR_HAVE_NO_MEMORY ( info - > info1006 ) ;
init_srv_share_info_1006 ( p , info - > info1006 , snum ) ;
break ;
case 1007 :
info - > info1007 = TALLOC_P ( p - > mem_ctx , struct srvsvc_NetShareInfo1007 ) ;
W_ERROR_HAVE_NO_MEMORY ( info - > info1007 ) ;
init_srv_share_info_1007 ( p , info - > info1007 , snum ) ;
break ;
case 1501 :
init_srv_share_info_1501 ( p , info - > info1501 , snum ) ;
break ;
default :
DEBUG ( 5 , ( " _srvsvc_NetShareGetInfo: unsupported switch value %d \n " ,
r - > in . level ) ) ;
status = WERR_UNKNOWN_LEVEL ;
break ;
}
DEBUG ( 5 , ( " _srvsvc_NetShareGetInfo: %d \n " , __LINE__ ) ) ;
return status ;
2001-02-27 18:22:39 +00:00
}
2001-04-07 18:46:47 +00:00
/*******************************************************************
Check a given DOS pathname is valid for a share .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-11-15 14:19:52 -08:00
char * valid_share_pathname ( TALLOC_CTX * ctx , const char * dos_pathname )
2007-10-10 15:34:30 -05:00
{
2007-11-27 14:35:30 -08:00
char * ptr = NULL ;
if ( ! dos_pathname ) {
return NULL ;
}
2006-12-03 16:19:29 +00:00
2007-11-27 14:35:30 -08:00
ptr = talloc_strdup ( ctx , dos_pathname ) ;
2007-11-15 14:19:52 -08:00
if ( ! ptr ) {
return NULL ;
}
2007-10-10 15:34:30 -05:00
/* Convert any '\' paths to '/' */
2007-11-15 14:19:52 -08:00
unix_format ( ptr ) ;
2007-11-27 11:22:58 -08:00
ptr = unix_clean_name ( ctx , ptr ) ;
2007-11-15 14:19:52 -08:00
if ( ! ptr ) {
return NULL ;
}
2006-12-03 16:19:29 +00:00
2007-10-10 15:34:30 -05:00
/* NT is braindead - it wants a C: prefix to a pathname ! So strip it. */
2007-11-15 14:19:52 -08:00
if ( strlen ( ptr ) > 2 & & ptr [ 1 ] = = ' : ' & & ptr [ 0 ] ! = ' / ' )
2007-10-10 15:34:30 -05:00
ptr + = 2 ;
2006-12-03 16:19:29 +00:00
2007-10-10 15:34:30 -05:00
/* Only absolute paths allowed. */
if ( * ptr ! = ' / ' )
return NULL ;
2006-12-03 16:19:29 +00:00
2007-10-10 15:34:30 -05:00
return ptr ;
2006-12-03 16:19:29 +00:00
}
2001-04-08 20:01:51 +00:00
/*******************************************************************
2008-03-05 01:26:39 +01:00
_srvsvc_NetShareSetInfo . Modify share details .
2001-04-08 20:01:51 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-05 01:26:39 +01:00
WERROR _srvsvc_NetShareSetInfo ( pipes_struct * p ,
struct srvsvc_NetShareSetInfo * r )
2001-04-08 20:01:51 +00:00
{
2007-11-27 14:35:30 -08:00
char * command = NULL ;
char * share_name = NULL ;
char * comment = NULL ;
2008-03-05 01:26:39 +01:00
const char * pathname = NULL ;
2001-04-08 20:01:51 +00:00
int type ;
int snum ;
2007-10-10 15:34:30 -05:00
int ret ;
2007-11-27 14:35:30 -08:00
char * path = NULL ;
2010-05-18 10:29:34 +02:00
struct security_descriptor * psd = NULL ;
2005-01-18 19:51:36 +00:00
SE_PRIV se_diskop = SE_DISK_OPERATOR ;
2007-10-18 17:40:25 -07:00
bool is_disk_op = False ;
2006-01-23 14:34:26 +00:00
int max_connections = 0 ;
2007-11-27 14:35:30 -08:00
TALLOC_CTX * ctx = p - > mem_ctx ;
2008-03-05 01:26:39 +01:00
union srvsvc_NetShareInfo * info = r - > in . info ;
2001-04-08 20:01:51 +00:00
2008-03-05 01:26:39 +01:00
DEBUG ( 5 , ( " _srvsvc_NetShareSetInfo: %d \n " , __LINE__ ) ) ;
2001-04-08 20:01:51 +00:00
2008-03-05 01:26:39 +01:00
share_name = talloc_strdup ( p - > mem_ctx , r - > in . share_name ) ;
2007-11-27 14:35:30 -08:00
if ( ! share_name ) {
2008-03-05 01:26:39 +01:00
return WERR_NOMEM ;
2007-11-27 14:35:30 -08:00
}
2001-04-08 20:01:51 +00:00
2008-03-31 22:49:03 +02:00
if ( r - > out . parm_error ) {
* r - > out . parm_error = 0 ;
}
2007-10-10 15:34:30 -05:00
2007-11-27 14:35:30 -08:00
if ( strequal ( share_name , " IPC$ " )
2007-10-10 15:34:30 -05:00
| | ( lp_enable_asu_support ( ) & & strequal ( share_name , " ADMIN$ " ) )
| | strequal ( share_name , " global " ) )
2005-05-23 16:25:31 +00:00
{
2009-08-20 11:08:21 -07:00
DEBUG ( 5 , ( " _srvsvc_NetShareSetInfo: share %s cannot be "
" modified by a remote user. \n " ,
share_name ) ) ;
2002-03-05 02:12:00 +00:00
return WERR_ACCESS_DENIED ;
2005-05-23 16:25:31 +00:00
}
2001-04-09 08:00:19 +00:00
2007-10-10 15:34:30 -05:00
snum = find_service ( share_name ) ;
2001-04-08 20:01:51 +00:00
/* Does this share exist ? */
if ( snum < 0 )
2005-06-15 12:43:36 +00:00
return WERR_NET_NAME_NOT_FOUND ;
2001-04-09 18:03:02 +00:00
/* No change to printer shares. */
if ( lp_print_ok ( snum ) )
2002-03-05 02:12:00 +00:00
return WERR_ACCESS_DENIED ;
2001-04-08 20:01:51 +00:00
2008-11-23 23:48:17 +01:00
is_disk_op = user_has_privileges ( p - > server_info - > ptok , & se_diskop ) ;
2007-11-27 14:35:30 -08:00
2005-01-18 19:51:36 +00:00
/* fail out now if you are not root and not a disk op */
2007-11-27 14:35:30 -08:00
2009-08-20 11:08:21 -07:00
if ( p - > server_info - > utok . uid ! = sec_initial_uid ( ) & & ! is_disk_op ) {
DEBUG ( 2 , ( " _srvsvc_NetShareSetInfo: uid %u doesn't have the "
" SeDiskOperatorPrivilege privilege needed to modify "
" share %s \n " ,
( unsigned int ) p - > server_info - > utok . uid ,
share_name ) ) ;
2002-03-05 02:12:00 +00:00
return WERR_ACCESS_DENIED ;
2009-08-20 11:08:21 -07:00
}
2001-04-08 20:01:51 +00:00
2008-03-05 01:26:39 +01:00
switch ( r - > in . level ) {
2001-04-08 20:01:51 +00:00
case 1 :
2007-11-27 14:35:30 -08:00
pathname = talloc_strdup ( ctx , lp_pathname ( snum ) ) ;
2008-03-31 22:49:03 +02:00
comment = talloc_strdup ( ctx , info - > info1 - > comment ) ;
type = info - > info1 - > type ;
2002-08-17 15:34:15 +00:00
psd = NULL ;
break ;
2001-04-08 20:01:51 +00:00
case 2 :
2008-03-05 01:26:39 +01:00
comment = talloc_strdup ( ctx , info - > info2 - > comment ) ;
pathname = info - > info2 - > path ;
type = info - > info2 - > type ;
2008-03-31 23:51:34 +02:00
max_connections = ( info - > info2 - > max_users = = ( uint32_t ) - 1 ) ?
2008-03-05 01:26:39 +01:00
0 : info - > info2 - > max_users ;
2002-08-17 15:34:15 +00:00
psd = NULL ;
break ;
2007-10-10 15:34:30 -05:00
#if 0
/* not supported on set but here for completeness */
case 501 :
2008-03-05 01:26:39 +01:00
comment = talloc_strdup ( ctx , info - > info501 - > comment ) ;
type = info - > info501 - > type ;
2007-10-10 15:34:30 -05:00
psd = NULL ;
break ;
# endif
2001-04-08 20:01:51 +00:00
case 502 :
2008-03-05 01:26:39 +01:00
comment = talloc_strdup ( ctx , info - > info502 - > comment ) ;
pathname = info - > info502 - > path ;
type = info - > info502 - > type ;
2008-04-01 00:02:48 +02:00
psd = info - > info502 - > sd_buf . sd ;
2001-04-09 08:00:19 +00:00
map_generic_share_sd_bits ( psd ) ;
2001-04-08 20:01:51 +00:00
break ;
2002-08-17 15:34:15 +00:00
case 1004 :
2007-11-27 14:35:30 -08:00
pathname = talloc_strdup ( ctx , lp_pathname ( snum ) ) ;
2008-03-05 01:26:39 +01:00
comment = talloc_strdup ( ctx , info - > info1004 - > comment ) ;
2002-08-17 15:34:15 +00:00
type = STYPE_DISKTREE ;
break ;
2001-04-08 20:01:51 +00:00
case 1005 :
2003-07-01 21:47:13 +00:00
/* XP re-sets the csc policy even if it wasn't changed by the
user , so we must compare it to see if it ' s what is set in
smb . conf , so that we can contine other ops like setting
ACLs on a share */
2008-03-05 01:26:39 +01:00
if ( ( ( info - > info1005 - > dfs_flags &
2003-07-01 21:47:13 +00:00
SHARE_1005_CSC_POLICY_MASK ) > >
SHARE_1005_CSC_POLICY_SHIFT ) = = lp_csc_policy ( snum ) )
return WERR_OK ;
else {
2008-03-05 01:26:39 +01:00
DEBUG ( 3 , ( " _srvsvc_NetShareSetInfo: client is trying to change csc policy from the network; must be done with smb.conf \n " ) ) ;
2003-07-01 21:47:13 +00:00
return WERR_ACCESS_DENIED ;
}
2002-08-17 15:34:15 +00:00
case 1006 :
case 1007 :
2002-03-05 02:12:00 +00:00
return WERR_ACCESS_DENIED ;
2001-04-09 08:00:19 +00:00
case 1501 :
2007-11-27 14:35:30 -08:00
pathname = talloc_strdup ( ctx , lp_pathname ( snum ) ) ;
comment = talloc_strdup ( ctx , lp_comment ( snum ) ) ;
2008-03-05 01:26:39 +01:00
psd = info - > info1501 - > sd ;
2001-04-09 08:00:19 +00:00
map_generic_share_sd_bits ( psd ) ;
type = STYPE_DISKTREE ;
break ;
2001-04-08 20:01:51 +00:00
default :
2008-03-05 01:26:39 +01:00
DEBUG ( 5 , ( " _srvsvc_NetShareSetInfo: unsupported switch value %d \n " ,
r - > in . level ) ) ;
2002-03-05 02:12:00 +00:00
return WERR_UNKNOWN_LEVEL ;
2001-04-09 06:36:38 +00:00
}
/* We can only modify disk shares. */
2009-08-20 11:08:21 -07:00
if ( type ! = STYPE_DISKTREE ) {
DEBUG ( 5 , ( " _srvsvc_NetShareSetInfo: share %s is not a "
" disk share \n " ,
share_name ) ) ;
2002-03-05 02:12:00 +00:00
return WERR_ACCESS_DENIED ;
2009-08-20 11:08:21 -07:00
}
2007-11-27 14:35:30 -08:00
2008-03-21 10:28:33 +01:00
if ( comment = = NULL ) {
return WERR_NOMEM ;
}
2001-04-09 06:36:38 +00:00
/* Check if the pathname is valid. */
2009-08-20 11:08:21 -07:00
if ( ! ( path = valid_share_pathname ( p - > mem_ctx , pathname ) ) ) {
DEBUG ( 5 , ( " _srvsvc_NetShareSetInfo: invalid pathname %s \n " ,
pathname ) ) ;
2002-03-05 02:12:00 +00:00
return WERR_OBJECT_PATH_INVALID ;
2009-08-20 11:08:21 -07:00
}
2001-04-09 06:36:38 +00:00
2007-10-10 15:34:30 -05:00
/* Ensure share name, pathname and comment don't contain '"' characters. */
string_replace ( share_name , ' " ' , ' ' ) ;
2005-01-19 18:28:55 +00:00
string_replace ( path , ' " ' , ' ' ) ;
2008-03-21 10:28:33 +01:00
string_replace ( comment , ' " ' , ' ' ) ;
2001-04-09 06:36:38 +00:00
2008-03-05 01:26:39 +01:00
DEBUG ( 10 , ( " _srvsvc_NetShareSetInfo: change share command = %s \n " ,
2007-10-10 15:34:30 -05:00
lp_change_share_cmd ( ) ? lp_change_share_cmd ( ) : " NULL " ) ) ;
2001-04-09 17:10:06 +00:00
2001-04-09 06:36:38 +00:00
/* Only call modify function if something changed. */
2007-11-27 14:35:30 -08:00
if ( strcmp ( path , lp_pathname ( snum ) ) | | strcmp ( comment , lp_comment ( snum ) )
| | ( lp_max_connections ( snum ) ! = max_connections ) ) {
2007-10-10 15:34:30 -05:00
if ( ! lp_change_share_cmd ( ) | | ! * lp_change_share_cmd ( ) ) {
2008-03-05 01:26:39 +01:00
DEBUG ( 10 , ( " _srvsvc_NetShareSetInfo: No change share command \n " ) ) ;
2007-10-10 15:34:30 -05:00
return WERR_ACCESS_DENIED ;
}
2001-04-09 06:36:38 +00:00
2007-11-27 14:35:30 -08:00
command = talloc_asprintf ( p - > mem_ctx ,
" %s \" %s \" \" %s \" \" %s \" \" %s \" %d " ,
lp_change_share_cmd ( ) ,
2007-12-10 11:30:37 -08:00
get_dyn_CONFIGFILE ( ) ,
2007-11-27 14:35:30 -08:00
share_name ,
path ,
comment ? comment : " " ,
max_connections ) ;
if ( ! command ) {
return WERR_NOMEM ;
}
2001-04-09 06:36:38 +00:00
2008-03-05 01:26:39 +01:00
DEBUG ( 10 , ( " _srvsvc_NetShareSetInfo: Running [%s] \n " , command ) ) ;
2007-11-27 14:35:30 -08:00
2007-10-10 15:34:30 -05:00
/********* BEGIN SeDiskOperatorPrivilege BLOCK *********/
2007-11-27 14:35:30 -08:00
if ( is_disk_op )
2007-10-10 15:34:30 -05:00
become_root ( ) ;
2007-11-27 14:35:30 -08:00
2007-10-10 15:34:30 -05:00
if ( ( ret = smbrun ( command , NULL ) ) = = 0 ) {
/* Tell everyone we updated smb.conf. */
message_send_all ( smbd_messaging_context ( ) ,
MSG_SMB_CONF_UPDATED , NULL , 0 ,
NULL ) ;
2005-01-19 21:10:56 +00:00
}
2007-11-27 14:35:30 -08:00
2007-10-10 15:34:30 -05:00
if ( is_disk_op )
unbecome_root ( ) ;
2007-11-27 14:35:30 -08:00
2007-10-10 15:34:30 -05:00
/********* END SeDiskOperatorPrivilege BLOCK *********/
2008-03-05 01:26:39 +01:00
DEBUG ( 3 , ( " _srvsvc_NetShareSetInfo: Running [%s] returned (%d) \n " ,
command , ret ) ) ;
2007-11-27 14:35:30 -08:00
TALLOC_FREE ( command ) ;
2007-10-10 15:34:30 -05:00
if ( ret ! = 0 )
return WERR_ACCESS_DENIED ;
} else {
2008-03-05 01:26:39 +01:00
DEBUG ( 10 , ( " _srvsvc_NetShareSetInfo: No change to share name (%s) \n " ,
share_name ) ) ;
2001-04-09 06:36:38 +00:00
}
/* Replace SD if changed. */
if ( psd ) {
2010-05-18 10:29:34 +02:00
struct security_descriptor * old_sd ;
2001-04-09 06:36:38 +00:00
size_t sd_size ;
2007-10-10 15:34:30 -05:00
old_sd = get_share_security ( p - > mem_ctx , lp_servicename ( snum ) , & sd_size ) ;
2001-04-09 06:36:38 +00:00
2009-04-21 18:15:59 +02:00
if ( old_sd & & ! security_descriptor_equal ( old_sd , psd ) ) {
2007-10-10 15:34:30 -05:00
if ( ! set_share_security ( share_name , psd ) )
2008-03-05 01:26:39 +01:00
DEBUG ( 0 , ( " _srvsvc_NetShareSetInfo: Failed to change security info in share %s. \n " ,
2007-10-10 15:34:30 -05:00
share_name ) ) ;
2001-04-09 06:36:38 +00:00
}
2001-04-08 20:01:51 +00:00
}
2007-11-27 14:35:30 -08:00
2008-03-05 01:26:39 +01:00
DEBUG ( 5 , ( " _srvsvc_NetShareSetInfo: %d \n " , __LINE__ ) ) ;
2001-04-08 20:01:51 +00:00
2002-03-05 02:12:00 +00:00
return WERR_OK ;
2001-04-08 20:01:51 +00:00
}
2001-04-06 17:41:47 +00:00
/*******************************************************************
2008-03-08 00:22:44 +01:00
_srvsvc_NetShareAdd .
Call ' add_share_command " sharename " " pathname "
2006-01-23 14:47:55 +00:00
" comment " " max connections = "
2001-04-06 17:41:47 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-08 00:22:44 +01:00
WERROR _srvsvc_NetShareAdd ( pipes_struct * p ,
struct srvsvc_NetShareAdd * r )
2001-04-06 17:41:47 +00:00
{
2007-11-27 14:35:30 -08:00
char * command = NULL ;
char * share_name = NULL ;
char * comment = NULL ;
char * pathname = NULL ;
2001-04-07 00:36:38 +00:00
int type ;
2007-10-10 15:34:30 -05:00
int snum ;
int ret ;
char * path ;
2010-05-18 10:29:34 +02:00
struct security_descriptor * psd = NULL ;
2005-01-18 19:51:36 +00:00
SE_PRIV se_diskop = SE_DISK_OPERATOR ;
2007-10-18 17:40:25 -07:00
bool is_disk_op ;
2007-10-10 15:34:30 -05:00
int max_connections = 0 ;
2007-11-27 14:35:30 -08:00
TALLOC_CTX * ctx = p - > mem_ctx ;
2001-04-06 17:41:47 +00:00
2008-03-08 00:22:44 +01:00
DEBUG ( 5 , ( " _srvsvc_NetShareAdd: %d \n " , __LINE__ ) ) ;
2001-04-06 17:41:47 +00:00
2008-09-26 01:32:16 +02:00
if ( r - > out . parm_error ) {
* r - > out . parm_error = 0 ;
}
2007-10-10 15:34:30 -05:00
2008-11-23 23:48:17 +01:00
is_disk_op = user_has_privileges ( p - > server_info - > ptok , & se_diskop ) ;
2005-01-18 19:51:36 +00:00
2008-11-23 23:48:17 +01:00
if ( p - > server_info - > utok . uid ! = sec_initial_uid ( ) & & ! is_disk_op )
2002-03-05 02:12:00 +00:00
return WERR_ACCESS_DENIED ;
2001-04-07 00:36:38 +00:00
2007-10-10 15:34:30 -05:00
if ( ! lp_add_share_cmd ( ) | | ! * lp_add_share_cmd ( ) ) {
2008-03-08 00:22:44 +01:00
DEBUG ( 10 , ( " _srvsvc_NetShareAdd: No add share command \n " ) ) ;
2007-10-10 15:34:30 -05:00
return WERR_ACCESS_DENIED ;
}
2007-11-27 14:35:30 -08:00
2008-03-08 00:22:44 +01:00
switch ( r - > in . level ) {
2002-08-17 15:34:15 +00:00
case 0 :
/* No path. Not enough info in a level 0 to do anything. */
return WERR_ACCESS_DENIED ;
2001-04-06 17:41:47 +00:00
case 1 :
2001-04-07 00:36:38 +00:00
/* Not enough info in a level 1 to do anything. */
2002-03-05 02:12:00 +00:00
return WERR_ACCESS_DENIED ;
2001-04-06 17:41:47 +00:00
case 2 :
2008-03-08 00:22:44 +01:00
share_name = talloc_strdup ( ctx , r - > in . info - > info2 - > name ) ;
comment = talloc_strdup ( ctx , r - > in . info - > info2 - > comment ) ;
pathname = talloc_strdup ( ctx , r - > in . info - > info2 - > path ) ;
2008-03-31 23:51:34 +02:00
max_connections = ( r - > in . info - > info2 - > max_users = = ( uint32_t ) - 1 ) ?
2008-03-08 00:22:44 +01:00
0 : r - > in . info - > info2 - > max_users ;
type = r - > in . info - > info2 - > type ;
2001-04-06 17:41:47 +00:00
break ;
2002-08-17 15:34:15 +00:00
case 501 :
/* No path. Not enough info in a level 501 to do anything. */
return WERR_ACCESS_DENIED ;
2001-04-06 17:41:47 +00:00
case 502 :
2008-03-08 00:22:44 +01:00
share_name = talloc_strdup ( ctx , r - > in . info - > info502 - > name ) ;
comment = talloc_strdup ( ctx , r - > in . info - > info502 - > comment ) ;
pathname = talloc_strdup ( ctx , r - > in . info - > info502 - > path ) ;
2008-03-31 23:51:34 +02:00
max_connections = ( r - > in . info - > info502 - > max_users = = ( uint32_t ) - 1 ) ?
2008-03-08 00:22:44 +01:00
0 : r - > in . info - > info502 - > max_users ;
type = r - > in . info - > info502 - > type ;
2008-04-01 00:02:48 +02:00
psd = r - > in . info - > info502 - > sd_buf . sd ;
2001-04-09 08:00:19 +00:00
map_generic_share_sd_bits ( psd ) ;
2001-04-06 17:41:47 +00:00
break ;
2002-08-17 15:34:15 +00:00
2008-03-04 21:46:09 +01:00
/* none of the following contain share names. NetShareAdd does not have a separate parameter for the share name */
2002-08-17 15:34:15 +00:00
case 1004 :
2001-04-06 17:41:47 +00:00
case 1005 :
2002-08-17 15:34:15 +00:00
case 1006 :
case 1007 :
return WERR_ACCESS_DENIED ;
case 1501 :
2001-04-07 00:36:38 +00:00
/* DFS only level. */
2002-03-05 02:12:00 +00:00
return WERR_ACCESS_DENIED ;
2001-04-06 17:41:47 +00:00
default :
2008-03-08 00:22:44 +01:00
DEBUG ( 5 , ( " _srvsvc_NetShareAdd: unsupported switch value %d \n " ,
r - > in . level ) ) ;
2002-03-05 02:12:00 +00:00
return WERR_UNKNOWN_LEVEL ;
2001-04-06 17:41:47 +00:00
}
2005-12-11 05:06:35 +00:00
/* check for invalid share names */
2007-11-27 14:35:30 -08:00
if ( ! share_name | | ! validate_net_name ( share_name ,
INVALID_SHARENAME_CHARS ,
strlen ( share_name ) ) ) {
2008-03-08 00:22:44 +01:00
DEBUG ( 5 , ( " _srvsvc_NetShareAdd: Bad sharename \" %s \" \n " ,
2007-11-27 14:35:30 -08:00
share_name ? share_name : " " ) ) ;
2005-12-11 05:06:35 +00:00
return WERR_INVALID_NAME ;
}
2007-11-27 14:35:30 -08:00
if ( strequal ( share_name , " IPC$ " ) | | strequal ( share_name , " global " )
| | ( lp_enable_asu_support ( ) & &
strequal ( share_name , " ADMIN$ " ) ) ) {
2002-03-05 02:12:00 +00:00
return WERR_ACCESS_DENIED ;
2005-05-23 16:25:31 +00:00
}
2001-04-10 19:43:14 +00:00
2007-10-10 15:34:30 -05:00
snum = find_service ( share_name ) ;
/* Share already exists. */
2007-11-27 14:35:30 -08:00
if ( snum > = 0 ) {
2008-10-23 15:37:39 +02:00
return WERR_FILE_EXISTS ;
2007-11-27 14:35:30 -08:00
}
2001-04-07 00:36:38 +00:00
2001-04-07 18:46:47 +00:00
/* We can only add disk shares. */
2007-11-27 14:35:30 -08:00
if ( type ! = STYPE_DISKTREE ) {
2002-03-05 02:12:00 +00:00
return WERR_ACCESS_DENIED ;
2007-11-27 14:35:30 -08:00
}
2001-04-07 18:46:47 +00:00
/* Check if the pathname is valid. */
2007-11-27 14:35:30 -08:00
if ( ! ( path = valid_share_pathname ( p - > mem_ctx , pathname ) ) ) {
2002-03-05 02:12:00 +00:00
return WERR_OBJECT_PATH_INVALID ;
2007-11-27 14:35:30 -08:00
}
2001-04-07 00:36:38 +00:00
2007-10-10 15:34:30 -05:00
/* Ensure share name, pathname and comment don't contain '"' characters. */
2001-04-08 20:01:51 +00:00
string_replace ( share_name , ' " ' , ' ' ) ;
2005-01-19 18:28:55 +00:00
string_replace ( path , ' " ' , ' ' ) ;
2007-11-27 14:35:30 -08:00
if ( comment ) {
string_replace ( comment , ' " ' , ' ' ) ;
}
command = talloc_asprintf ( ctx ,
" %s \" %s \" \" %s \" \" %s \" \" %s \" %d " ,
lp_add_share_cmd ( ) ,
2007-12-10 11:30:37 -08:00
get_dyn_CONFIGFILE ( ) ,
2007-11-27 14:35:30 -08:00
share_name ,
path ,
comment ? comment : " " ,
2007-10-10 15:34:30 -05:00
max_connections ) ;
2007-11-27 14:35:30 -08:00
if ( ! command ) {
return WERR_NOMEM ;
}
2008-03-08 00:22:44 +01:00
DEBUG ( 10 , ( " _srvsvc_NetShareAdd: Running [%s] \n " , command ) ) ;
2007-11-27 14:35:30 -08:00
2007-10-10 15:34:30 -05:00
/********* BEGIN SeDiskOperatorPrivilege BLOCK *********/
2007-11-27 14:35:30 -08:00
2007-10-10 15:34:30 -05:00
if ( is_disk_op )
become_root ( ) ;
2005-01-18 19:51:36 +00:00
2008-03-08 00:22:44 +01:00
/* FIXME: use libnetconf here - gd */
2007-10-10 15:34:30 -05:00
if ( ( ret = smbrun ( command , NULL ) ) = = 0 ) {
/* Tell everyone we updated smb.conf. */
message_send_all ( smbd_messaging_context ( ) ,
MSG_SMB_CONF_UPDATED , NULL , 0 , NULL ) ;
2005-01-19 21:10:56 +00:00
}
2005-01-18 19:51:36 +00:00
2007-10-10 15:34:30 -05:00
if ( is_disk_op )
unbecome_root ( ) ;
2007-11-27 14:35:30 -08:00
2007-10-10 15:34:30 -05:00
/********* END SeDiskOperatorPrivilege BLOCK *********/
2008-03-08 00:22:44 +01:00
DEBUG ( 3 , ( " _srvsvc_NetShareAdd: Running [%s] returned (%d) \n " ,
command , ret ) ) ;
2007-10-10 15:34:30 -05:00
2007-11-27 14:35:30 -08:00
TALLOC_FREE ( command ) ;
2007-10-10 15:34:30 -05:00
if ( ret ! = 0 )
return WERR_ACCESS_DENIED ;
2001-04-09 06:36:38 +00:00
if ( psd ) {
2006-11-11 18:07:51 +00:00
if ( ! set_share_security ( share_name , psd ) ) {
2008-03-08 00:22:44 +01:00
DEBUG ( 0 , ( " _srvsvc_NetShareAdd: Failed to add security info to share %s. \n " ,
share_name ) ) ;
2005-01-19 18:28:55 +00:00
}
2001-04-09 06:36:38 +00:00
}
2001-04-07 18:46:47 +00:00
/*
2001-04-10 01:44:45 +00:00
* We don ' t call reload_services ( ) here , the message will
2001-04-07 18:46:47 +00:00
* cause this to be done before the next packet is read
* from the client . JRA .
*/
2001-04-06 17:41:47 +00:00
2008-03-08 00:22:44 +01:00
DEBUG ( 5 , ( " _srvsvc_NetShareAdd: %d \n " , __LINE__ ) ) ;
2001-04-06 17:41:47 +00:00
2002-03-05 02:12:00 +00:00
return WERR_OK ;
2001-04-06 17:41:47 +00:00
}
2001-04-06 18:25:17 +00:00
/*******************************************************************
2008-03-07 23:26:00 +01:00
_srvsvc_NetShareDel
Call " delete share command " with the share name as
2001-04-07 00:36:38 +00:00
a parameter .
2001-04-06 18:25:17 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 23:26:00 +01:00
WERROR _srvsvc_NetShareDel ( pipes_struct * p ,
struct srvsvc_NetShareDel * r )
2001-04-06 18:25:17 +00:00
{
2007-11-27 14:35:30 -08:00
char * command = NULL ;
char * share_name = NULL ;
2007-10-10 15:34:30 -05:00
int ret ;
int snum ;
2005-01-18 19:51:36 +00:00
SE_PRIV se_diskop = SE_DISK_OPERATOR ;
2007-10-18 17:40:25 -07:00
bool is_disk_op ;
2007-11-27 14:35:30 -08:00
struct share_params * params ;
TALLOC_CTX * ctx = p - > mem_ctx ;
2001-04-06 18:25:17 +00:00
2008-03-07 23:26:00 +01:00
DEBUG ( 5 , ( " _srvsvc_NetShareDel: %d \n " , __LINE__ ) ) ;
2007-10-10 15:34:30 -05:00
2008-03-07 23:26:00 +01:00
share_name = talloc_strdup ( p - > mem_ctx , r - > in . share_name ) ;
2007-11-27 14:35:30 -08:00
if ( ! share_name ) {
return WERR_NET_NAME_NOT_FOUND ;
}
if ( strequal ( share_name , " IPC$ " )
2007-10-10 15:34:30 -05:00
| | ( lp_enable_asu_support ( ) & & strequal ( share_name , " ADMIN$ " ) )
| | strequal ( share_name , " global " ) )
2005-05-23 16:25:31 +00:00
{
2002-03-05 02:12:00 +00:00
return WERR_ACCESS_DENIED ;
2005-05-23 16:25:31 +00:00
}
2001-04-09 18:03:02 +00:00
2007-11-27 14:35:30 -08:00
if ( ! ( params = get_share_params ( p - > mem_ctx , share_name ) ) ) {
return WERR_NO_SUCH_SHARE ;
}
2007-10-10 15:34:30 -05:00
snum = find_service ( share_name ) ;
2001-04-09 18:03:02 +00:00
/* No change to printer shares. */
2007-10-10 15:34:30 -05:00
if ( lp_print_ok ( snum ) )
2002-03-05 02:12:00 +00:00
return WERR_ACCESS_DENIED ;
2001-04-06 18:25:17 +00:00
2008-11-23 23:48:17 +01:00
is_disk_op = user_has_privileges ( p - > server_info - > ptok , & se_diskop ) ;
2007-10-10 15:34:30 -05:00
2008-11-23 23:48:17 +01:00
if ( p - > server_info - > utok . uid ! = sec_initial_uid ( ) & & ! is_disk_op )
2007-10-10 15:34:30 -05:00
return WERR_ACCESS_DENIED ;
2005-01-18 19:51:36 +00:00
2007-10-10 15:34:30 -05:00
if ( ! lp_delete_share_cmd ( ) | | ! * lp_delete_share_cmd ( ) ) {
2008-03-07 23:26:00 +01:00
DEBUG ( 10 , ( " _srvsvc_NetShareDel: No delete share command \n " ) ) ;
2002-03-05 02:12:00 +00:00
return WERR_ACCESS_DENIED ;
2007-10-10 15:34:30 -05:00
}
2007-11-27 14:35:30 -08:00
command = talloc_asprintf ( ctx ,
" %s \" %s \" \" %s \" " ,
lp_delete_share_cmd ( ) ,
2007-12-10 11:30:37 -08:00
get_dyn_CONFIGFILE ( ) ,
2007-11-27 14:35:30 -08:00
lp_servicename ( snum ) ) ;
if ( ! command ) {
return WERR_NOMEM ;
}
2007-10-10 15:34:30 -05:00
2008-03-07 23:26:00 +01:00
DEBUG ( 10 , ( " _srvsvc_NetShareDel: Running [%s] \n " , command ) ) ;
2001-04-07 00:36:38 +00:00
2007-10-10 15:34:30 -05:00
/********* BEGIN SeDiskOperatorPrivilege BLOCK *********/
2007-11-27 14:35:30 -08:00
2007-10-10 15:34:30 -05:00
if ( is_disk_op )
become_root ( ) ;
2006-10-21 17:00:47 +00:00
2007-10-10 15:34:30 -05:00
if ( ( ret = smbrun ( command , NULL ) ) = = 0 ) {
/* Tell everyone we updated smb.conf. */
message_send_all ( smbd_messaging_context ( ) ,
MSG_SMB_CONF_UPDATED , NULL , 0 , NULL ) ;
2006-10-21 17:00:47 +00:00
}
2001-04-07 00:36:38 +00:00
2007-10-10 15:34:30 -05:00
if ( is_disk_op )
unbecome_root ( ) ;
2007-11-27 14:35:30 -08:00
2007-10-10 15:34:30 -05:00
/********* END SeDiskOperatorPrivilege BLOCK *********/
2008-03-07 23:26:00 +01:00
DEBUG ( 3 , ( " _srvsvc_NetShareDel: Running [%s] returned (%d) \n " , command , ret ) ) ;
2007-10-10 15:34:30 -05:00
if ( ret ! = 0 )
return WERR_ACCESS_DENIED ;
2005-01-18 19:51:36 +00:00
/* Delete the SD in the database. */
2007-10-07 17:58:48 +00:00
delete_share_security ( lp_servicename ( params - > service ) ) ;
2005-01-18 19:51:36 +00:00
2006-10-21 17:00:47 +00:00
lp_killservice ( params - > service ) ;
2001-04-07 00:36:38 +00:00
2002-03-05 02:12:00 +00:00
return WERR_OK ;
2001-04-06 18:25:17 +00:00
}
2008-03-07 23:26:00 +01:00
/*******************************************************************
_srvsvc_NetShareDelSticky
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
WERROR _srvsvc_NetShareDelSticky ( pipes_struct * p ,
struct srvsvc_NetShareDelSticky * r )
2002-08-17 15:34:15 +00:00
{
2008-03-07 23:26:00 +01:00
struct srvsvc_NetShareDel q ;
2002-08-17 15:34:15 +00:00
2008-03-07 23:26:00 +01:00
DEBUG ( 5 , ( " _srvsvc_NetShareDelSticky: %d \n " , __LINE__ ) ) ;
q . in . server_unc = r - > in . server_unc ;
q . in . share_name = r - > in . share_name ;
q . in . reserved = r - > in . reserved ;
return _srvsvc_NetShareDel ( p , & q ) ;
2002-08-17 15:34:15 +00:00
}
2001-02-27 18:22:39 +00:00
/*******************************************************************
2008-03-05 10:34:45 +01:00
_srvsvc_NetRemoteTOD
2001-02-27 18:22:39 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-05 10:34:45 +01:00
WERROR _srvsvc_NetRemoteTOD ( pipes_struct * p ,
struct srvsvc_NetRemoteTOD * r )
2001-02-27 18:22:39 +00:00
{
2008-03-05 10:34:45 +01:00
struct srvsvc_NetRemoteTODInfo * tod ;
2001-02-27 18:22:39 +00:00
struct tm * t ;
time_t unixdate = time ( NULL ) ;
2006-01-23 14:34:26 +00:00
2005-11-27 21:51:46 +00:00
/* We do this call first as if we do it *after* the gmtime call
it overwrites the pointed - to values . JRA */
2006-01-23 14:34:26 +00:00
2005-11-27 21:51:46 +00:00
uint32 zone = get_time_zone ( unixdate ) / 60 ;
2001-02-27 18:22:39 +00:00
2008-03-05 10:34:45 +01:00
DEBUG ( 5 , ( " _srvsvc_NetRemoteTOD: %d \n " , __LINE__ ) ) ;
2006-01-23 14:34:26 +00:00
2008-03-05 10:34:45 +01:00
if ( ! ( tod = TALLOC_ZERO_P ( p - > mem_ctx , struct srvsvc_NetRemoteTODInfo ) ) )
2007-10-10 15:34:30 -05:00
return WERR_NOMEM ;
2008-03-05 10:34:45 +01:00
* r - > out . info = tod ;
2007-10-10 15:34:30 -05:00
2008-03-05 10:34:45 +01:00
DEBUG ( 5 , ( " _srvsvc_NetRemoteTOD: %d \n " , __LINE__ ) ) ;
2007-10-10 15:34:30 -05:00
2001-02-27 18:22:39 +00:00
t = gmtime ( & unixdate ) ;
/* set up the */
2008-12-08 13:39:32 +01:00
tod - > elapsed = unixdate ;
tod - > msecs = 0 ;
tod - > hours = t - > tm_hour ;
tod - > mins = t - > tm_min ;
tod - > secs = t - > tm_sec ;
tod - > hunds = 0 ;
tod - > timezone = zone ;
tod - > tinterval = 10000 ;
tod - > day = t - > tm_mday ;
tod - > month = t - > tm_mon + 1 ;
tod - > year = 1900 + t - > tm_year ;
tod - > weekday = t - > tm_wday ;
2001-02-27 18:22:39 +00:00
2008-03-05 10:34:45 +01:00
DEBUG ( 5 , ( " _srvsvc_NetRemoteTOD: %d \n " , __LINE__ ) ) ;
return WERR_OK ;
2001-02-27 18:22:39 +00:00
}
2001-05-01 01:01:19 +00:00
2001-06-16 00:32:13 +00:00
/***********************************************************************************
2008-03-08 00:57:52 +01:00
_srvsvc_NetGetFileSecurity
2001-06-16 00:32:13 +00:00
Win9x NT tools get security descriptor .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-08 00:57:52 +01:00
WERROR _srvsvc_NetGetFileSecurity ( pipes_struct * p ,
struct srvsvc_NetGetFileSecurity * r )
2001-06-16 00:32:13 +00:00
{
2009-06-04 18:39:55 -07:00
struct smb_filename * smb_fname = NULL ;
2010-05-18 10:29:34 +02:00
struct security_descriptor * psd = NULL ;
2001-06-16 00:32:13 +00:00
size_t sd_size ;
2008-07-27 17:59:15 +02:00
fstring servicename ;
2001-06-16 00:32:13 +00:00
SMB_STRUCT_STAT st ;
2001-09-15 12:55:59 +00:00
NTSTATUS nt_status ;
2008-07-27 17:59:15 +02:00
WERROR werr ;
2001-06-16 00:32:13 +00:00
connection_struct * conn = NULL ;
2008-05-09 11:14:45 -07:00
struct sec_desc_buf * sd_buf = NULL ;
files_struct * fsp = NULL ;
2008-07-27 17:59:15 +02:00
int snum ;
char * oldcwd = NULL ;
2001-06-16 00:32:13 +00:00
ZERO_STRUCT ( st ) ;
2008-07-27 17:59:15 +02:00
fstrcpy ( servicename , r - > in . share ) ;
2007-11-27 14:35:30 -08:00
2008-07-27 17:59:15 +02:00
snum = find_service ( servicename ) ;
if ( snum = = - 1 ) {
DEBUG ( 10 , ( " Could not find service %s \n " , servicename ) ) ;
werr = WERR_NET_NAME_NOT_FOUND ;
2004-06-11 17:54:23 +00:00
goto error_exit ;
}
2008-07-27 17:59:15 +02:00
nt_status = create_conn_struct ( talloc_tos ( ) , & conn , snum ,
2008-11-23 22:21:26 +01:00
lp_pathname ( snum ) , p - > server_info ,
& oldcwd ) ;
2007-01-17 02:09:37 +00:00
if ( ! NT_STATUS_IS_OK ( nt_status ) ) {
2008-07-27 17:59:15 +02:00
DEBUG ( 10 , ( " create_conn_struct failed: %s \n " ,
nt_errstr ( nt_status ) ) ) ;
werr = ntstatus_to_werror ( nt_status ) ;
2004-06-11 17:54:23 +00:00
goto error_exit ;
}
2009-06-18 15:07:14 -07:00
nt_status = filename_convert ( talloc_tos ( ) ,
2009-06-16 17:23:54 -07:00
conn ,
false ,
r - > in . file ,
2009-07-24 12:13:07 -07:00
0 ,
NULL ,
2009-07-21 10:28:28 -07:00
& smb_fname ) ;
2009-06-16 17:23:54 -07:00
if ( ! NT_STATUS_IS_OK ( nt_status ) ) {
werr = ntstatus_to_werror ( nt_status ) ;
goto error_exit ;
}
2008-10-20 17:43:45 -07:00
nt_status = SMB_VFS_CREATE_FILE (
2008-07-27 17:59:15 +02:00
conn , /* conn */
NULL , /* req */
0 , /* root_dir_fid */
2009-06-12 12:54:11 -07:00
smb_fname , /* fname */
2008-07-27 17:59:15 +02:00
FILE_READ_ATTRIBUTES , /* access_mask */
FILE_SHARE_READ | FILE_SHARE_WRITE , /* share_access */
FILE_OPEN , /* create_disposition*/
0 , /* create_options */
0 , /* file_attributes */
INTERNAL_OPEN_ONLY , /* oplock_request */
0 , /* allocation_size */
2010-03-05 15:10:30 -08:00
0 , /* private_flags */
2008-07-27 17:59:15 +02:00
NULL , /* sd */
NULL , /* ea_list */
& fsp , /* result */
2009-06-12 12:54:11 -07:00
NULL ) ; /* pinfo */
2008-05-09 11:14:45 -07:00
if ( ! NT_STATUS_IS_OK ( nt_status ) ) {
DEBUG ( 3 , ( " _srvsvc_NetGetFileSecurity: can't open %s \n " ,
2009-06-12 12:54:11 -07:00
smb_fname_str_dbg ( smb_fname ) ) ) ;
2008-05-09 11:14:45 -07:00
werr = ntstatus_to_werror ( nt_status ) ;
goto error_exit ;
}
nt_status = SMB_VFS_FGET_NT_ACL ( fsp ,
2007-10-13 21:06:49 +02:00
( OWNER_SECURITY_INFORMATION
| GROUP_SECURITY_INFORMATION
| DACL_SECURITY_INFORMATION ) , & psd ) ;
2001-06-16 00:32:13 +00:00
2007-10-13 21:06:49 +02:00
if ( ! NT_STATUS_IS_OK ( nt_status ) ) {
2008-07-27 17:59:15 +02:00
DEBUG ( 3 , ( " _srvsvc_NetGetFileSecurity: Unable to get NT ACL "
2009-06-12 12:54:11 -07:00
" for file %s \n " , smb_fname_str_dbg ( smb_fname ) ) ) ;
2008-03-08 00:57:52 +01:00
werr = ntstatus_to_werror ( nt_status ) ;
2001-06-16 00:32:13 +00:00
goto error_exit ;
}
2010-05-10 00:42:06 +02:00
sd_size = ndr_size_security_descriptor ( psd , 0 ) ;
2007-10-13 21:06:49 +02:00
2008-07-27 17:59:15 +02:00
sd_buf = TALLOC_ZERO_P ( p - > mem_ctx , struct sec_desc_buf ) ;
2008-03-08 00:57:52 +01:00
if ( ! sd_buf ) {
werr = WERR_NOMEM ;
goto error_exit ;
}
sd_buf - > sd_size = sd_size ;
sd_buf - > sd = psd ;
* r - > out . sd_buf = sd_buf ;
2001-06-16 00:32:13 +00:00
2007-12-20 22:17:16 +01:00
psd - > dacl - > revision = NT4_ACL_REVISION ;
2001-06-16 00:32:13 +00:00
2008-10-09 16:27:49 +02:00
close_file ( NULL , fsp , NORMAL_CLOSE ) ;
2008-07-27 17:59:15 +02:00
vfs_ChDir ( conn , oldcwd ) ;
2009-08-07 11:48:03 +02:00
conn_free ( conn ) ;
2009-06-04 18:39:55 -07:00
werr = WERR_OK ;
goto done ;
2001-06-16 00:32:13 +00:00
2002-08-17 15:34:15 +00:00
error_exit :
2001-06-16 00:32:13 +00:00
2008-07-27 17:59:15 +02:00
if ( fsp ) {
2008-10-09 16:27:49 +02:00
close_file ( NULL , fsp , NORMAL_CLOSE ) ;
2008-05-09 11:14:45 -07:00
}
2008-07-27 17:59:15 +02:00
if ( oldcwd ) {
vfs_ChDir ( conn , oldcwd ) ;
2008-05-09 11:14:45 -07:00
}
2001-09-19 02:28:15 +00:00
2008-05-09 11:14:45 -07:00
if ( conn ) {
2009-08-07 11:48:03 +02:00
conn_free ( conn ) ;
2008-05-09 11:14:45 -07:00
}
2001-06-16 00:32:13 +00:00
2009-06-04 18:39:55 -07:00
done :
TALLOC_FREE ( smb_fname ) ;
2008-03-08 00:57:52 +01:00
return werr ;
2001-06-16 00:32:13 +00:00
}
/***********************************************************************************
2008-03-08 00:42:40 +01:00
_srvsvc_NetSetFileSecurity
2001-06-16 00:32:13 +00:00
Win9x NT tools set security descriptor .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-08 00:42:40 +01:00
WERROR _srvsvc_NetSetFileSecurity ( pipes_struct * p ,
struct srvsvc_NetSetFileSecurity * r )
2001-06-16 00:32:13 +00:00
{
2009-06-04 18:39:55 -07:00
struct smb_filename * smb_fname = NULL ;
2008-07-27 17:59:15 +02:00
fstring servicename ;
2001-06-16 00:32:13 +00:00
files_struct * fsp = NULL ;
SMB_STRUCT_STAT st ;
2001-09-15 12:55:59 +00:00
NTSTATUS nt_status ;
2008-03-08 00:42:40 +01:00
WERROR werr ;
2001-06-16 00:32:13 +00:00
connection_struct * conn = NULL ;
2008-07-27 17:59:15 +02:00
int snum ;
char * oldcwd = NULL ;
2008-10-08 18:06:58 -07:00
struct security_descriptor * psd = NULL ;
uint32_t security_info_sent = 0 ;
2001-06-16 00:32:13 +00:00
ZERO_STRUCT ( st ) ;
2008-07-27 17:59:15 +02:00
fstrcpy ( servicename , r - > in . share ) ;
2007-10-10 15:34:30 -05:00
2008-07-27 17:59:15 +02:00
snum = find_service ( servicename ) ;
if ( snum = = - 1 ) {
DEBUG ( 10 , ( " Could not find service %s \n " , servicename ) ) ;
werr = WERR_NET_NAME_NOT_FOUND ;
2007-11-27 14:35:30 -08:00
goto error_exit ;
}
2007-10-10 15:34:30 -05:00
2008-07-27 17:59:15 +02:00
nt_status = create_conn_struct ( talloc_tos ( ) , & conn , snum ,
2008-11-23 22:21:26 +01:00
lp_pathname ( snum ) , p - > server_info ,
& oldcwd ) ;
2008-07-27 17:59:15 +02:00
if ( ! NT_STATUS_IS_OK ( nt_status ) ) {
DEBUG ( 10 , ( " create_conn_struct failed: %s \n " ,
nt_errstr ( nt_status ) ) ) ;
2008-03-08 00:42:40 +01:00
werr = ntstatus_to_werror ( nt_status ) ;
2001-06-16 00:32:13 +00:00
goto error_exit ;
}
2009-06-18 15:07:14 -07:00
nt_status = filename_convert ( talloc_tos ( ) ,
2009-06-16 17:23:54 -07:00
conn ,
false ,
r - > in . file ,
2009-07-24 12:13:07 -07:00
0 ,
NULL ,
2009-07-21 10:28:28 -07:00
& smb_fname ) ;
2009-06-16 17:23:54 -07:00
if ( ! NT_STATUS_IS_OK ( nt_status ) ) {
werr = ntstatus_to_werror ( nt_status ) ;
goto error_exit ;
}
2009-06-04 18:39:55 -07:00
2008-10-20 17:43:45 -07:00
nt_status = SMB_VFS_CREATE_FILE (
2008-07-27 17:59:15 +02:00
conn , /* conn */
NULL , /* req */
0 , /* root_dir_fid */
2009-06-12 12:54:11 -07:00
smb_fname , /* fname */
2008-07-27 17:59:15 +02:00
FILE_WRITE_ATTRIBUTES , /* access_mask */
FILE_SHARE_READ | FILE_SHARE_WRITE , /* share_access */
FILE_OPEN , /* create_disposition*/
0 , /* create_options */
0 , /* file_attributes */
INTERNAL_OPEN_ONLY , /* oplock_request */
0 , /* allocation_size */
2010-03-05 15:10:30 -08:00
0 , /* private_flags */
2008-07-27 17:59:15 +02:00
NULL , /* sd */
NULL , /* ea_list */
& fsp , /* result */
2009-06-12 12:54:11 -07:00
NULL ) ; /* pinfo */
2001-08-13 23:19:16 +00:00
2007-01-17 02:09:37 +00:00
if ( ! NT_STATUS_IS_OK ( nt_status ) ) {
2008-07-27 17:59:15 +02:00
DEBUG ( 3 , ( " _srvsvc_NetSetFileSecurity: can't open %s \n " ,
2009-06-12 12:54:11 -07:00
smb_fname_str_dbg ( smb_fname ) ) ) ;
2008-07-27 17:59:15 +02:00
werr = ntstatus_to_werror ( nt_status ) ;
2004-06-11 17:54:23 +00:00
goto error_exit ;
}
2008-10-08 18:06:58 -07:00
psd = r - > in . sd_buf - > sd ;
security_info_sent = r - > in . securityinformation ;
if ( psd - > owner_sid = = 0 ) {
security_info_sent & = ~ OWNER_SECURITY_INFORMATION ;
}
if ( psd - > group_sid = = 0 ) {
security_info_sent & = ~ GROUP_SECURITY_INFORMATION ;
}
if ( psd - > sacl = = 0 ) {
security_info_sent & = ~ SACL_SECURITY_INFORMATION ;
}
if ( psd - > dacl = = 0 ) {
security_info_sent & = ~ DACL_SECURITY_INFORMATION ;
}
/* Convert all the generic bits. */
security_acl_map_generic ( psd - > dacl , & file_generic_mapping ) ;
security_acl_map_generic ( psd - > sacl , & file_generic_mapping ) ;
2008-05-08 18:09:07 -07:00
nt_status = SMB_VFS_FSET_NT_ACL ( fsp ,
2008-10-08 18:06:58 -07:00
security_info_sent ,
psd ) ;
2001-06-16 00:32:13 +00:00
2007-10-10 15:34:30 -05:00
if ( ! NT_STATUS_IS_OK ( nt_status ) ) {
2008-07-27 17:59:15 +02:00
DEBUG ( 3 , ( " _srvsvc_NetSetFileSecurity: Unable to set NT ACL "
" on file %s \n " , r - > in . share ) ) ;
2008-03-08 00:42:40 +01:00
werr = WERR_ACCESS_DENIED ;
2001-06-16 00:32:13 +00:00
goto error_exit ;
}
2008-10-09 16:27:49 +02:00
close_file ( NULL , fsp , NORMAL_CLOSE ) ;
2008-07-27 17:59:15 +02:00
vfs_ChDir ( conn , oldcwd ) ;
2009-08-07 11:48:03 +02:00
conn_free ( conn ) ;
2009-06-04 18:39:55 -07:00
werr = WERR_OK ;
goto done ;
2001-06-16 00:32:13 +00:00
2002-08-17 15:34:15 +00:00
error_exit :
2001-06-16 00:32:13 +00:00
2008-07-27 17:59:15 +02:00
if ( fsp ) {
2008-10-09 16:27:49 +02:00
close_file ( NULL , fsp , NORMAL_CLOSE ) ;
2001-06-16 00:32:13 +00:00
}
2008-07-27 17:59:15 +02:00
if ( oldcwd ) {
vfs_ChDir ( conn , oldcwd ) ;
2005-07-08 04:51:27 +00:00
}
2001-08-13 23:19:16 +00:00
2005-07-08 04:51:27 +00:00
if ( conn ) {
2009-08-07 11:48:03 +02:00
conn_free ( conn ) ;
2005-07-08 04:51:27 +00:00
}
2001-06-16 00:32:13 +00:00
2009-06-04 18:39:55 -07:00
done :
TALLOC_FREE ( smb_fname ) ;
2008-03-08 00:42:40 +01:00
return werr ;
2001-06-16 00:32:13 +00:00
}
2001-05-01 01:01:19 +00:00
/***********************************************************************************
It may be that we want to limit users to creating shares on certain areas of the UNIX file area .
We could define areas by mapping Windows style disks to points on the UNIX directory hierarchy .
These disks would the disks listed by this function .
Users could then create shares relative to these disks . Watch out for moving these disks around .
" Nigel Williams " < nigel @ veritas . com > .
2001-05-02 08:14:00 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2001-05-01 01:01:19 +00:00
2002-07-15 10:35:28 +00:00
static const char * server_disks [ ] = { " C: " } ;
2001-05-01 01:01:19 +00:00
static uint32 get_server_disk_count ( void )
{
return sizeof ( server_disks ) / sizeof ( server_disks [ 0 ] ) ;
}
static uint32 init_server_disk_enum ( uint32 * resume )
{
uint32 server_disk_count = get_server_disk_count ( ) ;
/*resume can be an offset into the list for now*/
2001-06-19 00:44:23 +00:00
if ( * resume & 0x80000000 )
2001-05-01 01:01:19 +00:00
* resume = 0 ;
if ( * resume > server_disk_count )
* resume = server_disk_count ;
return server_disk_count - * resume ;
}
static const char * next_server_disk_enum ( uint32 * resume )
{
const char * disk ;
if ( init_server_disk_enum ( resume ) = = 0 )
return NULL ;
disk = server_disks [ * resume ] ;
( * resume ) + + ;
DEBUG ( 10 , ( " next_server_disk_enum: reporting disk %s. resume handle %d. \n " , disk , * resume ) ) ;
return disk ;
}
2008-03-11 10:48:52 +01:00
/********************************************************************
_srvsvc_NetDiskEnum
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
WERROR _srvsvc_NetDiskEnum ( pipes_struct * p ,
struct srvsvc_NetDiskEnum * r )
2001-05-01 01:01:19 +00:00
{
uint32 i ;
const char * disk_name ;
2007-10-10 15:34:30 -05:00
TALLOC_CTX * ctx = p - > mem_ctx ;
2008-03-11 10:48:52 +01:00
WERROR werr ;
uint32_t resume = r - > in . resume_handle ? * r - > in . resume_handle : 0 ;
2001-05-01 01:01:19 +00:00
2008-03-11 10:48:52 +01:00
werr = WERR_OK ;
2007-10-10 15:34:30 -05:00
2008-03-11 10:48:52 +01:00
* r - > out . totalentries = init_server_disk_enum ( & resume ) ;
2002-08-17 15:34:15 +00:00
2008-03-11 10:48:52 +01:00
r - > out . info - > disks = TALLOC_ZERO_ARRAY ( ctx , struct srvsvc_NetDiskInfo0 ,
MAX_SERVER_DISK_ENTRIES ) ;
W_ERROR_HAVE_NO_MEMORY ( r - > out . info - > disks ) ;
2007-10-10 15:34:30 -05:00
2008-03-11 10:48:52 +01:00
/*allow one struct srvsvc_NetDiskInfo0 for null terminator*/
2001-05-01 01:01:19 +00:00
2009-02-09 12:32:16 +01:00
r - > out . info - > count = 0 ;
2007-10-10 15:34:30 -05:00
for ( i = 0 ; i < MAX_SERVER_DISK_ENTRIES - 1 & & ( disk_name = next_server_disk_enum ( & resume ) ) ; i + + ) {
2001-05-01 01:01:19 +00:00
2008-03-11 10:48:52 +01:00
r - > out . info - > count + + ;
2001-05-01 01:01:19 +00:00
/*copy disk name into a unicode string*/
2008-03-11 10:48:52 +01:00
r - > out . info - > disks [ i ] . disk = talloc_strdup ( ctx , disk_name ) ;
W_ERROR_HAVE_NO_MEMORY ( r - > out . info - > disks [ i ] . disk ) ;
2001-05-01 01:01:19 +00:00
}
2002-08-17 15:34:15 +00:00
/* add a terminating null string. Is this there if there is more data to come? */
2001-05-01 01:01:19 +00:00
2008-03-11 10:48:52 +01:00
r - > out . info - > count + + ;
2001-05-01 01:01:19 +00:00
2008-03-11 10:48:52 +01:00
r - > out . info - > disks [ i ] . disk = talloc_strdup ( ctx , " " ) ;
W_ERROR_HAVE_NO_MEMORY ( r - > out . info - > disks [ i ] . disk ) ;
2001-05-01 01:01:19 +00:00
2008-03-11 10:48:52 +01:00
if ( r - > out . resume_handle ) {
* r - > out . resume_handle = resume ;
}
2007-10-10 15:34:30 -05:00
2008-03-11 10:48:52 +01:00
return werr ;
2001-05-01 01:01:19 +00:00
}
2005-12-11 05:06:35 +00:00
/********************************************************************
2008-03-07 23:40:00 +01:00
_srvsvc_NetNameValidate
2005-12-11 05:06:35 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-07 23:40:00 +01:00
WERROR _srvsvc_NetNameValidate ( pipes_struct * p ,
struct srvsvc_NetNameValidate * r )
2001-05-01 01:01:19 +00:00
{
2008-03-07 23:40:00 +01:00
switch ( r - > in . name_type ) {
2001-05-01 01:01:19 +00:00
case 0x9 :
2008-03-07 23:40:00 +01:00
if ( ! validate_net_name ( r - > in . name , INVALID_SHARENAME_CHARS ,
strlen_m ( r - > in . name ) ) )
{
DEBUG ( 5 , ( " _srvsvc_NetNameValidate: Bad sharename \" %s \" \n " ,
r - > in . name ) ) ;
2005-12-11 05:06:35 +00:00
return WERR_INVALID_NAME ;
}
2001-05-01 01:01:19 +00:00
break ;
2005-12-11 05:06:35 +00:00
2001-05-01 01:01:19 +00:00
default :
2005-10-14 14:51:48 +00:00
return WERR_UNKNOWN_LEVEL ;
2001-05-01 01:01:19 +00:00
}
2005-10-14 14:51:48 +00:00
return WERR_OK ;
2001-05-01 01:01:19 +00:00
}
2006-07-11 18:01:26 +00:00
2008-05-27 11:23:59 -07:00
/*******************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static void enum_file_close_fn ( const struct share_mode_entry * e ,
const char * sharepath , const char * fname ,
void * private_data )
{
char msg [ MSG_SMB_SHARE_MODE_ENTRY_SIZE ] ;
struct srvsvc_NetFileClose * r =
( struct srvsvc_NetFileClose * ) private_data ;
uint32_t fid = ( ( ( uint32_t ) ( procid_to_pid ( & e - > pid ) ) < < 16 ) | e - > share_file_id ) ;
if ( fid ! = r - > in . fid ) {
return ; /* Not this file. */
}
if ( ! process_exists ( e - > pid ) ) {
return ;
}
/* Ok - send the close message. */
DEBUG ( 10 , ( " enum_file_close_fn: request to close file %s, %s \n " ,
sharepath ,
share_mode_str ( talloc_tos ( ) , 0 , e ) ) ) ;
share_mode_entry_to_message ( msg , e ) ;
r - > out . result = ntstatus_to_werror (
messaging_send_buf ( smbd_messaging_context ( ) ,
e - > pid , MSG_SMB_CLOSE_FILE ,
( uint8 * ) msg ,
MSG_SMB_SHARE_MODE_ENTRY_SIZE ) ) ;
}
2006-07-11 18:01:26 +00:00
/********************************************************************
2008-05-27 11:23:59 -07:00
Close a file given a 32 - bit file id .
2006-07-11 18:01:26 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetFileClose ( pipes_struct * p , struct srvsvc_NetFileClose * r )
2006-07-11 18:01:26 +00:00
{
2008-05-27 11:23:59 -07:00
SE_PRIV se_diskop = SE_DISK_OPERATOR ;
bool is_disk_op ;
DEBUG ( 5 , ( " _srvsvc_NetFileClose: %d \n " , __LINE__ ) ) ;
2008-11-23 23:48:17 +01:00
is_disk_op = user_has_privileges ( p - > server_info - > ptok , & se_diskop ) ;
2008-05-27 11:23:59 -07:00
2008-11-23 23:48:17 +01:00
if ( p - > server_info - > utok . uid ! = sec_initial_uid ( ) & & ! is_disk_op ) {
2008-05-27 11:23:59 -07:00
return WERR_ACCESS_DENIED ;
}
/* enum_file_close_fn sends the close message to
* the relevent smbd process . */
r - > out . result = WERR_BADFILE ;
share_mode_forall ( enum_file_close_fn , ( void * ) r ) ;
return r - > out . result ;
}
2007-10-10 15:34:30 -05:00
/********************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetCharDevEnum ( pipes_struct * p , struct srvsvc_NetCharDevEnum * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetCharDevGetInfo ( pipes_struct * p , struct srvsvc_NetCharDevGetInfo * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetCharDevControl ( pipes_struct * p , struct srvsvc_NetCharDevControl * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetCharDevQEnum ( pipes_struct * p , struct srvsvc_NetCharDevQEnum * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetCharDevQGetInfo ( pipes_struct * p , struct srvsvc_NetCharDevQGetInfo * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetCharDevQSetInfo ( pipes_struct * p , struct srvsvc_NetCharDevQSetInfo * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetCharDevQPurge ( pipes_struct * p , struct srvsvc_NetCharDevQPurge * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetCharDevQPurgeSelf ( pipes_struct * p , struct srvsvc_NetCharDevQPurgeSelf * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetFileGetInfo ( pipes_struct * p , struct srvsvc_NetFileGetInfo * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetShareCheck ( pipes_struct * p , struct srvsvc_NetShareCheck * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetServerStatisticsGet ( pipes_struct * p , struct srvsvc_NetServerStatisticsGet * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetTransportAdd ( pipes_struct * p , struct srvsvc_NetTransportAdd * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetTransportEnum ( pipes_struct * p , struct srvsvc_NetTransportEnum * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetTransportDel ( pipes_struct * p , struct srvsvc_NetTransportDel * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetSetServiceBits ( pipes_struct * p , struct srvsvc_NetSetServiceBits * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetPathType ( pipes_struct * p , struct srvsvc_NetPathType * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetPathCanonicalize ( pipes_struct * p , struct srvsvc_NetPathCanonicalize * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetPathCompare ( pipes_struct * p , struct srvsvc_NetPathCompare * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NETRPRNAMECANONICALIZE ( pipes_struct * p , struct srvsvc_NETRPRNAMECANONICALIZE * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetPRNameCompare ( pipes_struct * p , struct srvsvc_NetPRNameCompare * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetShareDelStart ( pipes_struct * p , struct srvsvc_NetShareDelStart * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetShareDelCommit ( pipes_struct * p , struct srvsvc_NetShareDelCommit * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetServerTransportAddEx ( pipes_struct * p , struct srvsvc_NetServerTransportAddEx * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NetServerSetServiceBitsEx ( pipes_struct * p , struct srvsvc_NetServerSetServiceBitsEx * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NETRDFSGETVERSION ( pipes_struct * p , struct srvsvc_NETRDFSGETVERSION * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NETRDFSCREATELOCALPARTITION ( pipes_struct * p , struct srvsvc_NETRDFSCREATELOCALPARTITION * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NETRDFSDELETELOCALPARTITION ( pipes_struct * p , struct srvsvc_NETRDFSDELETELOCALPARTITION * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-10-10 15:34:30 -05:00
WERROR _srvsvc_NETRDFSSETLOCALVOLUMESTATE ( pipes_struct * p , struct srvsvc_NETRDFSSETLOCALVOLUMESTATE * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NETRDFSSETSERVERINFO ( pipes_struct * p , struct srvsvc_NETRDFSSETSERVERINFO * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NETRDFSCREATEEXITPOINT ( pipes_struct * p , struct srvsvc_NETRDFSCREATEEXITPOINT * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-01-18 10:18:59 +00:00
WERROR _srvsvc_NETRDFSDELETEEXITPOINT ( pipes_struct * p , struct srvsvc_NETRDFSDELETEEXITPOINT * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-10-10 15:34:30 -05:00
WERROR _srvsvc_NETRDFSMODIFYPREFIX ( pipes_struct * p , struct srvsvc_NETRDFSMODIFYPREFIX * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-10-10 15:34:30 -05:00
WERROR _srvsvc_NETRDFSFIXLOCALVOLUME ( pipes_struct * p , struct srvsvc_NETRDFSFIXLOCALVOLUME * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-10-10 15:34:30 -05:00
WERROR _srvsvc_NETRDFSMANAGERREPORTSITEINFO ( pipes_struct * p , struct srvsvc_NETRDFSMANAGERREPORTSITEINFO * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-10-10 15:34:30 -05:00
WERROR _srvsvc_NETRSERVERTRANSPORTDELEX ( pipes_struct * p , struct srvsvc_NETRSERVERTRANSPORTDELEX * r )
2006-09-21 23:57:32 +00:00
{
2006-10-10 08:39:11 +00:00
p - > rng_fault_state = True ;
2006-09-21 23:57:32 +00:00
return WERR_NOT_SUPPORTED ;
}
2007-10-10 15:34:30 -05:00