2023-02-02 11:48:37 +03:00
/*
2002-01-30 09:08:46 +03:00
Unix SMB / CIFS implementation .
1996-05-04 11:50:46 +04:00
status reporting
1998-01-22 16:27:43 +03:00
Copyright ( C ) Andrew Tridgell 1994 - 1998
2009-09-18 20:10:54 +04:00
1996-05-04 11:50:46 +04: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 23:25:36 +04:00
the Free Software Foundation ; either version 3 of the License , or
1996-05-04 11:50:46 +04:00
( at your option ) any later version .
2009-09-18 20:10:54 +04:00
1996-05-04 11:50:46 +04: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 .
2009-09-18 20:10:54 +04:00
1996-05-04 11:50:46 +04:00
You should have received a copy of the GNU General Public License
2007-07-10 04:52:41 +04:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
1996-08-15 19:11:34 +04:00
Revision History :
12 aug 96 : Erik . Devriendt @ te6 . siemens . be
added support for shared memory implementation of share mode locking
1998-07-24 05:08:31 +04:00
21 - Jul - 1998 : rsharpe @ ns . aus . com ( Richard Sharpe )
Added - L ( locks only ) - S ( shares only ) flags and code
1996-05-04 11:50:46 +04:00
*/
/*
* This program reports current SMB connections
*/
# include "includes.h"
2017-01-01 23:00:55 +03:00
# include "lib/util/server_id.h"
2015-11-09 19:17:17 +03:00
# include "smbd/globals.h"
2011-02-26 01:20:06 +03:00
# include "system/filesys.h"
2021-01-13 15:18:23 +03:00
# include "lib/cmdline/cmdline.h"
2011-07-07 19:42:08 +04:00
# include "dbwrap/dbwrap.h"
2011-07-06 18:40:21 +04:00
# include "dbwrap/dbwrap_open.h"
2010-10-12 08:27:50 +04:00
# include "../libcli/security/security.h"
2011-02-25 01:14:15 +03:00
# include "session.h"
2020-10-28 14:09:39 +03:00
# include "locking/share_mode_lock.h"
2011-03-23 14:43:17 +03:00
# include "locking/proto.h"
2011-03-24 17:31:06 +03:00
# include "messages.h"
2011-11-24 17:11:28 +04:00
# include "librpc/gen_ndr/open_files.h"
2012-06-05 16:50:23 +04:00
# include "smbd/smbd.h"
2012-04-04 16:51:09 +04:00
# include "librpc/gen_ndr/notify.h"
2019-04-11 14:03:30 +03:00
# include "conn_tdb.h"
2013-04-18 19:09:32 +04:00
# include "serverid.h"
2014-10-10 16:18:50 +04:00
# include "status_profile.h"
2022-03-23 17:17:48 +03:00
# include "status.h"
2022-03-24 16:38:46 +03:00
# include "status_json.h"
2020-10-21 18:28:14 +03:00
# include "smbd/notifyd/notifyd_db.h"
2018-08-21 01:46:27 +03:00
# include "cmdline_contexts.h"
2018-09-19 13:52:46 +03:00
# include "locking/leases_db.h"
2020-08-07 21:17:34 +03:00
# include "lib/util/string_wrappers.h"
2023-08-07 07:48:22 +03:00
# include "lib/param/param.h"
1996-05-04 11:50:46 +04:00
2022-03-24 17:46:35 +03:00
# ifdef HAVE_JANSSON
# include <jansson.h>
# include "audit_logging.h" /* various JSON helpers */
# include "auth/common_auth.h"
# endif /* HAVE_JANSSON */
2003-11-13 01:35:50 +03:00
# define SMB_MAXPIDS 2048
2004-12-17 11:51:23 +03:00
static uid_t Ucrit_uid = 0 ; /* added by OH */
2007-05-07 19:31:12 +04:00
static struct server_id Ucrit_pid [ SMB_MAXPIDS ] ; /* Ugly !!! */ /* added by OH */
2003-11-13 01:35:50 +03:00
static int Ucrit_MaxPid = 0 ; /* added by OH */
static unsigned int Ucrit_IsActive = 0 ; /* added by OH */
2007-10-19 22:38:36 +04:00
static bool verbose , brief ;
static bool shares_only ; /* Added by RJS */
static bool locks_only ; /* Added by RJS */
static bool processes_only ;
static bool show_brl ;
static bool numeric_only ;
2012-07-13 19:24:02 +04:00
static bool do_checks = true ;
1998-07-24 05:08:31 +04:00
2004-11-12 02:30:32 +03:00
const char * username = NULL ;
1998-08-10 05:25:32 +04:00
/* added by OH */
2004-12-17 11:51:23 +03:00
static void Ucrit_addUid ( uid_t uid )
1998-08-10 05:25:32 +04:00
{
2004-12-17 11:51:23 +03:00
Ucrit_uid = uid ;
Ucrit_IsActive = 1 ;
1998-08-10 05:25:32 +04:00
}
2004-12-17 11:51:23 +03:00
static unsigned int Ucrit_checkUid ( uid_t uid )
1998-08-10 05:25:32 +04:00
{
2023-02-02 11:48:37 +03:00
if ( ! Ucrit_IsActive )
2003-11-13 01:35:50 +03:00
return 1 ;
2009-09-18 20:10:54 +04:00
2023-02-02 11:48:37 +03:00
if ( uid = = Ucrit_uid )
2003-11-13 01:35:50 +03:00
return 1 ;
2009-09-18 20:10:54 +04:00
1998-08-10 05:25:32 +04:00
return 0 ;
}
2007-05-07 19:31:12 +04:00
static unsigned int Ucrit_checkPid ( struct server_id pid )
1998-08-10 05:25:32 +04:00
{
int i ;
2009-09-18 20:10:54 +04:00
2023-02-02 11:48:37 +03:00
if ( ! Ucrit_IsActive )
2003-11-13 01:35:50 +03:00
return 1 ;
2009-09-18 20:10:54 +04:00
2003-11-13 01:35:50 +03:00
for ( i = 0 ; i < Ucrit_MaxPid ; i + + ) {
2019-10-09 22:38:04 +03:00
if ( server_id_equal ( & pid , & Ucrit_pid [ i ] ) ) {
2003-11-13 01:35:50 +03:00
return 1 ;
2012-06-16 02:07:16 +04:00
}
2003-11-13 01:35:50 +03:00
}
2009-09-18 20:10:54 +04:00
1998-08-10 05:25:32 +04:00
return 0 ;
}
2007-10-19 04:40:25 +04:00
static bool Ucrit_addPid ( struct server_id pid )
2003-11-13 01:35:50 +03:00
{
if ( ! Ucrit_IsActive )
return True ;
if ( Ucrit_MaxPid > = SMB_MAXPIDS ) {
2022-03-23 10:58:54 +03:00
fprintf ( stderr , " ERROR: More than %d pids for user %s! \n " ,
2004-12-17 11:51:23 +03:00
SMB_MAXPIDS , uidtoname ( Ucrit_uid ) ) ;
2003-11-13 01:35:50 +03:00
return False ;
}
Ucrit_pid [ Ucrit_MaxPid + + ] = pid ;
2009-09-18 20:10:54 +04:00
2003-11-13 01:35:50 +03:00
return True ;
}
1998-08-10 05:25:32 +04:00
2022-03-24 13:36:56 +03:00
static int print_share_mode_stdout ( struct traverse_state * state ,
const char * pid ,
const char * user_name ,
const char * denymode ,
int access_mask ,
const char * rw ,
const char * oplock ,
const char * servicepath ,
const char * filename ,
const char * timestr )
{
if ( state - > first ) {
d_printf ( " \n Locked files: \n " ) ;
d_printf ( " Pid User(ID) DenyMode Access R/W Oplock SharePath Name Time \n " ) ;
d_printf ( " -------------------------------------------------------------------------------------------------- \n " ) ;
state - > first = false ;
}
d_printf ( " %-11s %-9s %-10s 0x%-8x %-10s %-14s %s %s %s " ,
pid , user_name , denymode , access_mask , rw , oplock ,
servicepath , filename , timestr ) ;
return 0 ;
}
2022-03-24 18:34:10 +03:00
static int prepare_share_mode ( struct traverse_state * state )
{
2022-03-30 16:11:11 +03:00
if ( ! state - > json_output ) {
/* only print header line if there are open files */
state - > first = true ;
} else {
add_section_to_json ( state , " open_files " ) ;
}
2022-03-24 18:34:10 +03:00
return 0 ;
}
2023-01-03 20:45:14 +03:00
static uint32_t map_share_mode_to_deny_mode (
uint32_t share_access , uint32_t private_options )
{
switch ( share_access & ~ FILE_SHARE_DELETE ) {
case FILE_SHARE_NONE :
return DENY_ALL ;
case FILE_SHARE_READ :
return DENY_WRITE ;
case FILE_SHARE_WRITE :
return DENY_READ ;
case FILE_SHARE_READ | FILE_SHARE_WRITE :
return DENY_NONE ;
}
if ( private_options & NTCREATEX_FLAG_DENY_DOS ) {
return DENY_DOS ;
} else if ( private_options & NTCREATEX_FLAG_DENY_FCB ) {
return DENY_FCB ;
}
return ( uint32_t ) - 1 ;
}
2018-07-25 17:56:35 +03:00
static int print_share_mode ( struct file_id fid ,
const struct share_mode_data * d ,
const struct share_mode_entry * e ,
void * private_data )
1997-10-20 12:46:00 +04:00
{
2022-03-23 11:13:58 +03:00
const char * denymode = NULL ;
uint denymode_int ;
const char * oplock = NULL ;
const char * pid = NULL ;
const char * rw = NULL ;
const char * filename = NULL ;
const char * timestr = NULL ;
const char * user_str = NULL ;
2022-03-30 18:05:02 +03:00
uint32_t lstate ;
2022-03-24 18:27:10 +03:00
struct traverse_state * state = ( struct traverse_state * ) private_data ;
2022-03-23 11:13:58 +03:00
TALLOC_CTX * tmp_ctx = talloc_stackframe ( ) ;
if ( tmp_ctx = = NULL ) {
return - 1 ;
}
2006-02-01 00:54:24 +03:00
2012-07-13 19:24:02 +04:00
if ( do_checks & & ! is_valid_share_mode_entry ( e ) ) {
2022-03-23 11:13:58 +03:00
TALLOC_FREE ( tmp_ctx ) ;
2014-11-05 22:27:06 +03:00
return 0 ;
2006-02-01 00:54:24 +03:00
}
2013-04-18 19:09:32 +04:00
if ( do_checks & & ! serverid_exists ( & e - > pid ) ) {
/* the process for this entry does not exist any more */
2022-03-23 11:13:58 +03:00
TALLOC_FREE ( tmp_ctx ) ;
2014-09-24 22:46:15 +04:00
return 0 ;
2013-04-18 19:09:32 +04:00
}
2007-05-07 19:31:12 +04:00
if ( Ucrit_checkPid ( e - > pid ) ) {
2015-04-23 19:06:17 +03:00
struct server_id_buf tmp ;
2022-03-23 11:13:58 +03:00
pid = server_id_str_buf ( e - > pid , & tmp ) ;
2022-03-24 18:27:10 +03:00
if ( state - > resolve_uids ) {
2022-03-23 11:13:58 +03:00
user_str = talloc_asprintf ( tmp_ctx , " %s " , uidtoname ( e - > uid ) ) ;
2019-02-18 16:11:32 +03:00
} else {
2022-03-23 11:13:58 +03:00
user_str = talloc_asprintf ( tmp_ctx , " %u " , ( unsigned int ) e - > uid ) ;
}
if ( user_str = = NULL ) {
TALLOC_FREE ( tmp_ctx ) ;
return - 1 ;
2019-02-18 16:11:32 +03:00
}
2022-03-23 11:13:58 +03:00
denymode_int = map_share_mode_to_deny_mode ( e - > share_access ,
e - > private_options ) ;
switch ( denymode_int ) {
case DENY_NONE :
denymode = " DENY_NONE " ;
break ;
case DENY_ALL :
denymode = " DENY_ALL " ;
break ;
case DENY_DOS :
denymode = " DENY_DOS " ;
break ;
case DENY_READ :
denymode = " DENY_READ " ;
break ;
case DENY_WRITE :
denymode = " DENY_WRITE " ;
break ;
case DENY_FCB :
denymode = " DENY_FCB " ;
break ;
2005-07-08 08:51:27 +04:00
default : {
2022-03-23 11:13:58 +03:00
denymode = talloc_asprintf ( tmp_ctx ,
" UNKNOWN(0x%08x) " ,
denymode_int ) ;
if ( denymode = = NULL ) {
TALLOC_FREE ( tmp_ctx ) ;
return - 1 ;
}
2022-03-23 10:58:54 +03:00
fprintf ( stderr ,
" unknown-please report ! "
" e->share_access = 0x%x, "
" e->private_options = 0x%x \n " ,
( unsigned int ) e - > share_access ,
( unsigned int ) e - > private_options ) ;
2005-07-08 08:51:27 +04:00
break ;
}
}
2022-03-23 11:13:58 +03:00
filename = talloc_asprintf ( tmp_ctx ,
" %s%s " ,
d - > base_name ,
( d - > stream_name ! = NULL ) ? d - > stream_name : " " ) ;
if ( filename = = NULL ) {
TALLOC_FREE ( tmp_ctx ) ;
return - 1 ;
}
2005-09-14 00:13:33 +04:00
if ( ( e - > access_mask & ( FILE_READ_DATA | FILE_WRITE_DATA ) ) = =
( FILE_READ_DATA | FILE_WRITE_DATA ) ) {
2022-03-23 11:13:58 +03:00
rw = " RDWR " ;
2005-07-08 08:51:27 +04:00
} else if ( e - > access_mask & FILE_WRITE_DATA ) {
2022-03-23 11:13:58 +03:00
rw = " WRONLY " ;
2005-07-08 08:51:27 +04:00
} else {
2022-03-23 11:13:58 +03:00
rw = " RDONLY " ;
2005-07-08 08:51:27 +04:00
}
2022-05-09 13:09:18 +03:00
if ( e - > op_type & BATCH_OPLOCK ) {
2022-03-23 11:13:58 +03:00
oplock = " BATCH " ;
2005-07-08 08:51:27 +04:00
} else if ( e - > op_type & EXCLUSIVE_OPLOCK ) {
2022-03-23 11:13:58 +03:00
oplock = " EXCLUSIVE " ;
2005-07-08 08:51:27 +04:00
} else if ( e - > op_type & LEVEL_II_OPLOCK ) {
2022-03-23 11:13:58 +03:00
oplock = " LEVEL_II " ;
2014-11-27 20:34:56 +03:00
} else if ( e - > op_type = = LEASE_OPLOCK ) {
2018-09-19 13:52:46 +03:00
NTSTATUS status ;
status = leases_db_get (
& e - > client_guid ,
& e - > lease_key ,
& d - > id ,
& lstate , /* current_state */
NULL , /* breaking */
NULL , /* breaking_to_requested */
NULL , /* breaking_to_required */
NULL , /* lease_version */
NULL ) ; /* epoch */
if ( NT_STATUS_IS_OK ( status ) ) {
2022-03-23 11:13:58 +03:00
oplock = talloc_asprintf ( tmp_ctx , " LEASE(%s%s%s)%s%s%s " ,
( lstate & SMB2_LEASE_READ ) ? " R " : " " ,
( lstate & SMB2_LEASE_WRITE ) ? " W " : " " ,
( lstate & SMB2_LEASE_HANDLE ) ? " H " : " " ,
( lstate & SMB2_LEASE_READ ) ? " " : " " ,
( lstate & SMB2_LEASE_WRITE ) ? " " : " " ,
( lstate & SMB2_LEASE_HANDLE ) ? " " : " " ) ;
2018-09-19 13:52:46 +03:00
} else {
2022-03-23 11:13:58 +03:00
oplock = " LEASE STATE UNKNOWN " ;
2018-09-19 13:52:46 +03:00
}
2005-07-08 08:51:27 +04:00
} else {
2022-03-23 11:13:58 +03:00
oplock = " NONE " ;
2005-07-08 08:51:27 +04:00
}
2022-03-23 11:13:58 +03:00
timestr = time_to_asc ( ( time_t ) e - > time . tv_sec ) ;
2022-03-30 16:11:11 +03:00
if ( ! state - > json_output ) {
print_share_mode_stdout ( state ,
pid ,
user_str ,
denymode ,
( unsigned int ) e - > access_mask ,
rw ,
oplock ,
d - > servicepath ,
filename ,
timestr ) ;
} else {
print_share_mode_json ( state ,
d ,
2022-03-30 16:36:13 +03:00
e ,
2022-03-30 16:14:13 +03:00
fid ,
2022-03-30 16:36:13 +03:00
user_str ,
2022-03-30 16:40:56 +03:00
oplock ,
2022-03-30 18:05:02 +03:00
lstate ,
2022-03-30 16:11:11 +03:00
filename ) ;
}
1998-05-30 06:25:11 +04:00
}
2022-03-23 11:13:58 +03:00
TALLOC_FREE ( tmp_ctx ) ;
2014-09-24 22:46:15 +04:00
return 0 ;
1997-10-20 12:46:00 +04:00
}
1997-05-20 04:32:51 +04:00
2022-03-24 13:36:56 +03:00
static void print_brl_stdout ( struct traverse_state * state ,
char * pid ,
char * id ,
const char * desc ,
intmax_t start ,
intmax_t size ,
const char * sharepath ,
char * fname )
{
if ( state - > first ) {
d_printf ( " Byte range locks: \n " ) ;
d_printf ( " Pid dev:inode R/W start size SharePath Name \n " ) ;
d_printf ( " -------------------------------------------------------------------------------- \n " ) ;
state - > first = false ;
}
d_printf ( " %-10s %-15s %-4s %-9jd %-9jd %-24s %-24s \n " ,
pid , id , desc , start , size , sharepath , fname ) ;
}
2022-03-24 18:34:10 +03:00
static int prepare_brl ( struct traverse_state * state )
{
2022-03-31 11:30:30 +03:00
if ( ! state - > json_output ) {
/* only print header line if there are locked files */
state - > first = true ;
} else {
add_section_to_json ( state , " byte_range_locks " ) ;
}
2022-03-24 18:34:10 +03:00
return 0 ;
}
2007-05-29 13:30:34 +04:00
static void print_brl ( struct file_id id ,
2023-02-02 11:48:37 +03:00
struct server_id pid ,
2006-04-10 19:33:04 +04:00
enum brl_type lock_type ,
enum brl_flavour lock_flav ,
br_off start ,
2007-05-29 17:26:44 +04:00
br_off size ,
void * private_data )
2000-01-16 14:14:44 +03:00
{
2012-07-13 19:32:19 +04:00
unsigned int i ;
2007-05-29 13:30:34 +04:00
static const struct {
enum brl_type lock_type ;
const char * desc ;
} lock_types [ ] = {
{ READ_LOCK , " R " } ,
{ WRITE_LOCK , " W " } ,
{ UNLOCK_LOCK , " U " }
} ;
const char * desc = " X " ;
2007-08-01 15:18:56 +04:00
const char * sharepath = " " ;
2009-07-09 03:22:44 +04:00
char * fname = NULL ;
2007-08-01 15:18:56 +04:00
struct share_mode_lock * share_mode ;
2015-04-23 19:06:17 +03:00
struct server_id_buf tmp ;
2019-09-09 17:28:57 +03:00
struct file_id_buf ftmp ;
2022-03-24 18:34:10 +03:00
struct traverse_state * state = ( struct traverse_state * ) private_data ;
2007-08-01 15:18:56 +04:00
2009-07-09 03:22:44 +04:00
share_mode = fetch_share_mode_unlocked ( NULL , id ) ;
2007-08-01 15:18:56 +04:00
if ( share_mode ) {
2020-11-04 15:20:09 +03:00
fname = share_mode_filename ( NULL , share_mode ) ;
2022-04-25 13:15:57 +03:00
sharepath = share_mode_servicepath ( share_mode ) ;
2009-07-09 03:22:44 +04:00
} else {
fname = talloc_strdup ( NULL , " " ) ;
if ( fname = = NULL ) {
return ;
}
2007-08-01 15:18:56 +04:00
}
2007-05-29 13:30:34 +04:00
for ( i = 0 ; i < ARRAY_SIZE ( lock_types ) ; i + + ) {
if ( lock_type = = lock_types [ i ] . lock_type ) {
desc = lock_types [ i ] . desc ;
}
}
2022-03-31 11:30:30 +03:00
if ( ! state - > json_output ) {
print_brl_stdout ( state ,
server_id_str_buf ( pid , & tmp ) ,
file_id_str_buf ( id , & ftmp ) ,
desc ,
( intmax_t ) start ,
( intmax_t ) size ,
sharepath ,
fname ) ;
} else {
print_brl_json ( state ,
2022-05-02 11:57:28 +03:00
pid ,
2022-08-01 12:15:44 +03:00
id ,
2022-03-31 11:31:31 +03:00
desc ,
lock_flav ,
( intmax_t ) start ,
( intmax_t ) size ,
2022-03-31 11:30:30 +03:00
sharepath ,
fname ) ;
}
2007-08-01 15:18:56 +04:00
2009-07-09 03:22:44 +04:00
TALLOC_FREE ( fname ) ;
2007-08-02 13:22:47 +04:00
TALLOC_FREE ( share_mode ) ;
2000-01-16 14:14:44 +03:00
}
2015-11-30 12:48:12 +03:00
static const char * session_dialect_str ( uint16_t dialect )
{
2022-04-01 10:07:47 +03:00
static fstring unknown_dialect ;
2015-11-30 12:48:12 +03:00
switch ( dialect ) {
case SMB2_DIALECT_REVISION_000 :
return " NT1 " ;
case SMB2_DIALECT_REVISION_202 :
return " SMB2_02 " ;
case SMB2_DIALECT_REVISION_210 :
return " SMB2_10 " ;
case SMB2_DIALECT_REVISION_222 :
return " SMB2_22 " ;
case SMB2_DIALECT_REVISION_224 :
return " SMB2_24 " ;
case SMB3_DIALECT_REVISION_300 :
return " SMB3_00 " ;
case SMB3_DIALECT_REVISION_302 :
return " SMB3_02 " ;
case SMB3_DIALECT_REVISION_310 :
return " SMB3_10 " ;
case SMB3_DIALECT_REVISION_311 :
return " SMB3_11 " ;
}
2022-04-01 10:07:47 +03:00
fstr_sprintf ( unknown_dialect , " Unknown (0x%04x) " , dialect ) ;
return unknown_dialect ;
2015-11-30 12:48:12 +03:00
}
2022-03-24 13:36:56 +03:00
static int traverse_connections_stdout ( struct traverse_state * state ,
const char * servicename ,
char * server_id ,
const char * machine ,
const char * timestr ,
const char * encryption ,
const char * signing )
{
d_printf ( " %-12s %-7s %-13s %-32s %-12s %-12s \n " ,
servicename , server_id , machine , timestr , encryption , signing ) ;
return 0 ;
}
2022-03-24 18:34:10 +03:00
static int prepare_connections ( struct traverse_state * state )
{
2022-03-31 11:20:20 +03:00
if ( ! state - > json_output ) {
/* always print header line */
d_printf ( " \n %-12s %-7s %-13s %-32s %-12s %-12s \n " , " Service " , " pid " , " Machine " , " Connected at " , " Encryption " , " Signing " ) ;
d_printf ( " --------------------------------------------------------------------------------------------- \n " ) ;
} else {
add_section_to_json ( state , " tcons " ) ;
}
2022-03-24 18:34:10 +03:00
return 0 ;
}
2021-10-26 14:56:54 +03:00
static int traverse_connections ( const struct connections_data * crec ,
2015-11-19 17:54:17 +03:00
void * private_data )
1999-12-21 07:54:30 +03:00
{
2015-04-23 19:06:17 +03:00
struct server_id_buf tmp ;
2015-11-09 20:01:47 +03:00
char * timestr = NULL ;
2015-11-09 19:26:51 +03:00
int result = 0 ;
const char * encryption = " - " ;
2022-05-09 11:11:38 +03:00
enum crypto_degree encryption_degree = CRYPTO_DEGREE_NONE ;
2015-11-30 13:20:43 +03:00
const char * signing = " - " ;
2022-05-09 11:11:38 +03:00
enum crypto_degree signing_degree = CRYPTO_DEGREE_NONE ;
2022-03-24 13:36:56 +03:00
struct traverse_state * state = ( struct traverse_state * ) private_data ;
2015-04-23 19:06:17 +03:00
2022-03-24 18:27:10 +03:00
TALLOC_CTX * tmp_ctx = talloc_stackframe ( ) ;
if ( tmp_ctx = = NULL ) {
return - 1 ;
}
if ( crec - > cnum = = TID_FIELD_INVALID ) {
TALLOC_FREE ( tmp_ctx ) ;
2001-05-15 22:12:02 +04:00
return 0 ;
2022-03-24 18:27:10 +03:00
}
1999-12-21 07:54:30 +03:00
2012-07-13 19:24:02 +04:00
if ( do_checks & &
( ! process_exists ( crec - > pid ) | | ! Ucrit_checkUid ( crec - > uid ) ) ) {
2022-03-24 18:27:10 +03:00
TALLOC_FREE ( tmp_ctx ) ;
1999-12-21 07:54:30 +03:00
return 0 ;
}
2022-07-18 12:33:12 +03:00
timestr = timestring ( tmp_ctx , nt_time_to_unix ( crec - > start ) ) ;
2015-11-09 20:01:47 +03:00
if ( timestr = = NULL ) {
2022-03-24 18:27:10 +03:00
TALLOC_FREE ( tmp_ctx ) ;
2015-11-09 20:01:47 +03:00
return - 1 ;
}
2015-11-09 19:26:51 +03:00
if ( smbXsrv_is_encrypted ( crec - > encryption_flags ) ) {
switch ( crec - > cipher ) {
2015-11-30 19:03:26 +03:00
case SMB_ENCRYPTION_GSSAPI :
encryption = " GSSAPI " ;
break ;
2015-11-09 19:26:51 +03:00
case SMB2_ENCRYPTION_AES128_CCM :
encryption = " AES-128-CCM " ;
break ;
case SMB2_ENCRYPTION_AES128_GCM :
encryption = " AES-128-GCM " ;
break ;
default :
encryption = " ??? " ;
break ;
}
2022-05-09 11:11:38 +03:00
encryption_degree = CRYPTO_DEGREE_FULL ;
2015-11-09 19:26:51 +03:00
}
2015-11-30 13:20:43 +03:00
if ( smbXsrv_is_signed ( crec - > signing_flags ) ) {
2021-05-07 00:55:49 +03:00
switch ( crec - > signing ) {
case SMB2_SIGNING_MD5_SMB1 :
2015-11-30 19:03:26 +03:00
signing = " HMAC-MD5 " ;
2021-05-07 00:55:49 +03:00
break ;
case SMB2_SIGNING_HMAC_SHA256 :
signing = " HMAC-SHA256 " ;
break ;
case SMB2_SIGNING_AES128_CMAC :
signing = " AES-128-CMAC " ;
break ;
case SMB2_SIGNING_AES128_GMAC :
signing = " AES-128-GMAC " ;
break ;
default :
signing = " ??? " ;
break ;
2015-11-30 13:20:43 +03:00
}
2022-05-09 11:11:38 +03:00
signing_degree = CRYPTO_DEGREE_FULL ;
2015-11-30 13:20:43 +03:00
}
2022-03-31 11:20:20 +03:00
if ( ! state - > json_output ) {
result = traverse_connections_stdout ( state ,
crec - > servicename ,
server_id_str_buf ( crec - > pid , & tmp ) ,
crec - > machine ,
timestr ,
encryption ,
signing ) ;
} else {
result = traverse_connections_json ( state ,
2022-05-09 11:11:38 +03:00
crec ,
encryption ,
encryption_degree ,
signing ,
signing_degree ) ;
2022-03-31 11:20:20 +03:00
}
2015-11-09 20:01:47 +03:00
TALLOC_FREE ( timestr ) ;
2022-03-24 18:27:10 +03:00
TALLOC_FREE ( tmp_ctx ) ;
2001-08-22 23:11:55 +04:00
2015-11-09 19:26:51 +03:00
return result ;
2001-08-22 23:11:55 +04:00
}
2022-03-24 13:36:56 +03:00
static int traverse_sessionid_stdout ( struct traverse_state * state ,
char * server_id ,
char * uid_gid_str ,
char * machine_hostname ,
const char * dialect ,
2022-07-11 12:05:12 +03:00
const char * encryption_cipher ,
enum crypto_degree encryption_degree ,
const char * signing_cipher ,
enum crypto_degree signing_degree )
2022-03-24 13:36:56 +03:00
{
2022-07-11 12:05:12 +03:00
fstring encryption ;
fstring signing ;
if ( encryption_degree = = CRYPTO_DEGREE_FULL ) {
fstr_sprintf ( encryption , " %s " , encryption_cipher ) ;
} else if ( encryption_degree = = CRYPTO_DEGREE_PARTIAL ) {
fstr_sprintf ( encryption , " partial(%s) " , encryption_cipher ) ;
} else {
fstr_sprintf ( encryption , " - " ) ;
}
if ( signing_degree = = CRYPTO_DEGREE_FULL ) {
fstr_sprintf ( signing , " %s " , signing_cipher ) ;
} else if ( signing_degree = = CRYPTO_DEGREE_PARTIAL ) {
fstr_sprintf ( signing , " partial(%s) " , signing_cipher ) ;
} else {
fstr_sprintf ( signing , " - " ) ;
}
2022-03-24 13:36:56 +03:00
d_printf ( " %-7s %-25s %-41s %-17s %-20s %-21s \n " ,
server_id , uid_gid_str , machine_hostname , dialect , encryption ,
signing ) ;
return 0 ;
}
2022-03-24 18:34:10 +03:00
static int prepare_sessionid ( struct traverse_state * state )
{
2022-03-24 16:09:35 +03:00
if ( ! state - > json_output ) {
/* always print header line */
d_printf ( " \n Samba version %s \n " , samba_version_string ( ) ) ;
d_printf ( " %-7s %-12s %-12s %-41s %-17s %-20s %-21s \n " , " PID " , " Username " , " Group " , " Machine " , " Protocol Version " , " Encryption " , " Signing " ) ;
d_printf ( " ---------------------------------------------------------------------------------------------------------------------------------------- \n " ) ;
} else {
add_section_to_json ( state , " sessions " ) ;
}
2022-03-24 18:34:10 +03:00
return 0 ;
}
2010-03-01 18:18:23 +03:00
static int traverse_sessionid ( const char * key , struct sessionid * session ,
void * private_data )
2001-08-22 23:11:55 +04:00
{
2017-07-04 13:22:00 +03:00
fstring uid_gid_str ;
2022-03-24 16:09:35 +03:00
fstring uid_str ;
fstring gid_str ;
2015-04-23 19:06:17 +03:00
struct server_id_buf tmp ;
2015-11-09 19:02:38 +03:00
char * machine_hostname = NULL ;
2015-11-09 19:17:17 +03:00
int result = 0 ;
const char * encryption = " - " ;
2022-07-11 12:05:12 +03:00
enum crypto_degree encryption_degree = CRYPTO_DEGREE_NONE ;
2015-11-30 13:20:43 +03:00
const char * signing = " - " ;
2022-07-11 12:05:12 +03:00
enum crypto_degree signing_degree = CRYPTO_DEGREE_NONE ;
2022-03-24 13:36:56 +03:00
struct traverse_state * state = ( struct traverse_state * ) private_data ;
2001-08-22 23:11:55 +04:00
2022-03-24 18:27:10 +03:00
TALLOC_CTX * tmp_ctx = talloc_stackframe ( ) ;
if ( tmp_ctx = = NULL ) {
return - 1 ;
}
2012-07-13 19:24:02 +04:00
if ( do_checks & &
( ! process_exists ( session - > pid ) | |
! Ucrit_checkUid ( session - > uid ) ) ) {
2022-03-24 18:27:10 +03:00
TALLOC_FREE ( tmp_ctx ) ;
2001-08-22 23:11:55 +04:00
return 0 ;
1999-12-21 07:54:30 +03:00
}
2010-03-01 18:18:23 +03:00
Ucrit_addPid ( session - > pid ) ;
2003-11-13 01:35:50 +03:00
2017-07-04 13:22:00 +03:00
if ( numeric_only ) {
2022-03-24 16:09:35 +03:00
fstr_sprintf ( gid_str , " %u " , ( unsigned int ) session - > gid ) ;
fstr_sprintf ( uid_str , " %u " , ( unsigned int ) session - > uid ) ;
2017-07-04 13:22:00 +03:00
fstr_sprintf ( uid_gid_str , " %-12u %-12u " ,
( unsigned int ) session - > uid ,
( unsigned int ) session - > gid ) ;
} else {
if ( session - > uid = = - 1 & & session - > gid = = - 1 ) {
/*
* The session is not fully authenticated yet .
*/
fstrcpy ( uid_gid_str , " (auth in progress) " ) ;
2022-03-24 16:09:35 +03:00
fstrcpy ( gid_str , " (auth in progress) " ) ;
fstrcpy ( uid_str , " (auth in progress) " ) ;
2013-07-09 14:32:34 +04:00
} else {
2017-07-04 13:22:00 +03:00
/*
* In theory it should not happen that one of
* session - > uid and session - > gid is valid ( ie ! = - 1 )
* while the other is not ( ie = - 1 ) , so we a check for
* that case that bails out would be reasonable .
*/
const char * uid_name = " -1 " ;
const char * gid_name = " -1 " ;
if ( session - > uid ! = - 1 ) {
uid_name = uidtoname ( session - > uid ) ;
if ( uid_name = = NULL ) {
2022-03-24 18:27:10 +03:00
TALLOC_FREE ( tmp_ctx ) ;
2017-07-04 13:22:00 +03:00
return - 1 ;
}
2017-11-22 12:43:19 +03:00
}
2017-07-04 13:22:00 +03:00
if ( session - > gid ! = - 1 ) {
gid_name = gidtoname ( session - > gid ) ;
if ( gid_name = = NULL ) {
2022-03-24 18:27:10 +03:00
TALLOC_FREE ( tmp_ctx ) ;
2017-07-04 13:22:00 +03:00
return - 1 ;
}
2017-11-22 12:43:19 +03:00
}
2022-03-24 16:09:35 +03:00
fstr_sprintf ( gid_str , " %s " , gid_name ) ;
fstr_sprintf ( uid_str , " %s " , uid_name ) ;
2017-07-04 13:22:00 +03:00
fstr_sprintf ( uid_gid_str , " %-12s %-12s " ,
uid_name , gid_name ) ;
2013-07-09 14:32:34 +04:00
}
}
2004-12-17 11:51:23 +03:00
2022-03-24 18:27:10 +03:00
machine_hostname = talloc_asprintf ( tmp_ctx , " %s (%s) " ,
2015-11-09 19:02:38 +03:00
session - > remote_machine ,
session - > hostname ) ;
if ( machine_hostname = = NULL ) {
2022-03-24 18:27:10 +03:00
TALLOC_FREE ( tmp_ctx ) ;
2015-11-09 19:02:38 +03:00
return - 1 ;
}
2022-07-11 12:05:12 +03:00
if ( smbXsrv_is_encrypted ( session - > encryption_flags ) | |
smbXsrv_is_partially_encrypted ( session - > encryption_flags ) ) {
2015-11-09 19:17:17 +03:00
switch ( session - > cipher ) {
case SMB2_ENCRYPTION_AES128_CCM :
encryption = " AES-128-CCM " ;
break ;
case SMB2_ENCRYPTION_AES128_GCM :
encryption = " AES-128-GCM " ;
break ;
2021-05-07 00:55:49 +03:00
case SMB2_ENCRYPTION_AES256_CCM :
encryption = " AES-256-CCM " ;
break ;
case SMB2_ENCRYPTION_AES256_GCM :
encryption = " AES-256-GCM " ;
break ;
2015-11-09 19:17:17 +03:00
default :
encryption = " ??? " ;
result = - 1 ;
break ;
}
2022-07-11 12:05:12 +03:00
if ( smbXsrv_is_encrypted ( session - > encryption_flags ) ) {
encryption_degree = CRYPTO_DEGREE_FULL ;
} else if ( smbXsrv_is_partially_encrypted ( session - > encryption_flags ) ) {
encryption_degree = CRYPTO_DEGREE_PARTIAL ;
2015-11-09 19:17:17 +03:00
}
}
2022-07-11 12:05:12 +03:00
if ( smbXsrv_is_signed ( session - > signing_flags ) | |
smbXsrv_is_partially_signed ( session - > signing_flags ) ) {
2021-05-07 00:55:49 +03:00
switch ( session - > signing ) {
case SMB2_SIGNING_MD5_SMB1 :
2015-11-30 19:03:26 +03:00
signing = " HMAC-MD5 " ;
2021-05-07 00:55:49 +03:00
break ;
case SMB2_SIGNING_HMAC_SHA256 :
signing = " HMAC-SHA256 " ;
break ;
case SMB2_SIGNING_AES128_CMAC :
signing = " AES-128-CMAC " ;
break ;
case SMB2_SIGNING_AES128_GMAC :
signing = " AES-128-GMAC " ;
break ;
default :
signing = " ??? " ;
result = - 1 ;
break ;
2015-11-30 13:20:43 +03:00
}
2022-07-11 12:05:12 +03:00
if ( smbXsrv_is_signed ( session - > signing_flags ) ) {
signing_degree = CRYPTO_DEGREE_FULL ;
} else if ( smbXsrv_is_partially_signed ( session - > signing_flags ) ) {
signing_degree = CRYPTO_DEGREE_PARTIAL ;
2015-11-30 13:20:43 +03:00
}
}
2022-03-24 16:09:35 +03:00
if ( ! state - > json_output ) {
traverse_sessionid_stdout ( state ,
server_id_str_buf ( session - > pid , & tmp ) ,
uid_gid_str ,
machine_hostname ,
session_dialect_str ( session - > connection_dialect ) ,
encryption ,
encryption_degree ,
signing ,
signing_degree ) ;
} else {
result = traverse_sessionid_json ( state ,
session ,
uid_str ,
gid_str ,
2022-05-09 13:26:30 +03:00
encryption ,
encryption_degree ,
signing ,
signing_degree ,
2022-03-24 16:09:35 +03:00
session_dialect_str ( session - > connection_dialect ) ) ;
}
2009-09-18 20:10:54 +04:00
2015-11-09 19:02:38 +03:00
TALLOC_FREE ( machine_hostname ) ;
2022-03-24 18:27:10 +03:00
TALLOC_FREE ( tmp_ctx ) ;
2015-11-09 19:02:38 +03:00
2015-11-09 19:17:17 +03:00
return result ;
1999-12-21 07:54:30 +03:00
}
2022-03-24 13:36:56 +03:00
static bool print_notify_rec_stdout ( struct traverse_state * state ,
const char * path ,
char * server_id_str ,
unsigned filter ,
unsigned subdir_filter )
{
d_printf ( " %s \\ %s \\ %x \\ %x \n " , path , server_id_str ,
filter , subdir_filter ) ;
return true ;
}
2022-03-24 18:34:10 +03:00
static int prepare_notify ( struct traverse_state * state )
{
2022-08-01 12:19:37 +03:00
if ( ! state - > json_output ) {
/* don't print header line */
} else {
add_section_to_json ( state , " notifies " ) ;
}
2022-03-24 18:34:10 +03:00
return 0 ;
}
2015-01-09 15:48:56 +03:00
static bool print_notify_rec ( const char * path , struct server_id server ,
const struct notify_instance * instance ,
void * private_data )
2012-04-04 16:51:09 +04:00
{
2015-01-09 15:48:56 +03:00
struct server_id_buf idbuf ;
2022-03-24 13:36:56 +03:00
struct traverse_state * state = ( struct traverse_state * ) private_data ;
bool result ;
2012-04-04 16:51:09 +04:00
2022-08-01 12:19:37 +03:00
if ( ! state - > json_output ) {
result = print_notify_rec_stdout ( state ,
path ,
server_id_str_buf ( server , & idbuf ) ,
( unsigned ) instance - > filter ,
( unsigned ) instance - > subdir_filter ) ;
} else {
result = print_notify_rec_json ( state ,
instance ,
2022-05-02 11:58:24 +03:00
server ,
2022-08-01 12:19:37 +03:00
path ) ;
}
2012-04-04 16:51:09 +04:00
2022-03-24 13:36:56 +03:00
return result ;
2012-04-04 16:51:09 +04:00
}
1997-05-20 04:32:51 +04:00
2019-02-18 16:11:32 +03:00
enum {
OPT_RESOLVE_UIDS = 1000 ,
} ;
2014-02-26 23:16:26 +04:00
int main ( int argc , const char * argv [ ] )
1996-05-04 11:50:46 +04:00
{
1999-12-21 07:54:30 +03:00
int c ;
2006-07-11 22:01:26 +04:00
int profile_only = 0 ;
2007-10-19 04:40:25 +04:00
bool show_processes , show_locks , show_shares ;
2012-04-04 16:51:09 +04:00
bool show_notify = false ;
2019-08-19 14:29:03 +03:00
poptContext pc = NULL ;
2022-03-23 17:17:48 +03:00
struct traverse_state state = { 0 } ;
2002-03-12 00:37:01 +03:00
struct poptOption long_options [ ] = {
2002-10-28 22:50:06 +03:00
POPT_AUTOHELP
2019-01-08 14:21:36 +03:00
{
. longName = " processes " ,
. shortName = ' p ' ,
. argInfo = POPT_ARG_NONE ,
. arg = NULL ,
. val = ' p ' ,
. descrip = " Show processes only " ,
} ,
{
. longName = " verbose " ,
. shortName = ' v ' ,
. argInfo = POPT_ARG_NONE ,
. arg = NULL ,
. val = ' v ' ,
. descrip = " Be verbose " ,
} ,
{
. longName = " locks " ,
. shortName = ' L ' ,
. argInfo = POPT_ARG_NONE ,
. arg = NULL ,
. val = ' L ' ,
. descrip = " Show locks only " ,
} ,
{
. longName = " shares " ,
. shortName = ' S ' ,
. argInfo = POPT_ARG_NONE ,
. arg = NULL ,
. val = ' S ' ,
. descrip = " Show shares only " ,
} ,
{
. longName = " notify " ,
. shortName = ' N ' ,
. argInfo = POPT_ARG_NONE ,
. arg = NULL ,
. val = ' N ' ,
. descrip = " Show notifies " ,
} ,
{
. longName = " user " ,
. shortName = ' u ' ,
. argInfo = POPT_ARG_STRING ,
. arg = & username ,
. val = ' u ' ,
. descrip = " Switch to user " ,
} ,
{
. longName = " brief " ,
. shortName = ' b ' ,
. argInfo = POPT_ARG_NONE ,
. arg = NULL ,
. val = ' b ' ,
. descrip = " Be brief " ,
} ,
{
. longName = " profile " ,
. shortName = ' P ' ,
. argInfo = POPT_ARG_NONE ,
. arg = NULL ,
. val = ' P ' ,
. descrip = " Do profiling " ,
} ,
{
. longName = " profile-rates " ,
. shortName = ' R ' ,
. argInfo = POPT_ARG_NONE ,
. arg = NULL ,
. val = ' R ' ,
. descrip = " Show call rates " ,
} ,
{
. longName = " byterange " ,
. shortName = ' B ' ,
. argInfo = POPT_ARG_NONE ,
. arg = NULL ,
. val = ' B ' ,
. descrip = " Include byte range locks "
} ,
{
. longName = " numeric " ,
. shortName = ' n ' ,
. argInfo = POPT_ARG_NONE ,
. arg = NULL ,
. val = ' n ' ,
. descrip = " Numeric uid/gid "
} ,
2022-03-24 17:46:50 +03:00
{
. longName = " json " ,
. shortName = ' j ' ,
. argInfo = POPT_ARG_NONE ,
. arg = NULL ,
. val = ' j ' ,
. descrip = " JSON output "
} ,
2019-01-08 14:21:36 +03:00
{
. longName = " fast " ,
. shortName = ' f ' ,
. argInfo = POPT_ARG_NONE ,
. arg = NULL ,
. val = ' f ' ,
. descrip = " Skip checks if processes still exist "
} ,
2019-02-18 16:11:32 +03:00
{
. longName = " resolve-uids " ,
. shortName = 0 ,
. argInfo = POPT_ARG_NONE ,
. arg = NULL ,
. val = OPT_RESOLVE_UIDS ,
. descrip = " Try to resolve UIDs to usernames "
} ,
2003-04-14 07:30:20 +04:00
POPT_COMMON_SAMBA
2021-01-13 15:18:23 +03:00
POPT_COMMON_VERSION
2003-04-14 07:30:20 +04:00
POPT_TABLEEND
2002-03-12 00:37:01 +03:00
} ;
2007-08-31 13:54:30 +04:00
TALLOC_CTX * frame = talloc_stackframe ( ) ;
int ret = 0 ;
2015-01-09 15:48:56 +03:00
struct messaging_context * msg_ctx = NULL ;
2014-11-02 22:21:49 +03:00
char * db_path ;
2014-11-24 19:46:27 +03:00
bool ok ;
2023-08-07 07:48:22 +03:00
struct loadparm_context * lp_ctx = NULL ;
2002-03-12 00:37:01 +03:00
2022-03-24 18:34:10 +03:00
state . first = true ;
2022-03-24 17:46:35 +03:00
state . json_output = false ;
2022-03-23 17:17:48 +03:00
state . resolve_uids = false ;
2015-03-21 22:00:06 +03:00
smb_init_locale ( ) ;
2005-12-29 01:48:54 +03:00
2021-01-13 15:18:23 +03:00
ok = samba_cmdline_init ( frame ,
SAMBA_CMDLINE_CONFIG_CLIENT ,
false /* require_smbconf */ ) ;
if ( ! ok ) {
DBG_ERR ( " Failed to init cmdline parser! \n " ) ;
TALLOC_FREE ( frame ) ;
exit ( 1 ) ;
1998-07-24 05:08:31 +04:00
}
2023-08-07 07:48:22 +03:00
lp_ctx = samba_cmdline_get_lp_ctx ( ) ;
lpcfg_set_cmdline ( lp_ctx , " log level " , " 0 " ) ;
2002-03-12 00:37:01 +03:00
2021-01-13 15:18:23 +03:00
pc = samba_popt_get_context ( getprogname ( ) ,
argc ,
argv ,
long_options ,
POPT_CONTEXT_KEEP_FIRST ) ;
if ( pc = = NULL ) {
DBG_ERR ( " Failed to setup popt context! \n " ) ;
TALLOC_FREE ( frame ) ;
exit ( 1 ) ;
2014-12-16 17:52:43 +03:00
}
2003-04-16 18:31:10 +04:00
while ( ( c = poptGetNextOpt ( pc ) ) ! = - 1 ) {
1999-12-21 07:54:30 +03:00
switch ( c ) {
2007-10-19 22:38:36 +04:00
case ' p ' :
processes_only = true ;
break ;
case ' v ' :
verbose = true ;
break ;
case ' L ' :
locks_only = true ;
break ;
case ' S ' :
shares_only = true ;
break ;
2012-04-04 16:51:09 +04:00
case ' N ' :
show_notify = true ;
break ;
2007-10-19 22:38:36 +04:00
case ' b ' :
brief = true ;
break ;
case ' u ' :
2004-12-17 11:51:23 +03:00
Ucrit_addUid ( nametouid ( poptGetOptArg ( pc ) ) ) ;
1999-12-21 07:54:30 +03:00
break ;
2006-07-11 22:01:26 +04:00
case ' P ' :
case ' R ' :
profile_only = c ;
2007-10-19 22:38:36 +04:00
break ;
case ' B ' :
show_brl = true ;
break ;
case ' n ' :
numeric_only = true ;
break ;
2022-03-24 17:46:50 +03:00
case ' j ' :
state . json_output = true ;
break ;
2012-07-13 19:24:02 +04:00
case ' f ' :
do_checks = false ;
break ;
2019-02-18 16:11:32 +03:00
case OPT_RESOLVE_UIDS :
2022-03-23 17:17:48 +03:00
state . resolve_uids = true ;
2019-02-18 16:11:32 +03:00
break ;
2021-09-10 06:46:27 +03:00
case POPT_ERROR_BADOPT :
fprintf ( stderr , " \n Invalid option %s: %s \n \n " ,
poptBadOption ( pc , 0 ) , poptStrerror ( c ) ) ;
poptPrintUsage ( pc , stderr , 0 ) ;
exit ( 1 ) ;
1999-12-13 16:27:58 +03:00
}
1999-12-21 07:54:30 +03:00
}
2001-06-13 09:36:28 +04:00
2021-01-13 15:18:23 +03:00
sec_init ( ) ;
2022-03-24 17:46:35 +03:00
# ifdef HAVE_JANSSON
state . root_json = json_new_object ( ) ;
2023-05-23 02:16:56 +03:00
if ( ! json_is_invalid ( & state . root_json ) ) {
add_general_information_to_json ( & state ) ;
}
2022-03-24 17:46:50 +03:00
# else /* HAVE_JANSSON */
if ( state . json_output ) {
fprintf ( stderr , " JSON support not available, please install lib Jansson \n " ) ;
goto done ;
}
2022-03-24 17:46:35 +03:00
# endif /* HAVE_JANSSON */
2021-01-13 15:18:23 +03:00
if ( getuid ( ) ! = geteuid ( ) ) {
2022-03-23 10:58:54 +03:00
fprintf ( stderr , " smbstatus should not be run setuid \n " ) ;
2021-01-13 15:18:23 +03:00
ret = 1 ;
goto done ;
}
if ( getuid ( ) ! = 0 ) {
2022-03-23 10:58:54 +03:00
fprintf ( stderr , " smbstatus only works as root! \n " ) ;
2021-01-13 15:18:23 +03:00
ret = 1 ;
goto done ;
}
2004-11-12 02:30:32 +03:00
/* setup the flags based on the possible combincations */
show_processes = ! ( shares_only | | locks_only | | profile_only ) | | processes_only ;
show_locks = ! ( shares_only | | processes_only | | profile_only ) | | locks_only ;
show_shares = ! ( processes_only | | locks_only | | profile_only ) | | shares_only ;
if ( username )
2004-12-17 11:51:23 +03:00
Ucrit_addUid ( nametouid ( username ) ) ;
2004-11-12 02:30:32 +03:00
2022-03-24 17:46:50 +03:00
if ( verbose & & ! state . json_output ) {
2007-12-10 22:30:37 +03:00
d_printf ( " using configfile = %s \n " , get_dyn_CONFIGFILE ( ) ) ;
1999-12-21 07:54:30 +03:00
}
2002-10-28 22:50:06 +03:00
2018-08-21 01:46:27 +03:00
msg_ctx = cmdline_messaging_context ( get_dyn_CONFIGFILE ( ) ) ;
2015-11-10 19:59:09 +03:00
if ( msg_ctx = = NULL ) {
2018-08-21 01:46:27 +03:00
fprintf ( stderr , " Could not initialize messaging, not root? \n " ) ;
2015-11-10 19:59:09 +03:00
ret = - 1 ;
goto done ;
2008-06-13 14:00:24 +04:00
}
2006-07-11 22:01:26 +04:00
switch ( profile_only ) {
case ' P ' :
/* Dump profile data */
2022-03-25 16:16:27 +03:00
ok = status_profile_dump ( verbose , & state ) ;
2019-08-19 14:29:03 +03:00
ret = ok ? 0 : 1 ;
goto done ;
2006-07-11 22:01:26 +04:00
case ' R ' :
/* Continuously display rate-converted data */
2022-03-25 16:16:27 +03:00
if ( ! state . json_output ) {
ok = status_profile_rates ( verbose ) ;
ret = ok ? 0 : 1 ;
} else {
fprintf ( stderr , " Call rates not available in a json output. \n " ) ;
ret = 1 ;
}
2019-08-19 14:29:03 +03:00
goto done ;
2006-07-11 22:01:26 +04:00
default :
break ;
1999-12-21 07:54:30 +03:00
}
2006-07-11 22:01:26 +04:00
2004-11-12 02:30:32 +03:00
if ( show_processes ) {
2022-03-24 18:34:10 +03:00
prepare_sessionid ( & state ) ;
2022-03-24 18:27:10 +03:00
sessionid_traverse_read ( traverse_sessionid , & state ) ;
2010-03-01 18:18:23 +03:00
2007-08-31 13:54:30 +04:00
if ( processes_only ) {
goto done ;
}
2001-09-11 02:31:59 +04:00
}
2009-09-18 20:10:54 +04:00
2004-11-12 02:30:32 +03:00
if ( show_shares ) {
2007-08-31 13:54:30 +04:00
if ( brief ) {
goto done ;
}
2022-03-24 18:34:10 +03:00
prepare_connections ( & state ) ;
2022-03-24 18:27:10 +03:00
connections_forall_read ( traverse_connections , & state ) ;
2004-11-12 02:30:32 +03:00
2022-03-24 17:46:50 +03:00
if ( ! state . json_output ) {
d_printf ( " \n " ) ;
}
1999-12-21 07:54:30 +03:00
2007-08-31 13:54:30 +04:00
if ( shares_only ) {
goto done ;
}
2001-09-11 02:31:59 +04:00
}
1999-12-21 07:54:30 +03:00
2004-11-12 02:30:32 +03:00
if ( show_locks ) {
2007-08-31 13:54:30 +04:00
int result ;
2007-10-21 19:05:34 +04:00
struct db_context * db ;
2014-11-02 22:21:49 +03:00
2018-08-16 11:51:44 +03:00
db_path = lock_path ( talloc_tos ( ) , " locking.tdb " ) ;
2014-11-02 22:21:49 +03:00
if ( db_path = = NULL ) {
2022-03-23 10:58:54 +03:00
fprintf ( stderr , " Out of memory - exiting \n " ) ;
2014-11-02 22:21:49 +03:00
ret = - 1 ;
goto done ;
}
db = db_open ( NULL , db_path , 0 ,
2012-01-06 20:19:54 +04:00
TDB_CLEAR_IF_FIRST | TDB_INCOMPATIBLE_HASH , O_RDONLY , 0 ,
2014-01-27 17:49:12 +04:00
DBWRAP_LOCK_ORDER_1 , DBWRAP_FLAG_NONE ) ;
2007-10-21 19:05:34 +04:00
if ( ! db ) {
2022-03-23 10:58:54 +03:00
fprintf ( stderr , " %s not initialised \n " , db_path ) ;
fprintf ( stderr , " This is normal if an SMB client has never "
2007-10-21 19:05:34 +04:00
" connected to your server. \n " ) ;
2014-11-02 22:21:49 +03:00
TALLOC_FREE ( db_path ) ;
2023-01-11 11:59:42 +03:00
ret = 0 ;
goto done ;
2007-10-21 19:05:34 +04:00
} else {
TALLOC_FREE ( db ) ;
2014-11-02 22:21:49 +03:00
TALLOC_FREE ( db_path ) ;
2007-10-21 19:05:34 +04:00
}
1999-12-22 04:36:27 +03:00
2007-12-05 22:53:22 +03:00
if ( ! locking_init_readonly ( ) ) {
2022-03-23 10:58:54 +03:00
fprintf ( stderr , " Can't initialise locking module - exiting \n " ) ;
2007-08-31 13:54:30 +04:00
ret = 1 ;
goto done ;
1999-12-21 07:54:30 +03:00
}
2009-09-18 20:10:54 +04:00
2022-03-24 18:34:10 +03:00
prepare_share_mode ( & state ) ;
2022-03-24 18:27:10 +03:00
result = share_entry_forall ( print_share_mode , & state ) ;
1999-12-22 04:36:27 +03:00
2022-03-24 17:46:50 +03:00
if ( result = = 0 & & ! state . json_output ) {
2022-03-23 10:58:54 +03:00
fprintf ( stderr , " No locked files \n " ) ;
2022-03-24 17:46:50 +03:00
} else if ( result < 0 & & ! state . json_output ) {
2022-03-23 10:58:54 +03:00
fprintf ( stderr , " locked file list truncated \n " ) ;
1999-12-22 04:36:27 +03:00
}
2009-09-18 20:10:54 +04:00
2022-03-24 17:46:50 +03:00
if ( ! state . json_output ) {
d_printf ( " \n " ) ;
}
2000-01-16 14:14:44 +03:00
if ( show_brl ) {
2022-03-24 18:34:10 +03:00
prepare_brl ( & state ) ;
2022-03-24 18:27:10 +03:00
brl_forall ( print_brl , & state ) ;
2000-01-16 14:14:44 +03:00
}
2009-09-18 20:10:54 +04:00
1999-12-21 07:54:30 +03:00
locking_end ( ) ;
}
1997-05-20 04:32:51 +04:00
2012-04-04 16:51:09 +04:00
if ( show_notify ) {
2022-03-24 18:34:10 +03:00
prepare_notify ( & state ) ;
2022-03-24 18:27:10 +03:00
notify_walk ( msg_ctx , print_notify_rec , & state ) ;
2012-04-04 16:51:09 +04:00
}
2007-08-31 13:54:30 +04:00
done :
2020-12-24 14:38:18 +03:00
cmdline_messaging_context_free ( ) ;
2019-08-19 14:29:03 +03:00
poptFreeContext ( pc ) ;
2022-03-24 17:46:50 +03:00
# ifdef HAVE_JANSSON
2022-03-25 16:16:27 +03:00
if ( state . json_output ) {
2022-03-24 17:46:50 +03:00
d_printf ( " %s \n " , json_to_string ( frame , & state . root_json ) ) ;
}
json_free ( & state . root_json ) ;
# endif /* HAVE_JANSSON */
2007-08-31 13:54:30 +04:00
TALLOC_FREE ( frame ) ;
return ret ;
1996-05-04 11:50:46 +04:00
}