2008-05-08 11:14:16 +04:00
/*
Samba Unix / Linux SMB client library
Distributed SMB / CIFS Server Management Utility
2001-10-19 20:51:26 +04:00
Copyright ( C ) 2001 Steve French ( sfrench @ us . ibm . com )
Copyright ( C ) 2001 Jim McDonough ( jmcd @ us . ibm . com )
2001-11-24 16:26:01 +03:00
Copyright ( C ) 2001 Andrew Tridgell ( tridge @ samba . org )
2001-12-03 07:39:23 +03:00
Copyright ( C ) 2001 Andrew Bartlett ( abartlet @ samba . org )
2008-05-10 01:22:12 +04:00
Copyright ( C ) 2008 Kai Blin ( kai @ samba . org )
2001-10-19 20:51:26 +04:00
2001-11-24 16:26:01 +03:00
Originally written by Steve and Jim . Largely rewritten by tridge in
November 2001.
2001-10-19 20:51:26 +04:00
2001-12-03 07:39:23 +03:00
Reworked again by abartlet in December 2001
2008-05-10 01:22:12 +04:00
Another overhaul , moving functionality into plug - ins loaded on demand by Kai
in May 2008.
2001-10-19 20:51:26 +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
2001-10-19 20:51:26 +04:00
( at your option ) any later version .
2008-05-08 11:14:16 +04:00
2001-10-19 20:51:26 +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 .
2008-05-08 11:14:16 +04:00
2001-10-19 20:51:26 +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/>. */
2008-05-08 11:14:16 +04:00
2001-10-19 20:51:26 +04:00
/*****************************************************/
/* */
/* 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). */
/* */
/*****************************************************/
2001-11-25 03:18:11 +03:00
# include "includes.h"
2004-10-07 08:01:18 +04:00
# include "utils/net.h"
2001-10-19 20:51:26 +04:00
2008-06-05 20:40:26 +04:00
extern bool AllowDebugChange ;
2008-05-14 11:01:53 +04:00
# ifdef WITH_FAKE_KASERVER
# include "utils/net_afs.h"
# endif
2001-10-19 20:51:26 +04:00
/***********************************************************************/
/* 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"
2008-05-08 11:14:16 +04:00
/***********************************************************************/
/* end of internationalization section */
/***********************************************************************/
2001-10-19 20:51:26 +04:00
2008-05-08 11:14:16 +04:00
uint32 get_sec_channel_type ( const char * param )
2003-04-21 18:09:03 +04:00
{
if ( ! ( param & & * param ) ) {
return get_default_sec_channel ( ) ;
} else {
2003-10-23 03:38:20 +04:00
if ( strequal ( param , " PDC " ) ) {
2003-04-21 18:09:03 +04:00
return SEC_CHAN_BDC ;
2003-10-23 03:38:20 +04:00
} else if ( strequal ( param , " BDC " ) ) {
2003-04-21 18:09:03 +04:00
return SEC_CHAN_BDC ;
2003-10-23 03:38:20 +04:00
} else if ( strequal ( param , " MEMBER " ) ) {
2003-04-21 18:09:03 +04:00
return SEC_CHAN_WKSTA ;
2008-05-08 11:14:16 +04:00
#if 0
2003-10-23 03:38:20 +04:00
} else if ( strequal ( param , " DOMAIN " ) ) {
2003-04-21 18:09:03 +04:00
return SEC_CHAN_DOMAIN ;
# endif
} else {
return get_default_sec_channel ( ) ;
}
}
}
2008-05-10 01:22:12 +04:00
static int net_changetrustpw ( struct net_context * c , int argc , const char * * argv )
2003-04-15 02:27:09 +04:00
{
2008-05-10 01:22:12 +04:00
if ( net_ads_check_our_domain ( c ) = = 0 )
return net_ads_changetrustpw ( c , argc , argv ) ;
2003-04-15 02:27:09 +04:00
2008-05-10 01:22:12 +04:00
return net_rpc_changetrustpw ( c , argc , argv ) ;
2003-04-15 02:27:09 +04:00
}
2006-05-31 02:10:09 +04:00
static void set_line_buffering ( FILE * f )
{
setvbuf ( f , NULL , _IOLBF , 0 ) ;
}
2008-05-10 01:22:12 +04:00
static int net_changesecretpw ( struct net_context * c , int argc ,
const char * * argv )
2003-08-29 00:24:25 +04:00
{
char * trust_pw ;
uint32 sec_channel_type = SEC_CHAN_WKSTA ;
2008-05-10 01:22:12 +04:00
if ( c - > opt_force ) {
if ( c - > opt_stdin ) {
2006-05-31 02:10:09 +04:00
set_line_buffering ( stdin ) ;
set_line_buffering ( stdout ) ;
set_line_buffering ( stderr ) ;
}
2006-07-11 22:01:26 +04:00
2008-05-10 01:22:12 +04:00
trust_pw = get_pass ( " Enter machine password: " , c - > opt_stdin ) ;
2003-08-29 00:24:25 +04:00
2007-03-13 23:53:38 +03:00
if ( ! secrets_store_machine_password ( trust_pw , lp_workgroup ( ) , sec_channel_type ) ) {
2006-01-18 00:22:00 +03:00
d_fprintf ( stderr , " Unable to write the machine account password in the secrets database " ) ;
2003-08-29 00:24:25 +04:00
return 1 ;
}
else {
d_printf ( " Modified trust account password in secrets database \n " ) ;
}
}
else {
d_printf ( " Machine account password change requires the -f flag. \n " ) ;
d_printf ( " Do NOT use this function unless you know what it does! \n " ) ;
d_printf ( " This function will change the ADS Domain member machine account password in the secrets.tdb file! \n " ) ;
}
return 0 ;
}
2002-09-25 19:19:00 +04:00
/*
Retrieve our local SID or the SID for the specified name
*/
2008-05-10 01:22:12 +04:00
static int net_getlocalsid ( struct net_context * c , int argc , const char * * argv )
2002-09-25 19:19:00 +04:00
{
DOM_SID sid ;
const char * name ;
fstring sid_str ;
if ( argc > = 1 ) {
name = argv [ 0 ] ;
}
else {
2002-11-13 02:20:50 +03:00
name = global_myname ( ) ;
2002-09-25 19:19:00 +04:00
}
2008-05-12 13:53:23 +04:00
if ( ! initialize_password_db ( false , NULL ) ) {
2004-02-26 01:01:02 +03:00
DEBUG ( 0 , ( " WARNING: Could not open passdb - local sid may not reflect passdb \n "
2007-10-03 16:55:45 +04:00
" backend knowledge (such as the sid stored in LDAP) \n " ) ) ;
2004-02-26 01:01:02 +03:00
}
2004-11-15 20:20:58 +03:00
/* first check to see if we can even access secrets, so we don't
panic when we can ' t . */
if ( ! secrets_init ( ) ) {
2006-01-18 00:22:00 +03:00
d_fprintf ( stderr , " Unable to open secrets.tdb. Can't fetch domain SID for name: %s \n " , name ) ;
2004-11-15 20:20:58 +03:00
return 1 ;
}
2004-02-26 02:12:29 +03:00
/* Generate one, if it doesn't exist */
get_global_sam_sid ( ) ;
2002-09-25 19:19:00 +04:00
if ( ! secrets_fetch_domain_sid ( name , & sid ) ) {
2004-11-15 20:20:58 +03:00
DEBUG ( 0 , ( " Can't fetch domain SID for name: %s \n " , name ) ) ;
2002-09-25 19:19:00 +04:00
return 1 ;
}
2007-12-16 00:47:30 +03:00
sid_to_fstring ( sid_str , & sid ) ;
2002-09-25 19:19:00 +04:00
d_printf ( " SID for domain %s is: %s \n " , name , sid_str ) ;
return 0 ;
}
2008-05-10 01:22:12 +04:00
static int net_setlocalsid ( struct net_context * c , int argc , const char * * argv )
2002-09-25 19:19:00 +04:00
{
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 ;
}
2002-11-13 02:20:50 +03:00
if ( ! secrets_store_domain_sid ( global_myname ( ) , & sid ) ) {
2002-09-25 19:19:00 +04:00
DEBUG ( 0 , ( " Can't store domain SID as a pdc/bdc. \n " ) ) ;
return 1 ;
}
return 0 ;
}
2008-05-10 01:22:12 +04:00
static int net_setdomainsid ( struct net_context * c , int argc , const char * * argv )
2006-05-16 21:40:28 +04:00
{
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 setdomainsid S-1-5-21-x-y-z \n " ) ;
return 1 ;
}
if ( ! secrets_store_domain_sid ( lp_workgroup ( ) , & sid ) ) {
DEBUG ( 0 , ( " Can't store domain SID. \n " ) ) ;
return 1 ;
}
return 0 ;
}
2008-05-10 01:22:12 +04:00
static int net_getdomainsid ( struct net_context * c , int argc , const char * * argv )
2002-09-25 19:19:00 +04:00
{
DOM_SID domain_sid ;
fstring sid_str ;
2007-12-06 15:54:45 +03:00
if ( argc > 0 ) {
d_printf ( " usage: net getdomainsid \n " ) ;
return 1 ;
}
2008-05-12 13:53:23 +04:00
if ( ! initialize_password_db ( false , NULL ) ) {
2007-12-06 15:54:45 +03:00
DEBUG ( 0 , ( " WARNING: Could not open passdb - domain SID may "
2007-12-03 12:45:47 +03:00
" not reflect passdb \n "
2007-12-06 15:54:45 +03:00
" backend knowledge (such as the SID stored in "
2007-12-03 12:45:47 +03:00
" LDAP) \n " ) ) ;
2007-10-03 16:55:45 +04:00
}
/* first check to see if we can even access secrets, so we don't
panic when we can ' t . */
if ( ! secrets_init ( ) ) {
d_fprintf ( stderr , " Unable to open secrets.tdb. Can't fetch domain "
" SID for name: %s \n " , get_global_sam_name ( ) ) ;
return 1 ;
2004-02-26 01:01:02 +03:00
}
2004-02-26 02:12:29 +03:00
/* Generate one, if it doesn't exist */
get_global_sam_sid ( ) ;
2002-11-13 02:20:50 +03:00
if ( ! secrets_fetch_domain_sid ( global_myname ( ) , & domain_sid ) ) {
2006-01-18 00:22:00 +03:00
d_fprintf ( stderr , " Could not fetch local SID \n " ) ;
2002-09-25 19:19:00 +04:00
return 1 ;
}
2007-12-16 00:47:30 +03:00
sid_to_fstring ( sid_str , & domain_sid ) ;
2007-12-06 15:54:45 +03:00
d_printf ( " SID for local machine %s is: %s \n " , global_myname ( ) , sid_str ) ;
2002-09-25 19:19:00 +04:00
2008-05-10 01:22:12 +04:00
if ( ! secrets_fetch_domain_sid ( c - > opt_workgroup , & domain_sid ) ) {
2006-01-18 00:22:00 +03:00
d_fprintf ( stderr , " Could not fetch domain SID \n " ) ;
2002-09-25 19:19:00 +04:00
return 1 ;
}
2007-12-16 00:47:30 +03:00
sid_to_fstring ( sid_str , & domain_sid ) ;
2008-05-10 01:22:12 +04:00
d_printf ( " SID for domain %s is: %s \n " , c - > opt_workgroup , sid_str ) ;
2002-09-25 19:19:00 +04:00
return 0 ;
}
2007-10-19 04:40:25 +04:00
static bool search_maxrid ( struct pdb_search * search , const char * type ,
2005-04-10 19:26:37 +04:00
uint32 * max_rid )
2003-01-15 20:22:48 +03:00
{
2005-04-10 19:26:37 +04:00
struct samr_displayentry * entries ;
uint32 i , num_entries ;
2003-01-15 20:22:48 +03:00
2005-04-10 19:26:37 +04:00
if ( search = = NULL ) {
2006-01-18 00:22:00 +03:00
d_fprintf ( stderr , " get_maxrid: Could not search %s \n " , type ) ;
2008-05-12 13:53:23 +04:00
return false ;
2003-01-15 20:22:48 +03:00
}
2005-04-10 19:26:37 +04:00
num_entries = pdb_search_entries ( search , 0 , 0xffffffff , & entries ) ;
for ( i = 0 ; i < num_entries ; i + + )
* max_rid = MAX ( * max_rid , entries [ i ] . rid ) ;
pdb_search_destroy ( search ) ;
2008-05-12 13:53:23 +04:00
return true ;
2005-04-10 19:26:37 +04:00
}
2003-01-15 20:22:48 +03:00
2005-04-10 19:26:37 +04:00
static uint32 get_maxrid ( void )
{
uint32 max_rid = 0 ;
2003-01-15 20:22:48 +03:00
2005-04-10 19:26:37 +04:00
if ( ! search_maxrid ( pdb_search_users ( 0 ) , " users " , & max_rid ) )
return 0 ;
2003-01-15 20:22:48 +03:00
2005-04-10 19:26:37 +04:00
if ( ! search_maxrid ( pdb_search_groups ( ) , " groups " , & max_rid ) )
return 0 ;
2003-01-15 20:22:48 +03:00
2005-04-10 19:26:37 +04:00
if ( ! search_maxrid ( pdb_search_aliases ( get_global_sam_sid ( ) ) ,
" aliases " , & max_rid ) )
return 0 ;
2008-05-08 11:14:16 +04:00
2003-01-15 20:22:48 +03:00
return max_rid ;
}
2008-05-10 01:22:12 +04:00
static int net_maxrid ( struct net_context * c , int argc , const char * * argv )
2003-01-15 20:22:48 +03:00
{
uint32 rid ;
if ( argc ! = 0 ) {
2003-04-14 07:59:04 +04:00
DEBUG ( 0 , ( " usage: net maxrid \n " ) ) ;
2003-01-15 20:22:48 +03:00
return 1 ;
}
if ( ( rid = get_maxrid ( ) ) = = 0 ) {
DEBUG ( 0 , ( " can't get current maximum rid \n " ) ) ;
return 1 ;
}
d_printf ( " Currently used maximum rid: %d \n " , rid ) ;
return 0 ;
}
2001-11-24 16:26:01 +03:00
/* main function table */
2008-05-18 21:12:24 +04:00
static struct functable2 net_func [ ] = {
{ " rpc " , net_rpc , " Run functions using RPC transport " } ,
{ " rap " , net_rap , " Run functions using RAP transport " } ,
{ " ads " , net_ads , " Run functions using ADS transport " } ,
2001-12-11 01:25:21 +03:00
/* eventually these should auto-choose the transport ... */
2008-05-18 21:12:24 +04:00
{ " file " , net_file , " Functions on remote opened files " } ,
{ " share " , net_share , " Functions on shares " } ,
{ " session " , net_rap_session , " FIXME " } ,
{ " server " , net_rap_server , " FIXME " } ,
{ " domain " , net_rap_domain , " FIXME " } ,
{ " printq " , net_rap_printq , " FIXME " } ,
{ " user " , net_user , " Manage users " } ,
{ " group " , net_group , " Manage groups " } ,
{ " groupmap " , net_groupmap , " Manage group mappings " } ,
{ " sam " , net_sam , " Functions on the SAM database " } ,
{ " validate " , net_rap_validate , " FIXME " } ,
{ " groupmember " , net_rap_groupmember , " FIXME " } ,
{ " admin " , net_rap_admin , " FIXME " } ,
{ " service " , net_rap_service , " FIXME " } ,
{ " password " , net_rap_password , " FIXME " } ,
{ " changetrustpw " , net_changetrustpw , " Change the trust password " } ,
{ " changesecretpw " , net_changesecretpw , " Change the secret password " } ,
{ " time " , net_time , " Show/set time " } ,
{ " lookup " , net_lookup , " Look up host names/IP addresses " } ,
{ " join " , net_join , " Join a domain/AD " } ,
{ " dom " , net_dom , " Join/unjoin (remote) machines to/from a domain/AD " } ,
{ " cache " , net_cache , " Operate on the cache tdb file " } ,
{ " getlocalsid " , net_getlocalsid , " Get the SID for the local domain " } ,
{ " setlocalsid " , net_setlocalsid , " Set the SID for the local domain " } ,
{ " setdomainsid " , net_setdomainsid , " Get domain SID on member servers " } ,
{ " getdomainsid " , net_getdomainsid , " Set domain SID on member servers " } ,
{ " maxrid " , net_maxrid , " Display the maximul RID currently used " } ,
{ " idmap " , net_idmap , " IDmap functions " } ,
{ " status " , net_status , " Display server status " } ,
{ " usershare " , net_usershare , " Manage user-modifiable shares " } ,
{ " usersidlist " , net_usersidlist , " Display list of all users with SID " } ,
{ " conf " , net_conf , " Manage Samba registry based configuration " } ,
{ " registry " , net_registry , " Manage the Samba registry " } ,
2003-09-07 20:36:13 +04:00
# ifdef WITH_FAKE_KASERVER
2008-05-18 21:12:24 +04:00
{ " afs " , net_afs , " FIXME " } ,
2003-09-07 20:36:13 +04:00
# endif
2001-12-11 01:25:21 +03:00
2008-05-18 21:12:24 +04:00
{ " help " , net_help , " Print usage information " } ,
{ NULL , NULL , NULL }
2001-11-24 16:26:01 +03:00
} ;
2001-11-13 01:50:48 +03:00
2001-10-19 20:51:26 +04:00
/****************************************************************************
main program
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2001-11-26 08:59:43 +03:00
int main ( int argc , const char * * argv )
2001-10-19 20:51:26 +04:00
{
2001-11-24 16:26:01 +03:00
int opt , i ;
char * p ;
int rc = 0 ;
int argc_new = 0 ;
const char * * argv_new ;
poptContext pc ;
2008-05-10 01:22:12 +04:00
TALLOC_CTX * frame = talloc_stackframe ( ) ;
struct net_context * c = talloc_zero ( frame , struct net_context ) ;
2001-11-24 16:26:01 +03:00
struct poptOption long_options [ ] = {
2002-03-15 23:03:07 +03:00
{ " help " , ' h ' , POPT_ARG_NONE , 0 , ' h ' } ,
2008-05-10 01:22:12 +04:00
{ " workgroup " , ' w ' , POPT_ARG_STRING , & c - > opt_target_workgroup } ,
{ " user " , ' U ' , POPT_ARG_STRING , & c - > opt_user_name , ' U ' } ,
2002-03-15 23:03:07 +03:00
{ " ipaddress " , ' I ' , POPT_ARG_STRING , 0 , ' I ' } ,
2008-05-10 01:22:12 +04:00
{ " port " , ' p ' , POPT_ARG_INT , & c - > opt_port } ,
{ " myname " , ' n ' , POPT_ARG_STRING , & c - > opt_requester_name } ,
{ " server " , ' S ' , POPT_ARG_STRING , & c - > opt_host } ,
2008-01-05 11:23:35 +03:00
{ " encrypt " , ' e ' , POPT_ARG_NONE , NULL , ' e ' , " Encrypt SMB transport (UNIX extended servers only) " } ,
2008-05-10 01:22:12 +04:00
{ " container " , ' c ' , POPT_ARG_STRING , & c - > opt_container } ,
{ " comment " , ' C ' , POPT_ARG_STRING , & c - > opt_comment } ,
{ " maxusers " , ' M ' , POPT_ARG_INT , & c - > opt_maxusers } ,
{ " flags " , ' F ' , POPT_ARG_INT , & c - > opt_flags } ,
{ " long " , ' l ' , POPT_ARG_NONE , & c - > opt_long_list_entries } ,
{ " reboot " , ' r ' , POPT_ARG_NONE , & c - > opt_reboot } ,
{ " force " , ' f ' , POPT_ARG_NONE , & c - > opt_force } ,
{ " stdin " , ' i ' , POPT_ARG_NONE , & c - > opt_stdin } ,
{ " timeout " , ' t ' , POPT_ARG_INT , & c - > opt_timeout } ,
{ " machine-pass " , ' P ' , POPT_ARG_NONE , & c - > opt_machine_pass } ,
{ " myworkgroup " , ' W ' , POPT_ARG_STRING , & c - > opt_workgroup } ,
{ " verbose " , ' v ' , POPT_ARG_NONE , & c - > opt_verbose } ,
{ " test " , ' T ' , POPT_ARG_NONE , & c - > opt_testmode } ,
2004-02-26 14:29:56 +03:00
/* Options for 'net groupmap set' */
2008-05-10 01:22:12 +04:00
{ " local " , ' L ' , POPT_ARG_NONE , & c - > opt_localgroup } ,
{ " domain " , ' D ' , POPT_ARG_NONE , & c - > opt_domaingroup } ,
{ " ntname " , ' N ' , POPT_ARG_STRING , & c - > opt_newntname } ,
{ " rid " , ' R ' , POPT_ARG_INT , & c - > opt_rid } ,
2004-08-10 18:27:17 +04:00
/* Options for 'net rpc share migrate' */
2008-05-10 01:22:12 +04:00
{ " acls " , 0 , POPT_ARG_NONE , & c - > opt_acls } ,
{ " attrs " , 0 , POPT_ARG_NONE , & c - > opt_attrs } ,
{ " timestamps " , 0 , POPT_ARG_NONE , & c - > opt_timestamps } ,
{ " exclude " , ' X ' , POPT_ARG_STRING , & c - > opt_exclude } ,
{ " destination " , 0 , POPT_ARG_STRING , & c - > opt_destination } ,
{ " tallocreport " , 0 , POPT_ARG_NONE , & c - > do_talloc_report } ,
2004-02-26 14:29:56 +03:00
2003-04-14 07:59:04 +04:00
POPT_COMMON_SAMBA
2001-11-24 16:26:01 +03:00
{ 0 , 0 , 0 , 0 }
} ;
2007-08-31 13:10:54 +04:00
2008-05-10 01:22:12 +04:00
zero_addr ( & c - > opt_dest_ip ) ;
2001-11-24 16:26:01 +03:00
2005-12-29 00:10:11 +03:00
load_case_tables ( ) ;
2003-07-19 04:23:08 +04:00
/* set default debug level to 0 regardless of what smb.conf sets */
DEBUGLEVEL_CLASS [ DBGC_ALL ] = 0 ;
2001-12-20 10:13:47 +03:00
dbf = x_stderr ;
2008-05-08 11:14:16 +04:00
pc = poptGetContext ( NULL , argc , ( const char * * ) argv , long_options ,
2001-11-24 16:26:01 +03:00
POPT_CONTEXT_KEEP_FIRST ) ;
2008-05-08 11:14:16 +04:00
2001-11-24 16:26:01 +03:00
while ( ( opt = poptGetNextOpt ( pc ) ) ! = - 1 ) {
switch ( opt ) {
case ' h ' :
2008-05-10 01:22:12 +04:00
net_help ( c , argc , argv ) ;
2001-11-24 16:26:01 +03:00
exit ( 0 ) ;
break ;
2008-01-05 11:23:35 +03:00
case ' e ' :
2008-05-10 01:22:12 +04:00
c - > smb_encrypt = true ;
2008-01-05 11:23:35 +03:00
break ;
2001-11-24 16:26:01 +03:00
case ' I ' :
2008-05-10 01:22:12 +04:00
if ( ! interpret_string_addr ( & c - > opt_dest_ip ,
2007-10-25 01:16:54 +04:00
poptGetOptArg ( pc ) , 0 ) ) {
2006-01-18 00:22:00 +03:00
d_fprintf ( stderr , " \n Invalid ip address specified \n " ) ;
2007-10-25 01:16:54 +04:00
} else {
2008-05-10 01:22:12 +04:00
c - > opt_have_ip = true ;
2007-10-25 01:16:54 +04:00
}
2001-11-24 16:26:01 +03:00
break ;
case ' U ' :
2008-05-12 13:53:23 +04:00
c - > opt_user_specified = true ;
2008-05-10 01:22:12 +04:00
c - > opt_user_name = SMB_STRDUP ( c - > opt_user_name ) ;
p = strchr ( c - > opt_user_name , ' % ' ) ;
2001-11-24 16:26:01 +03:00
if ( p ) {
* p = 0 ;
2008-05-10 01:22:12 +04:00
c - > opt_password = p + 1 ;
2001-11-24 16:26:01 +03:00
}
break ;
default :
2008-05-08 11:14:16 +04:00
d_fprintf ( stderr , " \n Invalid option %s: %s \n " ,
2003-01-21 17:08:33 +03:00
poptBadOption ( pc , 0 ) , poptStrerror ( opt ) ) ;
2008-05-10 01:22:12 +04:00
net_help ( c , argc , argv ) ;
2002-07-15 14:35:28 +04:00
exit ( 1 ) ;
2001-11-24 16:26:01 +03:00
}
2001-10-23 18:16:59 +04:00
}
2008-05-08 11:14:16 +04:00
2003-07-19 04:23:08 +04:00
/*
* Don ' t load debug level from smb . conf . It should be
* set by cmdline arg or remain default ( 0 )
*/
2008-06-05 20:40:26 +04:00
AllowDebugChange = false ;
2008-05-10 01:22:12 +04:00
lp_load ( get_dyn_CONFIGFILE ( ) , true , false , false , true ) ;
2008-05-08 11:14:16 +04:00
2003-07-19 04:23:08 +04:00
argv_new = ( const char * * ) poptGetArgs ( pc ) ;
2001-10-19 20:51:26 +04:00
2001-11-24 16:26:01 +03:00
argc_new = argc ;
for ( i = 0 ; i < argc ; i + + ) {
if ( argv_new [ i ] = = NULL ) {
argc_new = i ;
break ;
}
}
2002-07-15 14:35:28 +04:00
2008-05-10 01:22:12 +04:00
if ( c - > do_talloc_report ) {
2006-07-11 22:01:26 +04:00
talloc_enable_leak_report ( ) ;
}
2008-05-10 01:22:12 +04:00
if ( c - > opt_requester_name ) {
set_global_myname ( c - > opt_requester_name ) ;
2001-11-24 16:26:01 +03:00
}
2008-05-10 01:22:12 +04:00
if ( ! c - > opt_user_name & & getenv ( " LOGNAME " ) ) {
c - > opt_user_name = getenv ( " LOGNAME " ) ;
2001-11-24 16:26:01 +03:00
}
2008-05-10 01:22:12 +04:00
if ( ! c - > opt_workgroup ) {
c - > opt_workgroup = smb_xstrdup ( lp_workgroup ( ) ) ;
2001-11-24 16:26:01 +03:00
}
2008-05-08 11:14:16 +04:00
2008-05-10 01:22:12 +04:00
if ( ! c - > opt_target_workgroup ) {
c - > opt_target_workgroup = smb_xstrdup ( lp_workgroup ( ) ) ;
2001-12-04 07:48:01 +03:00
}
2008-05-08 11:14:16 +04:00
2002-11-13 02:20:50 +03:00
if ( ! init_names ( ) )
exit ( 1 ) ;
2001-12-05 14:00:26 +03:00
2001-11-24 16:26:01 +03:00
load_interfaces ( ) ;
2008-05-08 11:14:16 +04:00
/* this makes sure that when we do things like call scripts,
2003-06-14 04:49:02 +04:00
that it won ' t assert becouse we are not root */
sec_init ( ) ;
2001-10-19 20:51:26 +04:00
2008-05-10 01:22:12 +04:00
if ( c - > opt_machine_pass ) {
2002-07-15 14:35:28 +04:00
/* it is very useful to be able to make ads queries as the
machine account for testing purposes and for domain leave */
2008-05-10 01:22:12 +04:00
net_use_krb_machine_account ( c ) ;
2002-07-15 14:35:28 +04:00
}
2003-04-14 07:59:04 +04:00
2008-05-10 01:22:12 +04:00
if ( ! c - > opt_password ) {
c - > opt_password = getenv ( " PASSWD " ) ;
2003-04-14 07:59:04 +04:00
}
2008-05-08 11:14:16 +04:00
2008-05-18 21:12:24 +04:00
rc = net_run_function2 ( c , argc_new - 1 , argv_new + 1 , " net " , net_func ) ;
2008-05-08 11:14:16 +04:00
2001-11-24 16:26:01 +03:00
DEBUG ( 2 , ( " return code = %d \n " , rc ) ) ;
2008-04-16 04:16:08 +04:00
2008-05-10 01:22:12 +04:00
libnetapi_free ( c - > netapi_ctx ) ;
2008-04-16 04:16:08 +04:00
2008-06-04 04:44:24 +04:00
poptFreeContext ( pc ) ;
2007-08-31 13:10:54 +04:00
TALLOC_FREE ( frame ) ;
2001-11-24 16:26:01 +03:00
return rc ;
}