0001-01-01 02:30:17 +02:30
/*
Samba Unix / Linux SMB client library
Distributed SMB / CIFS Server Management Utility
Copyright ( C ) 2001 Steve French ( sfrench @ us . ibm . com )
Copyright ( C ) 2001 Jim McDonough ( jmcd @ us . ibm . com )
0001-01-01 02:30:17 +02:30
Copyright ( C ) 2001 Andrew Tridgell ( tridge @ samba . org )
0001-01-01 02:30:17 +02:30
Copyright ( C ) 2001 Andrew Bartlett ( abartlet @ samba . org )
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
Originally written by Steve and Jim . Largely rewritten by tridge in
November 2001.
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
Reworked again by abartlet in December 2001
0001-01-01 02:30:17 +02:30
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
0001-01-01 02:30:17 +02:30
Foundation , Inc . , 675 Mass Ave , Cambridge , MA 0213 9 , USA . */
0001-01-01 02:30:17 +02:30
/*****************************************************/
/* */
/* Distributed SMB/CIFS Server Management Utility */
/* */
/* The intent was to make the syntax similar */
/* to the NET utility (first developed in DOS */
/* with additional interesting & useful functions */
/* added in later SMB server network operating */
/* systems). */
/* */
/*****************************************************/
0001-01-01 02:30:17 +02:30
# include "includes.h"
0001-01-01 02:30:17 +02:30
# include "../utils/net.h"
0001-01-01 02:30:17 +02:30
/***********************************************************************/
/* Beginning of internationalization section. Translatable constants */
/* should be kept in this area and referenced in the rest of the code. */
/* */
/* No functions, outside of Samba or LSB (Linux Standards Base) should */
/* be used (if possible). */
/***********************************************************************/
# define YES_STRING "Yes"
# define NO_STRING "No"
/************************************************************************************/
/* end of internationalization section */
/************************************************************************************/
0001-01-01 02:30:17 +02:30
/* Yes, these buggers are globals.... */
0001-01-01 02:30:17 +02:30
const char * opt_requester_name = NULL ;
const char * opt_host = NULL ;
const char * opt_password = NULL ;
const char * opt_user_name = NULL ;
0001-01-01 02:30:17 +02:30
BOOL opt_user_specified = False ;
0001-01-01 02:30:17 +02:30
const char * opt_workgroup = NULL ;
0001-01-01 02:30:17 +02:30
int opt_long_list_entries = 0 ;
0001-01-01 02:30:17 +02:30
int opt_reboot = 0 ;
int opt_force = 0 ;
0001-01-01 02:30:17 +02:30
int opt_port = 0 ;
int opt_maxusers = - 1 ;
0001-01-01 02:30:17 +02:30
const char * opt_comment = " " ;
0001-01-01 02:30:17 +02:30
char * opt_container = " cn=Users " ;
0001-01-01 02:30:17 +02:30
int opt_flags = - 1 ;
int opt_jobid = 0 ;
0001-01-01 02:30:17 +02:30
int opt_timeout = 0 ;
0001-01-01 02:30:17 +02:30
const char * opt_target_workgroup = NULL ;
0001-01-01 02:30:17 +02:30
static int opt_machine_pass = 0 ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
BOOL opt_have_ip = False ;
struct in_addr opt_dest_ip ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
extern BOOL AllowDebugChange ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
/*
run a function from a function table . If not found then
call the specified usage function
*/
0001-01-01 02:30:17 +02:30
int net_run_function ( int argc , const char * * argv , struct functable * table ,
0001-01-01 02:30:17 +02:30
int ( * usage_fn ) ( int argc , const char * * argv ) )
0001-01-01 02:30:17 +02:30
{
0001-01-01 02:30:17 +02:30
int i ;
0001-01-01 02:30:17 +02:30
if ( argc < 1 ) {
d_printf ( " \n Usage: \n " ) ;
0001-01-01 02:30:17 +02:30
return usage_fn ( argc , argv ) ;
0001-01-01 02:30:17 +02:30
}
0001-01-01 02:30:17 +02:30
for ( i = 0 ; table [ i ] . funcname ; i + + ) {
0001-01-01 02:30:17 +02:30
if ( StrCaseCmp ( argv [ 0 ] , table [ i ] . funcname ) = = 0 )
0001-01-01 02:30:17 +02:30
return table [ i ] . fn ( argc - 1 , argv + 1 ) ;
}
d_printf ( " No command: %s \n " , argv [ 0 ] ) ;
0001-01-01 02:30:17 +02:30
return usage_fn ( argc , argv ) ;
0001-01-01 02:30:17 +02:30
}
/****************************************************************************
0001-01-01 02:30:17 +02:30
connect to \ \ server \ ipc $
0001-01-01 02:30:17 +02:30
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
0001-01-01 02:30:17 +02:30
NTSTATUS connect_to_ipc ( struct cli_state * * c , struct in_addr * server_ip ,
const char * server_name )
0001-01-01 02:30:17 +02:30
{
0001-01-01 02:30:17 +02:30
NTSTATUS nt_status ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
if ( ! opt_password ) {
0001-01-01 02:30:17 +02:30
char * pass = getpass ( " Password: " ) ;
0001-01-01 02:30:17 +02:30
if ( pass ) {
opt_password = strdup ( pass ) ;
}
}
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
nt_status = cli_full_connection ( c , opt_requester_name , server_name ,
0001-01-01 02:30:17 +02:30
server_ip , opt_port ,
" IPC$ " , " IPC " ,
opt_user_name , opt_workgroup ,
0001-01-01 02:30:17 +02:30
opt_password , 0 , NULL ) ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
if ( NT_STATUS_IS_OK ( nt_status ) ) {
0001-01-01 02:30:17 +02:30
return nt_status ;
0001-01-01 02:30:17 +02:30
} else {
0001-01-01 02:30:17 +02:30
DEBUG ( 1 , ( " Cannot connect to server. Error was %s \n " ,
0001-01-01 02:30:17 +02:30
nt_errstr ( nt_status ) ) ) ;
0001-01-01 02:30:17 +02:30
/* Display a nicer message depending on the result */
if ( NT_STATUS_V ( nt_status ) = =
NT_STATUS_V ( NT_STATUS_LOGON_FAILURE ) )
d_printf ( " The username or password was not correct. \n " ) ;
0001-01-01 02:30:17 +02:30
return nt_status ;
0001-01-01 02:30:17 +02:30
}
}
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
/****************************************************************************
connect to \ \ server \ ipc $ anonymously
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
0001-01-01 02:30:17 +02:30
NTSTATUS connect_to_ipc_anonymous ( struct cli_state * * c ,
struct in_addr * server_ip , const char * server_name )
0001-01-01 02:30:17 +02:30
{
NTSTATUS nt_status ;
0001-01-01 02:30:17 +02:30
nt_status = cli_full_connection ( c , opt_requester_name , server_name ,
0001-01-01 02:30:17 +02:30
server_ip , opt_port ,
" IPC$ " , " IPC " ,
" " , " " ,
0001-01-01 02:30:17 +02:30
" " , 0 , NULL ) ;
0001-01-01 02:30:17 +02:30
if ( NT_STATUS_IS_OK ( nt_status ) ) {
0001-01-01 02:30:17 +02:30
return nt_status ;
0001-01-01 02:30:17 +02:30
} else {
0001-01-01 02:30:17 +02:30
DEBUG ( 1 , ( " Cannot connect to server (anonymously). Error was %s \n " , nt_errstr ( nt_status ) ) ) ;
0001-01-01 02:30:17 +02:30
return nt_status ;
0001-01-01 02:30:17 +02:30
}
}
0001-01-01 02:30:17 +02:30
BOOL net_find_server ( unsigned flags , struct in_addr * server_ip , char * * server_name )
0001-01-01 02:30:17 +02:30
{
0001-01-01 02:30:17 +02:30
if ( opt_host ) {
0001-01-01 02:30:17 +02:30
* server_name = strdup ( opt_host ) ;
0001-01-01 02:30:17 +02:30
}
0001-01-01 02:30:17 +02:30
if ( opt_have_ip ) {
* server_ip = opt_dest_ip ;
0001-01-01 02:30:17 +02:30
if ( ! * server_name ) {
0001-01-01 02:30:17 +02:30
* server_name = strdup ( inet_ntoa ( opt_dest_ip ) ) ;
0001-01-01 02:30:17 +02:30
}
0001-01-01 02:30:17 +02:30
} else if ( * server_name ) {
0001-01-01 02:30:17 +02:30
/* resolve the IP address */
0001-01-01 02:30:17 +02:30
if ( ! resolve_name ( * server_name , server_ip , 0x20 ) ) {
0001-01-01 02:30:17 +02:30
DEBUG ( 1 , ( " Unable to resolve server name \n " ) ) ;
0001-01-01 02:30:17 +02:30
return False ;
0001-01-01 02:30:17 +02:30
}
0001-01-01 02:30:17 +02:30
} else if ( flags & NET_FLAGS_PDC ) {
0001-01-01 02:30:17 +02:30
struct in_addr pdc_ip ;
if ( get_pdc_ip ( opt_target_workgroup , & pdc_ip ) ) {
0001-01-01 02:30:17 +02:30
fstring dc_name ;
0001-01-01 02:30:17 +02:30
if ( is_zero_ip ( pdc_ip ) )
0001-01-01 02:30:17 +02:30
return False ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
if ( ! lookup_dc_name ( global_myname ( ) , opt_target_workgroup , & pdc_ip , dc_name ) )
0001-01-01 02:30:17 +02:30
return False ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
* server_name = strdup ( dc_name ) ;
0001-01-01 02:30:17 +02:30
* server_ip = pdc_ip ;
0001-01-01 02:30:17 +02:30
}
0001-01-01 02:30:17 +02:30
} else if ( flags & NET_FLAGS_DMB ) {
struct in_addr msbrow_ip ;
/* if (!resolve_name(MSBROWSE, &msbrow_ip, 1)) */
if ( ! resolve_name ( opt_target_workgroup , & msbrow_ip , 0x1B ) ) {
DEBUG ( 1 , ( " Unable to resolve domain browser via name lookup \n " ) ) ;
0001-01-01 02:30:17 +02:30
return False ;
0001-01-01 02:30:17 +02:30
} else {
0001-01-01 02:30:17 +02:30
* server_ip = msbrow_ip ;
0001-01-01 02:30:17 +02:30
}
0001-01-01 02:30:17 +02:30
* server_name = strdup ( inet_ntoa ( opt_dest_ip ) ) ;
0001-01-01 02:30:17 +02:30
} else if ( flags & NET_FLAGS_MASTER ) {
0001-01-01 02:30:17 +02:30
struct in_addr brow_ips ;
0001-01-01 02:30:17 +02:30
if ( ! resolve_name ( opt_target_workgroup , & brow_ips , 0x1D ) ) {
0001-01-01 02:30:17 +02:30
/* go looking for workgroups */
DEBUG ( 1 , ( " Unable to resolve master browser via name lookup \n " ) ) ;
0001-01-01 02:30:17 +02:30
return False ;
0001-01-01 02:30:17 +02:30
} else {
0001-01-01 02:30:17 +02:30
* server_ip = brow_ips ;
0001-01-01 02:30:17 +02:30
}
0001-01-01 02:30:17 +02:30
* server_name = strdup ( inet_ntoa ( opt_dest_ip ) ) ;
0001-01-01 02:30:17 +02:30
} else if ( ! ( flags & NET_FLAGS_LOCALHOST_DEFAULT_INSANE ) ) {
0001-01-01 02:30:17 +02:30
extern struct in_addr loopback_ip ;
0001-01-01 02:30:17 +02:30
* server_ip = loopback_ip ;
* server_name = strdup ( " 127.0.0.1 " ) ;
0001-01-01 02:30:17 +02:30
}
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
if ( ! server_name | | ! * server_name ) {
0001-01-01 02:30:17 +02:30
DEBUG ( 1 , ( " no server to connect to \n " ) ) ;
0001-01-01 02:30:17 +02:30
return False ;
0001-01-01 02:30:17 +02:30
}
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
return True ;
}
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
BOOL net_find_dc ( struct in_addr * server_ip , fstring server_name , const char * domain_name )
0001-01-01 02:30:17 +02:30
{
0001-01-01 02:30:17 +02:30
if ( get_pdc_ip ( domain_name , server_ip ) ) {
0001-01-01 02:30:17 +02:30
fstring dc_name ;
if ( is_zero_ip ( * server_ip ) )
return False ;
0001-01-01 02:30:17 +02:30
if ( ! lookup_dc_name ( global_myname ( ) , domain_name , server_ip , dc_name ) )
0001-01-01 02:30:17 +02:30
return False ;
safe_strcpy ( server_name , dc_name , FSTRING_LEN ) ;
return True ;
} else
return False ;
}
0001-01-01 02:30:17 +02:30
struct cli_state * net_make_ipc_connection ( unsigned flags )
{
char * server_name = NULL ;
struct in_addr server_ip ;
0001-01-01 02:30:17 +02:30
struct cli_state * cli = NULL ;
NTSTATUS nt_status ;
0001-01-01 02:30:17 +02:30
if ( ! net_find_server ( flags , & server_ip , & server_name ) ) {
d_printf ( " \n Unable to find a suitable server \n " ) ;
return NULL ;
}
0001-01-01 02:30:17 +02:30
if ( flags & NET_FLAGS_ANONYMOUS ) {
0001-01-01 02:30:17 +02:30
nt_status = connect_to_ipc_anonymous ( & cli , & server_ip , server_name ) ;
0001-01-01 02:30:17 +02:30
} else {
0001-01-01 02:30:17 +02:30
nt_status = connect_to_ipc ( & cli , & server_ip , server_name ) ;
0001-01-01 02:30:17 +02:30
}
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
SAFE_FREE ( server_name ) ;
0001-01-01 02:30:17 +02:30
if ( NT_STATUS_IS_OK ( nt_status ) ) {
return cli ;
} else {
return NULL ;
}
0001-01-01 02:30:17 +02:30
}
0001-01-01 02:30:17 +02:30
static int net_user ( int argc , const char * * argv )
{
if ( net_ads_check ( ) = = 0 )
return net_ads_user ( argc , argv ) ;
0001-01-01 02:30:17 +02:30
/* if server is not specified, default to PDC? */
if ( net_rpc_check ( NET_FLAGS_PDC ) )
return net_rpc_user ( argc , argv ) ;
0001-01-01 02:30:17 +02:30
return net_rap_user ( argc , argv ) ;
}
0001-01-01 02:30:17 +02:30
static int net_group ( int argc , const char * * argv )
{
if ( net_ads_check ( ) = = 0 )
return net_ads_group ( argc , argv ) ;
if ( argc = = 0 & & net_rpc_check ( NET_FLAGS_PDC ) )
return net_rpc_group ( argc , argv ) ;
return net_rap_group ( argc , argv ) ;
}
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
static int net_join ( int argc , const char * * argv )
{
0001-01-01 02:30:17 +02:30
if ( net_ads_check ( ) = = 0 ) {
0001-01-01 02:30:17 +02:30
if ( net_ads_join ( argc , argv ) = = 0 )
return 0 ;
else
d_printf ( " ADS join did not work, trying RPC... \n " ) ;
}
return net_rpc_join ( argc , argv ) ;
}
0001-01-01 02:30:17 +02:30
static int net_share ( int argc , const char * * argv )
{
if ( net_rpc_check ( 0 ) )
return net_rpc_share ( argc , argv ) ;
return net_rap_share ( argc , argv ) ;
}
static int net_file ( int argc , const char * * argv )
{
if ( net_rpc_check ( 0 ) )
return net_rpc_file ( argc , argv ) ;
return net_rap_file ( argc , argv ) ;
}
0001-01-01 02:30:17 +02:30
/*
Retrieve our local SID or the SID for the specified name
*/
static int net_getlocalsid ( int argc , const char * * argv )
{
DOM_SID sid ;
const char * name ;
fstring sid_str ;
if ( argc > = 1 ) {
name = argv [ 0 ] ;
}
else {
0001-01-01 02:30:17 +02:30
name = global_myname ( ) ;
0001-01-01 02:30:17 +02:30
}
if ( ! secrets_fetch_domain_sid ( name , & sid ) ) {
DEBUG ( 0 , ( " Can't fetch domain SID for name: %s \n " , name ) ) ;
return 1 ;
}
sid_to_string ( sid_str , & sid ) ;
d_printf ( " SID for domain %s is: %s \n " , name , sid_str ) ;
return 0 ;
}
static int net_setlocalsid ( int argc , const char * * argv )
{
DOM_SID sid ;
if ( ( argc ! = 1 )
| | ( strncmp ( argv [ 0 ] , " S-1-5-21- " , strlen ( " S-1-5-21- " ) ) ! = 0 )
| | ( ! string_to_sid ( & sid , argv [ 0 ] ) )
| | ( sid . num_auths ! = 4 ) ) {
d_printf ( " usage: net setlocalsid S-1-5-21-x-y-z \n " ) ;
return 1 ;
}
0001-01-01 02:30:17 +02:30
if ( ! secrets_store_domain_sid ( global_myname ( ) , & sid ) ) {
0001-01-01 02:30:17 +02:30
DEBUG ( 0 , ( " Can't store domain SID as a pdc/bdc. \n " ) ) ;
return 1 ;
}
return 0 ;
}
static int net_getdomainsid ( int argc , const char * * argv )
{
DOM_SID domain_sid ;
fstring sid_str ;
0001-01-01 02:30:17 +02:30
if ( ! secrets_fetch_domain_sid ( global_myname ( ) , & domain_sid ) ) {
0001-01-01 02:30:17 +02:30
d_printf ( " Could not fetch local SID \n " ) ;
return 1 ;
}
sid_to_string ( sid_str , & domain_sid ) ;
0001-01-01 02:30:17 +02:30
d_printf ( " SID for domain %s is: %s \n " , global_myname ( ) , sid_str ) ;
0001-01-01 02:30:17 +02:30
if ( ! secrets_fetch_domain_sid ( lp_workgroup ( ) , & domain_sid ) ) {
d_printf ( " Could not fetch domain SID \n " ) ;
return 1 ;
}
sid_to_string ( sid_str , & domain_sid ) ;
d_printf ( " SID for domain %s is: %s \n " , lp_workgroup ( ) , sid_str ) ;
return 0 ;
}
0001-01-01 02:30:17 +02:30
/* main function table */
static struct functable net_func [ ] = {
0001-01-01 02:30:17 +02:30
{ " RPC " , net_rpc } ,
{ " RAP " , net_rap } ,
0001-01-01 02:30:17 +02:30
{ " ADS " , net_ads } ,
0001-01-01 02:30:17 +02:30
/* eventually these should auto-choose the transport ... */
0001-01-01 02:30:17 +02:30
{ " FILE " , net_file } ,
{ " SHARE " , net_share } ,
0001-01-01 02:30:17 +02:30
{ " SESSION " , net_rap_session } ,
{ " SERVER " , net_rap_server } ,
{ " DOMAIN " , net_rap_domain } ,
{ " PRINTQ " , net_rap_printq } ,
0001-01-01 02:30:17 +02:30
{ " USER " , net_user } ,
0001-01-01 02:30:17 +02:30
{ " GROUP " , net_group } ,
0001-01-01 02:30:17 +02:30
{ " VALIDATE " , net_rap_validate } ,
{ " GROUPMEMBER " , net_rap_groupmember } ,
{ " ADMIN " , net_rap_admin } ,
{ " SERVICE " , net_rap_service } ,
{ " PASSWORD " , net_rap_password } ,
0001-01-01 02:30:17 +02:30
{ " TIME " , net_time } ,
0001-01-01 02:30:17 +02:30
{ " LOOKUP " , net_lookup } ,
0001-01-01 02:30:17 +02:30
{ " JOIN " , net_join } ,
0001-01-01 02:30:17 +02:30
{ " CACHE " , net_cache } ,
{ " GETLOCALSID " , net_getlocalsid } ,
{ " SETLOCALSID " , net_setlocalsid } ,
{ " GETDOMAINSID " , net_getdomainsid } ,
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
{ " HELP " , net_help } ,
{ NULL , NULL }
} ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
/****************************************************************************
main program
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
0001-01-01 02:30:17 +02:30
int main ( int argc , const char * * argv )
0001-01-01 02:30:17 +02:30
{
0001-01-01 02:30:17 +02:30
int opt , i ;
char * p ;
int rc = 0 ;
int argc_new = 0 ;
const char * * argv_new ;
poptContext pc ;
0001-01-01 02:30:17 +02:30
static char * servicesf = dyn_CONFIGFILE ;
0001-01-01 02:30:17 +02:30
static char * debuglevel = NULL ;
0001-01-01 02:30:17 +02:30
struct poptOption long_options [ ] = {
0001-01-01 02:30:17 +02:30
{ " help " , ' h ' , POPT_ARG_NONE , 0 , ' h ' } ,
{ " workgroup " , ' w ' , POPT_ARG_STRING , & opt_target_workgroup } ,
{ " myworkgroup " , ' W ' , POPT_ARG_STRING , & opt_workgroup } ,
{ " user " , ' U ' , POPT_ARG_STRING , & opt_user_name , ' U ' } ,
{ " ipaddress " , ' I ' , POPT_ARG_STRING , 0 , ' I ' } ,
{ " port " , ' p ' , POPT_ARG_INT , & opt_port } ,
{ " myname " , ' n ' , POPT_ARG_STRING , & opt_requester_name } ,
{ " conf " , ' s ' , POPT_ARG_STRING , & servicesf } ,
{ " server " , ' S ' , POPT_ARG_STRING , & opt_host } ,
0001-01-01 02:30:17 +02:30
{ " container " , ' c ' , POPT_ARG_STRING , & opt_container } ,
0001-01-01 02:30:17 +02:30
{ " comment " , ' C ' , POPT_ARG_STRING , & opt_comment } ,
{ " maxusers " , ' M ' , POPT_ARG_INT , & opt_maxusers } ,
{ " flags " , ' F ' , POPT_ARG_INT , & opt_flags } ,
{ " jobid " , ' j ' , POPT_ARG_INT , & opt_jobid } ,
{ " long " , ' l ' , POPT_ARG_NONE , & opt_long_list_entries } ,
{ " reboot " , ' r ' , POPT_ARG_NONE , & opt_reboot } ,
{ " force " , ' f ' , POPT_ARG_NONE , & opt_force } ,
{ " timeout " , ' t ' , POPT_ARG_INT , & opt_timeout } ,
0001-01-01 02:30:17 +02:30
{ " machine-pass " , ' P ' , POPT_ARG_NONE , & opt_machine_pass } ,
0001-01-01 02:30:17 +02:30
{ " debuglevel " , ' D ' , POPT_ARG_STRING , & debuglevel } ,
0001-01-01 02:30:17 +02:30
{ 0 , 0 , 0 , 0 }
} ;
0001-01-01 02:30:17 +02:30
zero_ip ( & opt_dest_ip ) ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
dbf = x_stderr ;
0001-01-01 02:30:17 +02:30
pc = poptGetContext ( NULL , argc , ( const char * * ) argv , long_options ,
POPT_CONTEXT_KEEP_FIRST ) ;
while ( ( opt = poptGetNextOpt ( pc ) ) ! = - 1 ) {
switch ( opt ) {
case ' h ' :
0001-01-01 02:30:17 +02:30
net_help ( argc , argv ) ;
0001-01-01 02:30:17 +02:30
exit ( 0 ) ;
break ;
case ' I ' :
0001-01-01 02:30:17 +02:30
opt_dest_ip = * interpret_addr2 ( poptGetOptArg ( pc ) ) ;
if ( is_zero_ip ( opt_dest_ip ) )
0001-01-01 02:30:17 +02:30
d_printf ( " \n Invalid ip address specified \n " ) ;
0001-01-01 02:30:17 +02:30
else
0001-01-01 02:30:17 +02:30
opt_have_ip = True ;
0001-01-01 02:30:17 +02:30
break ;
case ' U ' :
0001-01-01 02:30:17 +02:30
opt_user_specified = True ;
0001-01-01 02:30:17 +02:30
opt_user_name = strdup ( opt_user_name ) ;
p = strchr ( opt_user_name , ' % ' ) ;
if ( p ) {
* p = 0 ;
opt_password = p + 1 ;
}
break ;
default :
0001-01-01 02:30:17 +02:30
d_printf ( " \n Invalid option %c (%d) \n " , ( char ) opt , opt ) ;
0001-01-01 02:30:17 +02:30
net_help ( argc , argv ) ;
0001-01-01 02:30:17 +02:30
exit ( 1 ) ;
0001-01-01 02:30:17 +02:30
}
0001-01-01 02:30:17 +02:30
}
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
if ( debuglevel ) {
debug_parse_levels ( debuglevel ) ;
AllowDebugChange = False ;
}
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
lp_load ( servicesf , True , False , False ) ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
argv_new = ( const char * * ) poptGetArgs ( pc ) ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
argc_new = argc ;
for ( i = 0 ; i < argc ; i + + ) {
if ( argv_new [ i ] = = NULL ) {
argc_new = i ;
break ;
}
}
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
if ( ! opt_requester_name ) {
static fstring myname ;
get_myname ( myname ) ;
opt_requester_name = myname ;
}
if ( ! opt_user_name & & getenv ( " LOGNAME " ) ) {
opt_user_name = getenv ( " LOGNAME " ) ;
}
if ( ! opt_workgroup ) {
opt_workgroup = lp_workgroup ( ) ;
}
0001-01-01 02:30:17 +02:30
if ( ! opt_target_workgroup ) {
0001-01-01 02:30:17 +02:30
opt_target_workgroup = strdup ( lp_workgroup ( ) ) ;
0001-01-01 02:30:17 +02:30
}
0001-01-01 02:30:17 +02:30
if ( ! init_names ( ) )
exit ( 1 ) ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
load_interfaces ( ) ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
if ( opt_machine_pass ) {
0001-01-01 02:30:17 +02:30
char * user ;
0001-01-01 02:30:17 +02:30
/* it is very useful to be able to make ads queries as the
machine account for testing purposes and for domain leave */
if ( ! secrets_init ( ) ) {
d_printf ( " ERROR: Unable to open secrets database \n " ) ;
exit ( 1 ) ;
}
0001-01-01 02:30:17 +02:30
asprintf ( & user , " %s$ " , global_myname ( ) ) ;
opt_user_name = user ;
0001-01-01 02:30:17 +02:30
opt_password = secrets_fetch_machine_password ( ) ;
if ( ! opt_password ) {
d_printf ( " ERROR: Unable to fetch machine password \n " ) ;
exit ( 1 ) ;
}
}
0001-01-01 02:30:17 +02:30
rc = net_run_function ( argc_new - 1 , argv_new + 1 , net_func , net_help ) ;
0001-01-01 02:30:17 +02:30
DEBUG ( 2 , ( " return code = %d \n " , rc ) ) ;
return rc ;
}