2000-07-05 11:24:26 +00:00
/*
2002-01-30 06:08:46 +00:00
Unix SMB / CIFS implementation .
2000-07-05 11:24:26 +00:00
Winbind status program .
2003-08-12 00:46:15 +00:00
Copyright ( C ) Tim Potter 2000 - 2003
2002-01-10 11:28:14 +00:00
Copyright ( C ) Andrew Bartlett 2002
2000-07-05 11:24:26 +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
the Free Software Foundation ; either version 2 of the License , or
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
along with this program ; if not , write to the Free Software
Foundation , Inc . , 675 Mass Ave , Cambridge , MA 0213 9 , USA .
*/
# include "includes.h"
# include "winbindd.h"
# include "debug.h"
2002-07-15 10:35:28 +00:00
# undef DBGC_CLASS
# define DBGC_CLASS DBGC_WINBIND
2002-09-25 15:19:00 +00:00
extern int winbindd_fd ;
2000-07-05 11:24:26 +00:00
2002-03-20 03:54:47 +00:00
static char winbind_separator ( void )
2002-01-10 11:28:14 +00:00
{
struct winbindd_response response ;
2002-03-20 03:54:47 +00:00
static BOOL got_sep ;
static char sep ;
if ( got_sep )
return sep ;
2002-01-10 11:28:14 +00:00
ZERO_STRUCT ( response ) ;
/* Send off request */
if ( winbindd_request ( WINBINDD_INFO , NULL , & response ) ! =
NSS_STATUS_SUCCESS ) {
2002-04-04 06:47:20 +00:00
d_printf ( " could not obtain winbind separator! \n " ) ;
2002-02-15 13:28:59 +00:00
/* HACK: (this module should not call lp_ funtions) */
return * lp_winbind_separator ( ) ;
2002-01-10 11:28:14 +00:00
}
2002-03-20 03:54:47 +00:00
sep = response . data . info . winbind_separator ;
got_sep = True ;
2002-01-10 11:28:14 +00:00
2002-03-20 03:54:47 +00:00
if ( ! sep ) {
2002-03-01 01:13:42 +00:00
d_printf ( " winbind separator was NULL! \n " ) ;
2002-02-15 13:28:59 +00:00
/* HACK: (this module should not call lp_ funtions) */
2002-03-20 03:54:47 +00:00
sep = * lp_winbind_separator ( ) ;
2002-01-10 11:28:14 +00:00
}
2002-03-20 03:54:47 +00:00
return sep ;
2002-01-10 11:28:14 +00:00
}
2002-11-12 23:20:50 +00:00
static const char * get_winbind_domain ( void )
2002-01-26 09:55:38 +00:00
{
struct winbindd_response response ;
static fstring winbind_domain ;
ZERO_STRUCT ( response ) ;
/* Send off request */
if ( winbindd_request ( WINBINDD_DOMAIN_NAME , NULL , & response ) ! =
NSS_STATUS_SUCCESS ) {
2002-03-01 01:13:42 +00:00
d_printf ( " could not obtain winbind domain name! \n " ) ;
2002-02-15 13:28:59 +00:00
/* HACK: (this module should not call lp_ funtions) */
return lp_workgroup ( ) ;
2002-01-26 09:55:38 +00:00
}
fstrcpy ( winbind_domain , response . data . domain_name ) ;
return winbind_domain ;
}
2002-01-10 10:23:54 +00:00
/* Copy of parse_domain_user from winbindd_util.c. Parse a string of the
form DOMAIN / user into a domain and a user */
2002-03-20 03:54:47 +00:00
static BOOL parse_wbinfo_domain_user ( const char * domuser , fstring domain ,
fstring user )
2002-01-10 10:23:54 +00:00
{
2002-01-10 11:28:14 +00:00
2002-03-20 03:54:47 +00:00
char * p = strchr ( domuser , winbind_separator ( ) ) ;
2002-01-10 10:23:54 +00:00
2002-01-18 02:37:55 +00:00
if ( ! p ) {
fstrcpy ( user , domuser ) ;
2002-01-26 09:55:38 +00:00
fstrcpy ( domain , get_winbind_domain ( ) ) ;
2002-01-18 02:37:55 +00:00
return True ;
}
2002-01-10 10:23:54 +00:00
fstrcpy ( user , p + 1 ) ;
fstrcpy ( domain , domuser ) ;
domain [ PTR_DIFF ( p , domuser ) ] = 0 ;
2003-07-03 19:11:31 +00:00
strupper_m ( domain ) ;
2002-03-20 03:54:47 +00:00
2002-01-10 10:23:54 +00:00
return True ;
}
2000-10-13 05:19:57 +00:00
/* List groups a user is a member of */
2000-10-11 05:25:32 +00:00
static BOOL wbinfo_get_usergroups ( char * user )
{
struct winbindd_request request ;
struct winbindd_response response ;
2001-09-05 07:55:54 +00:00
NSS_STATUS result ;
int i ;
2000-10-11 05:25:32 +00:00
ZERO_STRUCT ( response ) ;
/* Send request */
fstrcpy ( request . data . username , user ) ;
2000-10-11 05:45:06 +00:00
result = winbindd_request ( WINBINDD_GETGROUPS , & request , & response ) ;
2000-10-11 05:25:32 +00:00
2002-01-11 03:49:51 +00:00
if ( result ! = NSS_STATUS_SUCCESS )
2000-10-11 05:25:32 +00:00
return False ;
2002-01-11 03:49:51 +00:00
for ( i = 0 ; i < response . data . num_entries ; i + + )
2002-03-01 01:13:42 +00:00
d_printf ( " %d \n " , ( int ) ( ( gid_t * ) response . extra_data ) [ i ] ) ;
2002-01-11 03:49:51 +00:00
SAFE_FREE ( response . extra_data ) ;
2000-10-11 05:25:32 +00:00
return True ;
}
2003-11-19 08:11:14 +00:00
/* List group SIDs a user SID is a member of */
static BOOL wbinfo_get_usersids ( char * user_sid )
{
struct winbindd_request request ;
struct winbindd_response response ;
NSS_STATUS result ;
int i ;
const char * s ;
ZERO_STRUCT ( response ) ;
/* Send request */
fstrcpy ( request . data . sid , user_sid ) ;
result = winbindd_request ( WINBINDD_GETUSERSIDS , & request , & response ) ;
if ( result ! = NSS_STATUS_SUCCESS )
return False ;
s = response . extra_data ;
for ( i = 0 ; i < response . data . num_entries ; i + + ) {
d_printf ( " %s \n " , s ) ;
s + = strlen ( s ) + 1 ;
}
SAFE_FREE ( response . extra_data ) ;
return True ;
}
2002-03-29 15:37:39 +00:00
/* Convert NetBIOS name to IP */
static BOOL wbinfo_wins_byname ( char * name )
{
struct winbindd_request request ;
struct winbindd_response response ;
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
/* Send request */
fstrcpy ( request . data . winsreq , name ) ;
if ( winbindd_request ( WINBINDD_WINS_BYNAME , & request , & response ) ! =
NSS_STATUS_SUCCESS ) {
return False ;
}
/* Display response */
printf ( " %s \n " , response . data . winsresp ) ;
return True ;
}
/* Convert IP to NetBIOS name */
static BOOL wbinfo_wins_byip ( char * ip )
{
struct winbindd_request request ;
struct winbindd_response response ;
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
/* Send request */
fstrcpy ( request . data . winsreq , ip ) ;
if ( winbindd_request ( WINBINDD_WINS_BYIP , & request , & response ) ! =
NSS_STATUS_SUCCESS ) {
return False ;
}
/* Display response */
printf ( " %s \n " , response . data . winsresp ) ;
return True ;
}
2000-07-05 11:24:26 +00:00
/* List trusted domains */
static BOOL wbinfo_list_domains ( void )
{
struct winbindd_response response ;
fstring name ;
ZERO_STRUCT ( response ) ;
/* Send request */
2001-09-05 07:55:54 +00:00
if ( winbindd_request ( WINBINDD_LIST_TRUSTDOM , NULL , & response ) ! =
2002-03-20 03:54:47 +00:00
NSS_STATUS_SUCCESS )
2000-07-05 11:24:26 +00:00
return False ;
/* Display response */
if ( response . extra_data ) {
2002-11-12 23:20:50 +00:00
const char * extra_data = ( char * ) response . extra_data ;
2002-01-11 03:49:51 +00:00
while ( next_token ( & extra_data , name , " , " , sizeof ( fstring ) ) )
2002-03-01 01:13:42 +00:00
d_printf ( " %s \n " , name ) ;
2002-01-11 03:49:51 +00:00
SAFE_FREE ( response . extra_data ) ;
2000-07-05 11:24:26 +00:00
}
return True ;
}
2002-01-31 11:49:29 +00:00
/* show sequence numbers */
2003-08-10 22:01:11 +00:00
static BOOL wbinfo_show_sequence ( const char * domain )
2002-01-31 11:49:29 +00:00
{
2003-08-10 22:01:11 +00:00
struct winbindd_request request ;
2002-01-31 11:49:29 +00:00
struct winbindd_response response ;
ZERO_STRUCT ( response ) ;
2003-08-10 22:01:11 +00:00
ZERO_STRUCT ( request ) ;
if ( domain )
fstrcpy ( request . domain_name , domain ) ;
2002-01-31 11:49:29 +00:00
/* Send request */
2002-03-20 03:54:47 +00:00
2003-08-10 22:01:11 +00:00
if ( winbindd_request ( WINBINDD_SHOW_SEQUENCE , & request , & response ) ! =
2002-03-20 03:54:47 +00:00
NSS_STATUS_SUCCESS )
2002-01-31 11:49:29 +00:00
return False ;
/* Display response */
2002-03-20 03:54:47 +00:00
2002-01-31 11:49:29 +00:00
if ( response . extra_data ) {
char * extra_data = ( char * ) response . extra_data ;
2002-03-01 01:13:42 +00:00
d_printf ( " %s " , extra_data ) ;
2002-01-31 11:49:29 +00:00
SAFE_FREE ( response . extra_data ) ;
}
return True ;
}
2004-01-04 11:51:31 +00:00
/* Show domain info */
static BOOL wbinfo_domain_info ( const char * domain_name )
{
struct winbindd_request request ;
struct winbindd_response response ;
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
fstrcpy ( request . domain_name , domain_name ) ;
/* Send request */
if ( winbindd_request ( WINBINDD_DOMAIN_INFO , & request , & response ) ! =
NSS_STATUS_SUCCESS )
return False ;
/* Display response */
2004-01-08 08:19:18 +00:00
d_printf ( " Name : %s \n " , response . data . domain_info . name ) ;
d_printf ( " Alt_Name : %s \n " , response . data . domain_info . alt_name ) ;
2004-01-04 11:51:31 +00:00
2004-01-08 08:19:18 +00:00
d_printf ( " SID : %s \n " , response . data . domain_info . sid ) ;
2004-01-04 11:51:31 +00:00
2004-01-08 08:19:18 +00:00
d_printf ( " Active Directory : %s \n " ,
response . data . domain_info . active_directory ? " Yes " : " No " ) ;
d_printf ( " Native : %s \n " ,
2004-01-04 11:51:31 +00:00
response . data . domain_info . native_mode ? " Yes " : " No " ) ;
2004-01-08 08:19:18 +00:00
d_printf ( " Primary : %s \n " ,
2004-01-04 11:51:31 +00:00
response . data . domain_info . primary ? " Yes " : " No " ) ;
2004-01-08 08:19:18 +00:00
d_printf ( " Sequence : %d \n " , response . data . domain_info . sequence_number ) ;
2004-01-04 11:51:31 +00:00
return True ;
}
2000-07-05 11:24:26 +00:00
/* Check trust account password */
static BOOL wbinfo_check_secret ( void )
{
2000-10-13 05:19:57 +00:00
struct winbindd_response response ;
2002-07-15 10:35:28 +00:00
NSS_STATUS result ;
2000-10-13 05:19:57 +00:00
ZERO_STRUCT ( response ) ;
2002-08-17 17:00:51 +00:00
result = winbindd_request ( WINBINDD_CHECK_MACHACC , NULL , & response ) ;
2002-07-15 10:35:28 +00:00
d_printf ( " checking the trust secret via RPC calls %s \n " ,
( result = = NSS_STATUS_SUCCESS ) ? " succeeded " : " failed " ) ;
2000-10-13 05:19:57 +00:00
2002-07-15 10:35:28 +00:00
if ( result ! = NSS_STATUS_SUCCESS )
d_printf ( " error code was %s (0x%x) \n " ,
response . data . auth . nt_status_string ,
response . data . auth . nt_status ) ;
return result = = NSS_STATUS_SUCCESS ;
2000-07-05 11:24:26 +00:00
}
/* Convert uid to sid */
static BOOL wbinfo_uid_to_sid ( uid_t uid )
{
struct winbindd_request request ;
struct winbindd_response response ;
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
/* Send request */
request . data . uid = uid ;
2002-03-20 03:54:47 +00:00
2001-09-05 07:55:54 +00:00
if ( winbindd_request ( WINBINDD_UID_TO_SID , & request , & response ) ! =
2002-03-20 03:54:47 +00:00
NSS_STATUS_SUCCESS )
2000-07-05 11:24:26 +00:00
return False ;
/* Display response */
2002-03-01 01:13:42 +00:00
d_printf ( " %s \n " , response . data . sid . sid ) ;
2000-07-05 11:24:26 +00:00
return True ;
}
/* Convert gid to sid */
static BOOL wbinfo_gid_to_sid ( gid_t gid )
{
struct winbindd_request request ;
struct winbindd_response response ;
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
/* Send request */
request . data . gid = gid ;
2002-03-20 03:54:47 +00:00
2001-09-05 07:55:54 +00:00
if ( winbindd_request ( WINBINDD_GID_TO_SID , & request , & response ) ! =
2002-03-20 03:54:47 +00:00
NSS_STATUS_SUCCESS )
2000-07-05 11:24:26 +00:00
return False ;
/* Display response */
2002-03-01 01:13:42 +00:00
d_printf ( " %s \n " , response . data . sid . sid ) ;
2000-07-05 11:24:26 +00:00
return True ;
}
/* Convert sid to uid */
static BOOL wbinfo_sid_to_uid ( char * sid )
{
struct winbindd_request request ;
struct winbindd_response response ;
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
/* Send request */
fstrcpy ( request . data . sid , sid ) ;
2002-03-20 03:54:47 +00:00
2001-09-05 07:55:54 +00:00
if ( winbindd_request ( WINBINDD_SID_TO_UID , & request , & response ) ! =
2002-03-20 03:54:47 +00:00
NSS_STATUS_SUCCESS )
2000-07-05 11:24:26 +00:00
return False ;
/* Display response */
2002-03-01 01:13:42 +00:00
d_printf ( " %d \n " , ( int ) response . data . uid ) ;
2000-07-05 11:24:26 +00:00
return True ;
}
static BOOL wbinfo_sid_to_gid ( char * sid )
{
struct winbindd_request request ;
struct winbindd_response response ;
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
/* Send request */
fstrcpy ( request . data . sid , sid ) ;
2002-03-20 03:54:47 +00:00
2001-09-05 07:55:54 +00:00
if ( winbindd_request ( WINBINDD_SID_TO_GID , & request , & response ) ! =
2002-03-20 03:54:47 +00:00
NSS_STATUS_SUCCESS )
2000-07-05 11:24:26 +00:00
return False ;
/* Display response */
2002-03-01 01:13:42 +00:00
d_printf ( " %d \n " , ( int ) response . data . gid ) ;
2000-07-05 11:24:26 +00:00
return True ;
}
2004-04-07 12:43:44 +00:00
static BOOL wbinfo_allocate_rid ( void )
{
uint32 rid ;
if ( ! winbind_allocate_rid ( & rid ) )
return False ;
d_printf ( " New rid: %d \n " , rid ) ;
return True ;
}
2000-07-05 11:24:26 +00:00
/* Convert sid to string */
static BOOL wbinfo_lookupsid ( char * sid )
{
struct winbindd_request request ;
struct winbindd_response response ;
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
/* Send off request */
fstrcpy ( request . data . sid , sid ) ;
2002-03-20 03:54:47 +00:00
2001-09-05 07:55:54 +00:00
if ( winbindd_request ( WINBINDD_LOOKUPSID , & request , & response ) ! =
2002-03-20 03:54:47 +00:00
NSS_STATUS_SUCCESS )
2000-07-05 11:24:26 +00:00
return False ;
/* Display response */
2002-03-20 03:54:47 +00:00
d_printf ( " %s%c%s %d \n " , response . data . name . dom_name ,
winbind_separator ( ) , response . data . name . name ,
response . data . name . type ) ;
2000-07-05 11:24:26 +00:00
return True ;
}
/* Convert string to sid */
static BOOL wbinfo_lookupname ( char * name )
{
struct winbindd_request request ;
struct winbindd_response response ;
/* Send off request */
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
2002-03-20 03:54:47 +00:00
parse_wbinfo_domain_user ( name , request . data . name . dom_name ,
request . data . name . name ) ;
2002-01-26 09:55:38 +00:00
2001-09-05 07:55:54 +00:00
if ( winbindd_request ( WINBINDD_LOOKUPNAME , & request , & response ) ! =
2002-03-20 03:54:47 +00:00
NSS_STATUS_SUCCESS )
2000-07-05 11:24:26 +00:00
return False ;
/* Display response */
2004-01-05 04:26:35 +00:00
d_printf ( " %s %s (%d) \n " , response . data . sid . sid , sid_type_lookup ( response . data . sid . type ) , response . data . sid . type ) ;
2000-07-05 11:24:26 +00:00
return True ;
}
2001-08-22 02:48:16 +00:00
/* Authenticate a user with a plaintext password */
static BOOL wbinfo_auth ( char * username )
{
struct winbindd_request request ;
struct winbindd_response response ;
2001-09-05 07:55:54 +00:00
NSS_STATUS result ;
2001-08-22 02:48:16 +00:00
char * p ;
/* Send off request */
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
p = strchr ( username , ' % ' ) ;
if ( p ) {
* p = 0 ;
fstrcpy ( request . data . auth . user , username ) ;
fstrcpy ( request . data . auth . pass , p + 1 ) ;
* p = ' % ' ;
} else
fstrcpy ( request . data . auth . user , username ) ;
result = winbindd_request ( WINBINDD_PAM_AUTH , & request , & response ) ;
/* Display response */
2002-03-01 01:13:42 +00:00
d_printf ( " plaintext password authentication %s \n " ,
2001-09-05 07:55:54 +00:00
( result = = NSS_STATUS_SUCCESS ) ? " succeeded " : " failed " ) ;
2001-08-22 02:48:16 +00:00
2002-09-25 15:19:00 +00:00
if ( response . data . auth . nt_status )
2003-04-07 07:32:51 +00:00
d_printf ( " error code was %s (0x%x) \n error messsage was: %s \n " ,
2002-09-25 15:19:00 +00:00
response . data . auth . nt_status_string ,
2003-04-07 07:32:51 +00:00
response . data . auth . nt_status ,
response . data . auth . error_string ) ;
2002-02-05 09:40:36 +00:00
2001-09-05 07:55:54 +00:00
return result = = NSS_STATUS_SUCCESS ;
2001-08-22 02:48:16 +00:00
}
/* Authenticate a user with a challenge/response */
static BOOL wbinfo_auth_crap ( char * username )
{
struct winbindd_request request ;
struct winbindd_response response ;
2001-09-05 07:55:54 +00:00
NSS_STATUS result ;
2002-01-10 10:23:54 +00:00
fstring name_user ;
fstring name_domain ;
2001-08-22 02:48:16 +00:00
fstring pass ;
char * p ;
/* Send off request */
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
p = strchr ( username , ' % ' ) ;
if ( p ) {
* p = 0 ;
fstrcpy ( pass , p + 1 ) ;
2002-01-10 10:23:54 +00:00
}
2002-01-10 11:28:14 +00:00
parse_wbinfo_domain_user ( username , name_domain , name_user ) ;
2002-01-10 10:23:54 +00:00
2004-10-01 03:28:39 +00:00
fstrcpy ( request . data . auth_crap . user , name_user ) ;
2002-01-10 10:23:54 +00:00
2004-10-01 03:28:39 +00:00
fstrcpy ( request . data . auth_crap . domain ,
name_domain ) ;
2001-08-22 02:48:16 +00:00
2004-07-14 04:36:01 +00:00
generate_random_buffer ( request . data . auth_crap . chal , 8 ) ;
2001-08-22 02:48:16 +00:00
2004-09-30 00:49:41 +00:00
if ( lp_client_ntlmv2_auth ( ) ) {
DATA_BLOB server_chal ;
DATA_BLOB names_blob ;
2001-08-22 02:48:16 +00:00
2004-09-30 00:49:41 +00:00
DATA_BLOB lm_response ;
DATA_BLOB nt_response ;
server_chal = data_blob ( request . data . auth_crap . chal , 8 ) ;
/* Pretend this is a login to 'us', for blob purposes */
names_blob = NTLMv2_generate_names_blob ( global_myname ( ) , lp_workgroup ( ) ) ;
if ( ! SMBNTLMv2encrypt ( name_user , name_domain , pass , & server_chal ,
& names_blob ,
& lm_response , & nt_response , NULL ) ) {
data_blob_free ( & names_blob ) ;
data_blob_free ( & server_chal ) ;
return False ;
}
data_blob_free ( & names_blob ) ;
data_blob_free ( & server_chal ) ;
memcpy ( request . data . auth_crap . nt_resp , nt_response . data ,
MIN ( nt_response . length ,
sizeof ( request . data . auth_crap . nt_resp ) ) ) ;
request . data . auth_crap . nt_resp_len = nt_response . length ;
memcpy ( request . data . auth_crap . lm_resp , lm_response . data ,
MIN ( lm_response . length ,
sizeof ( request . data . auth_crap . lm_resp ) ) ) ;
request . data . auth_crap . lm_resp_len = lm_response . length ;
data_blob_free ( & nt_response ) ;
data_blob_free ( & lm_response ) ;
} else {
if ( lp_client_lanman_auth ( )
& & SMBencrypt ( pass , request . data . auth_crap . chal ,
( uchar * ) request . data . auth_crap . lm_resp ) ) {
request . data . auth_crap . lm_resp_len = 24 ;
} else {
request . data . auth_crap . lm_resp_len = 0 ;
}
SMBNTencrypt ( pass , request . data . auth_crap . chal ,
( uchar * ) request . data . auth_crap . nt_resp ) ;
request . data . auth_crap . nt_resp_len = 24 ;
}
2001-08-22 02:48:16 +00:00
result = winbindd_request ( WINBINDD_PAM_AUTH_CRAP , & request , & response ) ;
/* Display response */
2002-03-01 01:13:42 +00:00
d_printf ( " challenge/response password authentication %s \n " ,
2001-09-05 07:55:54 +00:00
( result = = NSS_STATUS_SUCCESS ) ? " succeeded " : " failed " ) ;
2001-08-22 02:48:16 +00:00
2002-09-25 15:19:00 +00:00
if ( response . data . auth . nt_status )
2003-04-07 07:32:51 +00:00
d_printf ( " error code was %s (0x%x) \n error messsage was: %s \n " ,
2002-09-25 15:19:00 +00:00
response . data . auth . nt_status_string ,
2003-04-07 07:32:51 +00:00
response . data . auth . nt_status ,
response . data . auth . error_string ) ;
2002-02-05 09:40:36 +00:00
2001-09-05 07:55:54 +00:00
return result = = NSS_STATUS_SUCCESS ;
2001-08-22 02:48:16 +00:00
}
2004-04-01 12:31:50 +00:00
/* Authenticate a user with a plaintext password and set a token */
static BOOL wbinfo_klog ( char * username )
{
struct winbindd_request request ;
struct winbindd_response response ;
NSS_STATUS result ;
char * p ;
/* Send off request */
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
p = strchr ( username , ' % ' ) ;
if ( p ) {
* p = 0 ;
fstrcpy ( request . data . auth . user , username ) ;
fstrcpy ( request . data . auth . pass , p + 1 ) ;
* p = ' % ' ;
} else {
fstrcpy ( request . data . auth . user , username ) ;
fstrcpy ( request . data . auth . pass , getpass ( " Password: " ) ) ;
}
request . flags | = WBFLAG_PAM_AFS_TOKEN ;
result = winbindd_request ( WINBINDD_PAM_AUTH , & request , & response ) ;
/* Display response */
d_printf ( " plaintext password authentication %s \n " ,
( result = = NSS_STATUS_SUCCESS ) ? " succeeded " : " failed " ) ;
if ( response . data . auth . nt_status )
d_printf ( " error code was %s (0x%x) \n error messsage was: %s \n " ,
response . data . auth . nt_status_string ,
response . data . auth . nt_status ,
response . data . auth . error_string ) ;
if ( result ! = NSS_STATUS_SUCCESS )
return False ;
if ( response . extra_data = = NULL ) {
d_printf ( " Did not get token data \n " ) ;
return False ;
}
if ( ! afs_settoken_str ( ( char * ) response . extra_data ) ) {
d_printf ( " Could not set token \n " ) ;
return False ;
}
d_printf ( " Successfully created AFS token \n " ) ;
return True ;
}
2003-07-09 16:44:47 +00:00
/******************************************************************
create a winbindd user
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL wbinfo_create_user ( char * username )
{
struct winbindd_request request ;
struct winbindd_response response ;
NSS_STATUS result ;
/* Send off request */
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
2003-07-11 05:33:40 +00:00
request . flags = WBFLAG_ALLOCATE_RID ;
2003-07-09 16:44:47 +00:00
fstrcpy ( request . data . acct_mgt . username , username ) ;
result = winbindd_request ( WINBINDD_CREATE_USER , & request , & response ) ;
2003-07-11 05:33:40 +00:00
if ( result = = NSS_STATUS_SUCCESS )
d_printf ( " New RID is %d \n " , response . data . rid ) ;
return result = = NSS_STATUS_SUCCESS ;
}
2003-07-09 16:44:47 +00:00
2003-07-11 05:33:40 +00:00
/******************************************************************
remove a winbindd user
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL wbinfo_delete_user ( char * username )
{
struct winbindd_request request ;
struct winbindd_response response ;
NSS_STATUS result ;
/* Send off request */
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
fstrcpy ( request . data . acct_mgt . username , username ) ;
result = winbindd_request ( WINBINDD_DELETE_USER , & request , & response ) ;
2003-07-09 16:44:47 +00:00
return result = = NSS_STATUS_SUCCESS ;
}
/******************************************************************
create a winbindd group
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL wbinfo_create_group ( char * groupname )
{
struct winbindd_request request ;
struct winbindd_response response ;
NSS_STATUS result ;
/* Send off request */
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
fstrcpy ( request . data . acct_mgt . groupname , groupname ) ;
result = winbindd_request ( WINBINDD_CREATE_GROUP , & request , & response ) ;
2003-07-11 05:33:40 +00:00
return result = = NSS_STATUS_SUCCESS ;
}
2003-07-09 16:44:47 +00:00
2003-07-11 05:33:40 +00:00
/******************************************************************
remove a winbindd group
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL wbinfo_delete_group ( char * groupname )
{
struct winbindd_request request ;
struct winbindd_response response ;
NSS_STATUS result ;
/* Send off request */
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
fstrcpy ( request . data . acct_mgt . groupname , groupname ) ;
result = winbindd_request ( WINBINDD_DELETE_GROUP , & request , & response ) ;
2003-07-09 16:44:47 +00:00
return result = = NSS_STATUS_SUCCESS ;
}
/******************************************************************
parse a string in the form user : group
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL parse_user_group ( const char * string , fstring user , fstring group )
{
char * p ;
if ( ! string )
return False ;
if ( ! ( p = strchr ( string , ' : ' ) ) )
return False ;
* p = ' \0 ' ;
p + + ;
fstrcpy ( user , string ) ;
fstrcpy ( group , p ) ;
return True ;
}
/******************************************************************
add a user to a winbindd group
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL wbinfo_add_user_to_group ( char * string )
{
struct winbindd_request request ;
struct winbindd_response response ;
NSS_STATUS result ;
/* Send off request */
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
if ( ! parse_user_group ( string , request . data . acct_mgt . username ,
request . data . acct_mgt . groupname ) )
{
d_printf ( " Can't parse user:group from %s \n " , string ) ;
return False ;
}
result = winbindd_request ( WINBINDD_ADD_USER_TO_GROUP , & request , & response ) ;
return result = = NSS_STATUS_SUCCESS ;
}
/******************************************************************
remove a user from a winbindd group
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL wbinfo_remove_user_from_group ( char * string )
{
struct winbindd_request request ;
struct winbindd_response response ;
NSS_STATUS result ;
/* Send off request */
ZERO_STRUCT ( request ) ;
ZERO_STRUCT ( response ) ;
if ( ! parse_user_group ( string , request . data . acct_mgt . username ,
request . data . acct_mgt . groupname ) )
{
d_printf ( " Can't parse user:group from %s \n " , string ) ;
return False ;
}
result = winbindd_request ( WINBINDD_REMOVE_USER_FROM_GROUP , & request , & response ) ;
return result = = NSS_STATUS_SUCCESS ;
}
2000-07-05 11:24:26 +00:00
/* Print domain users */
2003-08-10 22:01:11 +00:00
static BOOL print_domain_users ( const char * domain )
2000-07-05 11:24:26 +00:00
{
2003-08-10 22:01:11 +00:00
struct winbindd_request request ;
2000-07-05 11:24:26 +00:00
struct winbindd_response response ;
2002-11-12 23:20:50 +00:00
const char * extra_data ;
2000-07-05 11:24:26 +00:00
fstring name ;
/* Send request to winbind daemon */
2003-08-10 22:01:11 +00:00
ZERO_STRUCT ( request ) ;
2000-07-05 11:24:26 +00:00
ZERO_STRUCT ( response ) ;
2003-08-10 22:01:11 +00:00
2003-08-11 06:36:30 +00:00
if ( domain ) {
/* '.' is the special sign for our own domwin */
if ( strequal ( domain , " . " ) )
fstrcpy ( request . domain_name , lp_workgroup ( ) ) ;
else
fstrcpy ( request . domain_name , domain ) ;
}
2000-07-05 11:24:26 +00:00
2003-08-10 22:01:11 +00:00
if ( winbindd_request ( WINBINDD_LIST_USERS , & request , & response ) ! =
2002-03-20 03:54:47 +00:00
NSS_STATUS_SUCCESS )
2000-07-05 11:24:26 +00:00
return False ;
/* Look through extra data */
2002-01-11 03:49:51 +00:00
if ( ! response . extra_data )
2000-07-05 11:24:26 +00:00
return False ;
2002-11-12 23:20:50 +00:00
extra_data = ( const char * ) response . extra_data ;
2002-01-11 03:49:51 +00:00
while ( next_token ( & extra_data , name , " , " , sizeof ( fstring ) ) )
2002-03-01 01:13:42 +00:00
d_printf ( " %s \n " , name ) ;
2000-07-05 11:24:26 +00:00
2002-01-11 03:49:51 +00:00
SAFE_FREE ( response . extra_data ) ;
2000-07-05 11:24:26 +00:00
return True ;
}
/* Print domain groups */
2003-08-10 22:01:11 +00:00
static BOOL print_domain_groups ( const char * domain )
2000-07-05 11:24:26 +00:00
{
2003-08-10 22:01:11 +00:00
struct winbindd_request request ;
2000-07-05 11:24:26 +00:00
struct winbindd_response response ;
2002-11-12 23:20:50 +00:00
const char * extra_data ;
2000-07-05 11:24:26 +00:00
fstring name ;
2003-08-10 22:01:11 +00:00
ZERO_STRUCT ( request ) ;
2000-07-05 11:24:26 +00:00
ZERO_STRUCT ( response ) ;
2003-08-11 06:36:30 +00:00
if ( domain ) {
if ( strequal ( domain , " . " ) )
fstrcpy ( request . domain_name , lp_workgroup ( ) ) ;
else
fstrcpy ( request . domain_name , domain ) ;
}
2003-08-10 22:01:11 +00:00
if ( winbindd_request ( WINBINDD_LIST_GROUPS , & request , & response ) ! =
2002-03-20 03:54:47 +00:00
NSS_STATUS_SUCCESS )
2000-07-05 11:24:26 +00:00
return False ;
/* Look through extra data */
2002-01-11 03:49:51 +00:00
if ( ! response . extra_data )
2000-07-05 11:24:26 +00:00
return False ;
2002-11-12 23:20:50 +00:00
extra_data = ( const char * ) response . extra_data ;
2002-01-11 03:49:51 +00:00
while ( next_token ( & extra_data , name , " , " , sizeof ( fstring ) ) )
2002-03-01 01:13:42 +00:00
d_printf ( " %s \n " , name ) ;
2002-01-11 03:49:51 +00:00
SAFE_FREE ( response . extra_data ) ;
2000-07-05 11:24:26 +00:00
return True ;
}
2001-12-11 05:18:36 +00:00
/* Set the authorised user for winbindd access in secrets.tdb */
static BOOL wbinfo_set_auth_user ( char * username )
{
2004-04-01 08:54:01 +00:00
const char * password ;
char * p ;
2002-02-15 13:28:59 +00:00
fstring user , domain ;
2001-12-11 05:18:36 +00:00
/* Separate into user and password */
2002-02-15 13:28:59 +00:00
parse_wbinfo_domain_user ( username , domain , user ) ;
2004-04-01 08:54:01 +00:00
p = strchr ( user , ' % ' ) ;
2001-12-11 05:18:36 +00:00
2004-04-01 08:54:01 +00:00
if ( p ! = NULL ) {
* p = 0 ;
password = p + 1 ;
2003-10-31 20:29:18 +00:00
} else {
char * thepass = getpass ( " Password: " ) ;
if ( thepass ) {
password = thepass ;
} else
password = " " ;
}
2001-12-11 05:18:36 +00:00
2002-11-02 01:51:53 +00:00
/* Store or remove DOMAIN\username%password in secrets.tdb */
secrets_init ( ) ;
if ( user [ 0 ] ) {
if ( ! secrets_store ( SECRETS_AUTH_USER , user ,
strlen ( user ) + 1 ) ) {
d_fprintf ( stderr , " error storing username \n " ) ;
return False ;
}
/* We always have a domain name added by the
parse_wbinfo_domain_user ( ) function . */
if ( ! secrets_store ( SECRETS_AUTH_DOMAIN , domain ,
strlen ( domain ) + 1 ) ) {
d_fprintf ( stderr , " error storing domain name \n " ) ;
return False ;
}
} else {
secrets_delete ( SECRETS_AUTH_USER ) ;
secrets_delete ( SECRETS_AUTH_DOMAIN ) ;
2001-12-11 05:18:36 +00:00
}
2002-11-02 01:51:53 +00:00
if ( password [ 0 ] ) {
if ( ! secrets_store ( SECRETS_AUTH_PASSWORD , password ,
strlen ( password ) + 1 ) ) {
d_fprintf ( stderr , " error storing password \n " ) ;
return False ;
}
} else
secrets_delete ( SECRETS_AUTH_PASSWORD ) ;
2001-12-11 05:18:36 +00:00
return True ;
}
2002-11-02 01:51:53 +00:00
static void wbinfo_get_auth_user ( void )
{
char * user , * domain , * password ;
/* Lift data from secrets file */
2004-01-07 10:11:24 +00:00
secrets_fetch_ipc_userpass ( & user , & domain , & password ) ;
2002-11-02 01:51:53 +00:00
2004-01-07 10:11:24 +00:00
if ( ( ! user | | ! * user ) & & ( ! domain | | ! * domain ) & & ( ! password | | ! * password ) ) {
2002-11-02 01:51:53 +00:00
2004-01-07 10:11:24 +00:00
SAFE_FREE ( user ) ;
SAFE_FREE ( domain ) ;
SAFE_FREE ( password ) ;
2002-11-02 01:51:53 +00:00
d_printf ( " No authorised user configured \n " ) ;
return ;
}
/* Pretty print authorised user info */
2004-01-06 19:57:14 +00:00
d_printf ( " %s%s%s%s%s \n " , domain ? domain : " " , domain ? lp_winbind_separator ( ) : " " ,
2002-11-02 01:51:53 +00:00
user , password ? " % " : " " , password ? password : " " ) ;
SAFE_FREE ( user ) ;
SAFE_FREE ( domain ) ;
SAFE_FREE ( password ) ;
}
2002-01-10 10:23:54 +00:00
static BOOL wbinfo_ping ( void )
{
NSS_STATUS result ;
2002-09-25 15:19:00 +00:00
2002-01-10 10:23:54 +00:00
result = winbindd_request ( WINBINDD_PING , NULL , NULL ) ;
/* Display response */
2003-03-18 06:07:50 +00:00
d_printf ( " Ping to winbindd %s on fd %d \n " ,
2002-09-25 15:19:00 +00:00
( result = = NSS_STATUS_SUCCESS ) ? " succeeded " : " failed " , winbindd_fd ) ;
2002-01-10 10:23:54 +00:00
return result = = NSS_STATUS_SUCCESS ;
}
2000-07-05 11:24:26 +00:00
/* Main program */
2001-12-11 05:18:36 +00:00
enum {
2002-03-20 03:54:47 +00:00
OPT_SET_AUTH_USER = 1000 ,
2002-11-02 01:51:53 +00:00
OPT_GET_AUTH_USER ,
2003-08-10 22:01:11 +00:00
OPT_DOMAIN_NAME ,
2003-11-19 08:11:14 +00:00
OPT_SEQUENCE ,
OPT_USERSIDS
2001-12-11 05:18:36 +00:00
} ;
2000-07-05 11:24:26 +00:00
int main ( int argc , char * * argv )
{
int opt ;
2001-12-11 05:18:36 +00:00
poptContext pc ;
2001-12-11 18:08:48 +00:00
static char * string_arg ;
2003-08-10 22:01:11 +00:00
static char * opt_domain_name ;
2001-12-11 18:08:48 +00:00
static int int_arg ;
2002-04-04 06:40:17 +00:00
int result = 1 ;
2001-12-11 05:18:36 +00:00
struct poptOption long_options [ ] = {
2002-09-25 15:19:00 +00:00
POPT_AUTOHELP
2001-12-11 05:18:36 +00:00
2002-03-20 03:54:47 +00:00
/* longName, shortName, argInfo, argPtr, value, descrip,
argDesc */
2003-08-10 22:01:11 +00:00
{ " domain-users " , ' u ' , POPT_ARG_NONE , 0 , ' u ' , " Lists all domain users " , " domain " } ,
{ " domain-groups " , ' g ' , POPT_ARG_NONE , 0 , ' g ' , " Lists all domain groups " , " domain " } ,
2003-03-18 06:07:50 +00:00
{ " WINS-by-name " , ' N ' , POPT_ARG_STRING , & string_arg , ' N ' , " Converts NetBIOS name to IP " , " NETBIOS-NAME " } ,
{ " WINS-by-ip " , ' I ' , POPT_ARG_STRING , & string_arg , ' I ' , " Converts IP address to NetBIOS name " , " IP " } ,
2002-10-29 17:36:50 +00:00
{ " name-to-sid " , ' n ' , POPT_ARG_STRING , & string_arg , ' n ' , " Converts name to sid " , " NAME " } ,
{ " sid-to-name " , ' s ' , POPT_ARG_STRING , & string_arg , ' s ' , " Converts sid to name " , " SID " } ,
{ " uid-to-sid " , ' U ' , POPT_ARG_INT , & int_arg , ' U ' , " Converts uid to sid " , " UID " } ,
{ " gid-to-sid " , ' G ' , POPT_ARG_INT , & int_arg , ' G ' , " Converts gid to sid " , " GID " } ,
{ " sid-to-uid " , ' S ' , POPT_ARG_STRING , & string_arg , ' S ' , " Converts sid to uid " , " SID " } ,
{ " sid-to-gid " , ' Y ' , POPT_ARG_STRING , & string_arg , ' Y ' , " Converts sid to gid " , " SID " } ,
2004-04-07 12:43:44 +00:00
{ " allocate-rid " , ' A ' , POPT_ARG_NONE , 0 , ' A ' , " Get a new RID out of idmap " } ,
2003-07-09 16:44:47 +00:00
{ " create-user " , ' c ' , POPT_ARG_STRING , & string_arg , ' c ' , " Create a local user account " , " name " } ,
2003-07-11 05:33:40 +00:00
{ " delete-user " , ' x ' , POPT_ARG_STRING , & string_arg , ' x ' , " Delete a local user account " , " name " } ,
2003-07-09 16:44:47 +00:00
{ " create-group " , ' C ' , POPT_ARG_STRING , & string_arg , ' C ' , " Create a local group " , " name " } ,
2003-07-11 05:33:40 +00:00
{ " delete-group " , ' X ' , POPT_ARG_STRING , & string_arg , ' X ' , " Delete a local group " , " name " } ,
2003-07-09 16:44:47 +00:00
{ " add-to-group " , ' o ' , POPT_ARG_STRING , & string_arg , ' o ' , " Add user to group " , " user:group " } ,
{ " del-from-group " , ' O ' , POPT_ARG_STRING , & string_arg , ' O ' , " Remove user from group " , " user:group " } ,
2002-09-25 15:19:00 +00:00
{ " check-secret " , ' t ' , POPT_ARG_NONE , 0 , ' t ' , " Check shared secret " } ,
{ " trusted-domains " , ' m ' , POPT_ARG_NONE , 0 , ' m ' , " List trusted domains " } ,
2003-03-18 06:07:50 +00:00
{ " sequence " , 0 , POPT_ARG_NONE , 0 , OPT_SEQUENCE , " Show sequence numbers of all domains " } ,
2004-01-23 12:57:29 +00:00
{ " domain-info " , ' D ' , POPT_ARG_STRING , & string_arg , ' D ' , " Show most of the info we have about the domain " } ,
2002-10-29 17:36:50 +00:00
{ " user-groups " , ' r ' , POPT_ARG_STRING , & string_arg , ' r ' , " Get user groups " , " USER " } ,
2003-11-19 08:11:14 +00:00
{ " user-sids " , 0 , POPT_ARG_STRING , & string_arg , OPT_USERSIDS , " Get user group sids for user SID " , " SID " } ,
2002-09-25 15:19:00 +00:00
{ " authenticate " , ' a ' , POPT_ARG_STRING , & string_arg , ' a ' , " authenticate user " , " user%password " } ,
2003-06-18 14:20:23 +00:00
{ " set-auth-user " , 0 , POPT_ARG_STRING , & string_arg , OPT_SET_AUTH_USER , " Store user and password used by winbindd (root only) " , " user%password " } ,
2002-11-02 01:51:53 +00:00
{ " get-auth-user " , 0 , POPT_ARG_NONE , NULL , OPT_GET_AUTH_USER , " Retrieve user and password used by winbindd (root only) " , NULL } ,
2003-03-18 06:07:50 +00:00
{ " ping " , ' p ' , POPT_ARG_NONE , 0 , ' p ' , " Ping winbindd to see if it is alive " } ,
2003-12-23 20:25:21 +00:00
{ " domain " , 0 , POPT_ARG_STRING , & opt_domain_name , OPT_DOMAIN_NAME , " Define to the domain to restrict operation " , " domain " } ,
2004-04-01 12:31:50 +00:00
# ifdef WITH_FAKE_KASERVER
{ " klog " , ' k ' , POPT_ARG_STRING , & string_arg , ' k ' , " set an AFS token from winbind " , " user%password " } ,
# endif
2003-04-14 02:38:21 +00:00
POPT_COMMON_VERSION
POPT_TABLEEND
2001-12-11 05:18:36 +00:00
} ;
2000-07-05 11:24:26 +00:00
/* Samba client initialisation */
2001-11-19 02:49:53 +00:00
if ( ! lp_load ( dyn_CONFIGFILE , True , False , False ) ) {
2002-03-01 01:13:42 +00:00
d_fprintf ( stderr , " wbinfo: error opening config file %s. Error was %s \n " ,
2001-12-04 21:30:52 +00:00
dyn_CONFIGFILE , strerror ( errno ) ) ;
2000-07-05 11:24:26 +00:00
exit ( 1 ) ;
}
2002-01-10 11:28:14 +00:00
2002-11-12 23:20:50 +00:00
if ( ! init_names ( ) )
return 1 ;
2000-07-05 11:24:26 +00:00
load_interfaces ( ) ;
2002-09-25 15:19:00 +00:00
/* Parse options */
pc = poptGetContext ( " wbinfo " , argc , ( const char * * ) argv , long_options , 0 ) ;
2000-07-05 11:24:26 +00:00
/* Parse command line options */
if ( argc = = 1 ) {
2002-09-25 15:19:00 +00:00
poptPrintHelp ( pc , stderr , 0 ) ;
2000-07-05 11:24:26 +00:00
return 1 ;
}
2001-12-11 05:18:36 +00:00
while ( ( opt = poptGetNextOpt ( pc ) ) ! = - 1 ) {
2003-08-10 22:01:11 +00:00
/* get the generic configuration parameters like --domain */
2001-12-11 05:18:36 +00:00
}
2002-04-04 06:40:17 +00:00
poptFreeContext ( pc ) ;
2001-12-11 05:18:36 +00:00
pc = poptGetContext ( NULL , argc , ( const char * * ) argv , long_options ,
POPT_CONTEXT_KEEP_FIRST ) ;
while ( ( opt = poptGetNextOpt ( pc ) ) ! = - 1 ) {
2000-07-05 11:24:26 +00:00
switch ( opt ) {
case ' u ' :
2003-08-10 22:01:11 +00:00
if ( ! print_domain_users ( opt_domain_name ) ) {
2002-03-01 01:13:42 +00:00
d_printf ( " Error looking up domain users \n " ) ;
2002-04-04 06:40:17 +00:00
goto done ;
2000-07-05 11:24:26 +00:00
}
break ;
case ' g ' :
2003-08-10 22:01:11 +00:00
if ( ! print_domain_groups ( opt_domain_name ) ) {
2002-03-01 01:13:42 +00:00
d_printf ( " Error looking up domain groups \n " ) ;
2002-04-04 06:40:17 +00:00
goto done ;
2000-07-05 11:24:26 +00:00
}
break ;
case ' s ' :
2001-12-11 05:18:36 +00:00
if ( ! wbinfo_lookupsid ( string_arg ) ) {
2002-03-01 01:13:42 +00:00
d_printf ( " Could not lookup sid %s \n " , string_arg ) ;
2002-04-04 06:40:17 +00:00
goto done ;
2000-07-05 11:24:26 +00:00
}
break ;
case ' n ' :
2001-12-11 05:18:36 +00:00
if ( ! wbinfo_lookupname ( string_arg ) ) {
2002-03-01 01:13:42 +00:00
d_printf ( " Could not lookup name %s \n " , string_arg ) ;
2002-04-04 06:40:17 +00:00
goto done ;
2000-07-05 11:24:26 +00:00
}
break ;
2002-03-29 15:37:39 +00:00
case ' N ' :
if ( ! wbinfo_wins_byname ( string_arg ) ) {
d_printf ( " Could not lookup WINS by name %s \n " , string_arg ) ;
2002-04-04 06:40:17 +00:00
goto done ;
2002-03-29 15:37:39 +00:00
}
break ;
case ' I ' :
if ( ! wbinfo_wins_byip ( string_arg ) ) {
d_printf ( " Could not lookup WINS by IP %s \n " , string_arg ) ;
2002-04-04 06:40:17 +00:00
goto done ;
2002-03-29 15:37:39 +00:00
}
break ;
2000-07-05 11:24:26 +00:00
case ' U ' :
2001-12-11 05:18:36 +00:00
if ( ! wbinfo_uid_to_sid ( int_arg ) ) {
2002-03-01 01:13:42 +00:00
d_printf ( " Could not convert uid %d to sid \n " , int_arg ) ;
2002-04-04 06:40:17 +00:00
goto done ;
2000-07-05 11:24:26 +00:00
}
break ;
case ' G ' :
2001-12-11 05:18:36 +00:00
if ( ! wbinfo_gid_to_sid ( int_arg ) ) {
2002-03-01 01:13:42 +00:00
d_printf ( " Could not convert gid %d to sid \n " ,
2001-12-11 05:18:36 +00:00
int_arg ) ;
2002-04-04 06:40:17 +00:00
goto done ;
2000-07-05 11:24:26 +00:00
}
break ;
case ' S ' :
2001-12-11 05:18:36 +00:00
if ( ! wbinfo_sid_to_uid ( string_arg ) ) {
2002-03-01 01:13:42 +00:00
d_printf ( " Could not convert sid %s to uid \n " ,
2001-12-11 05:18:36 +00:00
string_arg ) ;
2002-04-04 06:40:17 +00:00
goto done ;
2000-07-05 11:24:26 +00:00
}
break ;
case ' Y ' :
2001-12-11 05:18:36 +00:00
if ( ! wbinfo_sid_to_gid ( string_arg ) ) {
2002-03-01 01:13:42 +00:00
d_printf ( " Could not convert sid %s to gid \n " ,
2001-12-11 05:18:36 +00:00
string_arg ) ;
2002-04-04 06:40:17 +00:00
goto done ;
2000-07-05 11:24:26 +00:00
}
break ;
2004-04-07 12:43:44 +00:00
case ' A ' :
if ( ! wbinfo_allocate_rid ( ) ) {
d_printf ( " Could not allocate a RID \n " ) ;
goto done ;
}
break ;
2000-07-05 11:24:26 +00:00
case ' t ' :
if ( ! wbinfo_check_secret ( ) ) {
2002-03-01 01:13:42 +00:00
d_printf ( " Could not check secret \n " ) ;
2002-04-04 06:40:17 +00:00
goto done ;
2000-07-05 11:24:26 +00:00
}
break ;
case ' m ' :
if ( ! wbinfo_list_domains ( ) ) {
2002-03-01 01:13:42 +00:00
d_printf ( " Could not list trusted domains \n " ) ;
2002-04-04 06:40:17 +00:00
goto done ;
2000-07-05 11:24:26 +00:00
}
break ;
2002-01-31 11:49:29 +00:00
case OPT_SEQUENCE :
2003-08-10 22:01:11 +00:00
if ( ! wbinfo_show_sequence ( opt_domain_name ) ) {
2002-03-01 01:13:42 +00:00
d_printf ( " Could not show sequence numbers \n " ) ;
2002-04-04 06:40:17 +00:00
goto done ;
2002-01-31 11:49:29 +00:00
}
break ;
2004-01-04 11:51:31 +00:00
case ' D ' :
if ( ! wbinfo_domain_info ( string_arg ) ) {
d_printf ( " Could not get domain info \n " ) ;
goto done ;
}
break ;
2000-10-11 05:25:32 +00:00
case ' r ' :
2001-12-11 05:18:36 +00:00
if ( ! wbinfo_get_usergroups ( string_arg ) ) {
2002-03-01 01:13:42 +00:00
d_printf ( " Could not get groups for user %s \n " ,
2001-12-11 05:18:36 +00:00
string_arg ) ;
2002-04-04 06:40:17 +00:00
goto done ;
2000-10-11 05:25:32 +00:00
}
break ;
2003-11-19 08:11:14 +00:00
case OPT_USERSIDS :
if ( ! wbinfo_get_usersids ( string_arg ) ) {
d_printf ( " Could not get group SIDs for user SID %s \n " ,
string_arg ) ;
goto done ;
}
break ;
2002-10-29 17:36:50 +00:00
case ' a ' : {
2003-07-08 03:16:28 +00:00
BOOL got_error = False ;
if ( ! wbinfo_auth ( string_arg ) ) {
d_printf ( " Could not authenticate user %s with "
" plaintext password \n " , string_arg ) ;
got_error = True ;
}
if ( ! wbinfo_auth_crap ( string_arg ) ) {
d_printf ( " Could not authenticate user %s with "
" challenge/response \n " , string_arg ) ;
got_error = True ;
}
if ( got_error )
goto done ;
break ;
}
2004-04-01 12:31:50 +00:00
case ' k ' :
if ( ! wbinfo_klog ( string_arg ) ) {
d_printf ( " Could not klog user \n " ) ;
goto done ;
}
break ;
2003-07-09 16:44:47 +00:00
case ' c ' :
if ( ! wbinfo_create_user ( string_arg ) ) {
d_printf ( " Could not create user account \n " ) ;
goto done ;
}
break ;
case ' C ' :
if ( ! wbinfo_create_group ( string_arg ) ) {
d_printf ( " Could not create group \n " ) ;
goto done ;
}
break ;
case ' o ' :
if ( ! wbinfo_add_user_to_group ( string_arg ) ) {
d_printf ( " Could not add user to group \n " ) ;
goto done ;
}
break ;
case ' O ' :
if ( ! wbinfo_remove_user_from_group ( string_arg ) ) {
2004-03-07 08:16:10 +00:00
d_printf ( " Could not remove user from group \n " ) ;
2003-07-09 16:44:47 +00:00
goto done ;
}
break ;
2003-07-11 05:33:40 +00:00
case ' x ' :
if ( ! wbinfo_delete_user ( string_arg ) ) {
d_printf ( " Could not delete user account \n " ) ;
goto done ;
}
break ;
case ' X ' :
if ( ! wbinfo_delete_group ( string_arg ) ) {
d_printf ( " Could not delete group \n " ) ;
goto done ;
}
break ;
2003-07-25 01:18:10 +00:00
case ' p ' :
2003-07-08 03:16:28 +00:00
if ( ! wbinfo_ping ( ) ) {
d_printf ( " could not ping winbindd! \n " ) ;
goto done ;
}
break ;
2001-12-11 05:18:36 +00:00
case OPT_SET_AUTH_USER :
2002-11-02 01:51:53 +00:00
wbinfo_set_auth_user ( string_arg ) ;
break ;
case OPT_GET_AUTH_USER :
wbinfo_get_auth_user ( ) ;
2001-12-11 05:18:36 +00:00
break ;
2003-08-10 22:01:11 +00:00
/* generic configuration options */
case OPT_DOMAIN_NAME :
break ;
2000-07-05 11:24:26 +00:00
default :
2002-03-01 01:13:42 +00:00
d_fprintf ( stderr , " Invalid option \n " ) ;
2002-09-25 15:19:00 +00:00
poptPrintHelp ( pc , stderr , 0 ) ;
2002-04-04 06:40:17 +00:00
goto done ;
2000-07-05 11:24:26 +00:00
}
}
2001-12-11 05:18:36 +00:00
2002-04-04 06:40:17 +00:00
result = 0 ;
/* Exit code */
2000-07-05 11:24:26 +00:00
2002-04-04 06:40:17 +00:00
done :
poptFreeContext ( pc ) ;
return result ;
2000-07-05 11:24:26 +00:00
}