2002-07-29 13:23:01 +04:00
/*
Unix SMB / CIFS implementation .
Common popt routines
Copyright ( C ) Tim Potter 2001 , 2002
2003-04-14 07:30:20 +04:00
Copyright ( C ) Jelmer Vernooij 2002 , 2003
2006-05-24 08:02:14 +04:00
Copyright ( C ) James Peach 2006
2002-07-29 13:23:01 +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
2002-07-29 13:23:01 +04:00
( 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
2007-07-10 04:52:41 +04:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2002-07-29 13:23:01 +04:00
*/
# include "includes.h"
2010-08-05 12:49:53 +04:00
# include "popt_common.h"
2014-02-21 03:54:29 +04:00
# include "lib/param/param.h"
2002-07-29 13:23:01 +04:00
2002-10-28 22:44:11 +03:00
/* Handle command line options:
2003-04-14 07:30:20 +04:00
* - d , - - debuglevel
* - s , - - configfile
* - O , - - socket - options
* - V , - - version
* - l , - - log - base
* - n , - - netbios - name
* - W , - - workgroup
* - i , - - scope
2002-10-28 22:44:11 +03:00
*/
2002-07-29 13:23:01 +04:00
2010-08-11 07:35:14 +04:00
enum { OPT_OPTION = 1 } ;
2007-10-19 04:40:25 +04:00
extern bool override_logfile ;
2002-10-28 22:44:11 +03:00
2006-05-24 08:02:14 +04:00
static void set_logfile ( poptContext con , const char * arg )
2002-07-29 13:23:01 +04:00
{
2006-05-24 08:02:14 +04:00
2008-11-03 23:36:34 +03:00
char * lfile = NULL ;
2002-11-09 19:57:45 +03:00
const char * pname ;
2007-11-16 01:19:52 +03:00
2002-11-09 19:57:45 +03:00
/* Find out basename of current program */
pname = strrchr_m ( poptGetInvocationName ( con ) , ' / ' ) ;
if ( ! pname )
pname = poptGetInvocationName ( con ) ;
2007-11-16 01:19:52 +03:00
else
2002-11-09 19:57:45 +03:00
pname + + ;
2008-11-03 23:36:34 +03:00
if ( asprintf ( & lfile , " %s/log.%s " , arg , pname ) < 0 ) {
2007-11-16 01:19:52 +03:00
return ;
}
2008-11-03 23:36:34 +03:00
lp_set_logfile ( lfile ) ;
SAFE_FREE ( lfile ) ;
2006-05-24 08:02:14 +04:00
}
2007-10-19 04:40:25 +04:00
static bool PrintSambaVersionString ;
2007-08-22 15:55:48 +04:00
2009-08-03 13:30:44 +04:00
static void popt_s3_talloc_log_fn ( const char * message )
{
DEBUG ( 0 , ( " %s " , message ) ) ;
}
2006-05-24 08:02:14 +04:00
static void popt_common_callback ( poptContext con ,
enum poptCallbackReason reason ,
const struct poptOption * opt ,
const char * arg , const void * data )
{
2002-11-09 19:57:45 +03:00
if ( reason = = POPT_CALLBACK_REASON_PRE ) {
2007-12-10 22:30:37 +03:00
set_logfile ( con , get_dyn_LOGFILEBASE ( ) ) ;
2009-08-03 13:30:44 +04:00
talloc_set_log_fn ( popt_s3_talloc_log_fn ) ;
talloc_set_abort_fn ( smb_panic ) ;
2002-11-09 19:57:45 +03:00
return ;
}
2007-08-22 15:55:48 +04:00
if ( reason = = POPT_CALLBACK_REASON_POST ) {
2008-02-04 18:16:59 +03:00
if ( PrintSambaVersionString ) {
2009-01-16 00:27:52 +03:00
printf ( " Version %s \n " , samba_version_string ( ) ) ;
2008-02-04 18:16:59 +03:00
exit ( 0 ) ;
}
if ( is_default_dyn_CONFIGFILE ( ) ) {
if ( getenv ( " SMB_CONF_PATH " ) ) {
set_dyn_CONFIGFILE ( getenv ( " SMB_CONF_PATH " ) ) ;
}
}
/* Further 'every Samba program must do this' hooks here. */
2007-08-22 15:55:48 +04:00
return ;
}
2002-07-29 13:23:01 +04:00
switch ( opt - > val ) {
2010-08-11 07:35:14 +04:00
case OPT_OPTION :
2014-02-21 03:54:29 +04:00
{
struct loadparm_context * lp_ctx ;
lp_ctx = loadparm_init_s3 ( talloc_tos ( ) , loadparm_s3_helpers ( ) ) ;
if ( lp_ctx = = NULL ) {
fprintf ( stderr , " loadparm_init_s3() failed! \n " ) ;
exit ( 1 ) ;
}
if ( ! lpcfg_set_option ( lp_ctx , arg ) ) {
2010-08-11 07:35:14 +04:00
fprintf ( stderr , " Error setting option '%s' \n " , arg ) ;
exit ( 1 ) ;
}
2014-02-21 03:54:29 +04:00
TALLOC_FREE ( lp_ctx ) ;
2010-08-11 07:35:14 +04:00
break ;
2014-02-21 03:54:29 +04:00
}
2002-07-29 13:23:01 +04:00
case ' d ' :
if ( arg ) {
2010-10-29 08:06:36 +04:00
lp_set_cmdline ( " log level " , arg ) ;
2002-07-29 13:23:01 +04:00
}
2002-10-28 22:44:11 +03:00
break ;
2002-07-29 13:23:01 +04:00
2002-10-28 22:44:11 +03:00
case ' V ' :
2007-08-22 15:55:48 +04:00
PrintSambaVersionString = True ;
2002-10-28 22:44:11 +03:00
break ;
case ' O ' :
2002-11-09 19:57:45 +03:00
if ( arg ) {
2014-03-20 00:44:59 +04:00
lp_set_cmdline ( " socket options " , arg ) ;
2002-11-09 19:57:45 +03:00
}
2002-10-28 22:44:11 +03:00
break ;
case ' s ' :
2002-11-09 19:57:45 +03:00
if ( arg ) {
2007-12-10 22:30:37 +03:00
set_dyn_CONFIGFILE ( arg ) ;
2002-11-09 19:57:45 +03:00
}
2002-10-28 22:44:11 +03:00
break ;
case ' n ' :
2002-11-09 19:57:45 +03:00
if ( arg ) {
2011-06-09 09:31:03 +04:00
lp_set_cmdline ( " netbios name " , arg ) ;
2002-11-09 19:57:45 +03:00
}
break ;
case ' l ' :
if ( arg ) {
2006-05-24 08:02:14 +04:00
set_logfile ( con , arg ) ;
2006-06-05 17:00:24 +04:00
override_logfile = True ;
2007-12-10 22:30:37 +03:00
set_dyn_LOGFILEBASE ( arg ) ;
2002-11-09 19:57:45 +03:00
}
2002-07-29 13:23:01 +04:00
break ;
2003-04-14 07:30:20 +04:00
case ' i ' :
if ( arg ) {
2011-06-08 10:27:06 +04:00
lp_set_cmdline ( " netbios scope " , arg ) ;
2003-04-14 07:30:20 +04:00
}
break ;
case ' W ' :
if ( arg ) {
2011-06-08 09:42:22 +04:00
lp_set_cmdline ( " workgroup " , arg ) ;
2003-04-14 07:30:20 +04:00
}
break ;
2002-07-29 13:23:01 +04:00
}
}
2003-04-14 07:30:20 +04:00
struct poptOption popt_common_connection [ ] = {
2006-07-11 22:01:26 +04:00
{ NULL , 0 , POPT_ARG_CALLBACK , ( void * ) popt_common_callback } ,
2003-04-14 07:30:20 +04:00
{ " socket-options " , ' O ' , POPT_ARG_STRING , NULL , ' O ' , " socket options to use " ,
" SOCKETOPTIONS " } ,
{ " netbiosname " , ' n ' , POPT_ARG_STRING , NULL , ' n ' , " Primary netbios name " , " NETBIOSNAME " } ,
{ " workgroup " , ' W ' , POPT_ARG_STRING , NULL , ' W ' , " Set the workgroup name " , " WORKGROUP " } ,
{ " scope " , ' i ' , POPT_ARG_STRING , NULL , ' i ' , " Use this Netbios scope " , " SCOPE " } ,
2003-08-14 05:08:00 +04:00
2003-04-14 07:30:20 +04:00
POPT_TABLEEND
2002-07-29 13:23:01 +04:00
} ;
2002-10-28 22:44:11 +03:00
2003-04-14 07:30:20 +04:00
struct poptOption popt_common_samba [ ] = {
2007-08-22 15:55:48 +04:00
{ NULL , 0 , POPT_ARG_CALLBACK | POPT_CBFLAG_PRE | POPT_CBFLAG_POST , ( void * ) popt_common_callback } ,
2003-04-14 07:30:20 +04:00
{ " debuglevel " , ' d ' , POPT_ARG_STRING , NULL , ' d ' , " Set debug level " , " DEBUGLEVEL " } ,
2006-05-24 08:02:14 +04:00
{ " configfile " , ' s ' , POPT_ARG_STRING , NULL , ' s ' , " Use alternate configuration file " , " CONFIGFILE " } ,
{ " log-basename " , ' l ' , POPT_ARG_STRING , NULL , ' l ' , " Base name for log files " , " LOGFILEBASE " } ,
2003-04-14 07:30:20 +04:00
{ " version " , ' V ' , POPT_ARG_NONE , NULL , ' V ' , " Print version " } ,
2010-08-11 07:35:14 +04:00
{ " option " , 0 , POPT_ARG_STRING , NULL , OPT_OPTION , " Set smb.conf option from command line " , " name=value " } ,
2003-04-14 07:30:20 +04:00
POPT_TABLEEND
2002-10-28 22:44:11 +03:00
} ;
2007-12-14 21:36:14 +03:00
struct poptOption popt_common_configfile [ ] = {
{ NULL , 0 , POPT_ARG_CALLBACK | POPT_CBFLAG_PRE | POPT_CBFLAG_POST , ( void * ) popt_common_callback } ,
{ " configfile " , 0 , POPT_ARG_STRING , NULL , ' s ' , " Use alternate configuration file " , " CONFIGFILE " } ,
POPT_TABLEEND
} ;
2002-10-28 22:44:11 +03:00
struct poptOption popt_common_version [ ] = {
2008-12-06 03:30:39 +03:00
{ NULL , 0 , POPT_ARG_CALLBACK | POPT_CBFLAG_POST , ( void * ) popt_common_callback } ,
2003-04-14 07:30:20 +04:00
{ " version " , ' V ' , POPT_ARG_NONE , NULL , ' V ' , " Print version " } ,
POPT_TABLEEND
2002-10-28 22:44:11 +03:00
} ;
2008-07-15 13:26:11 +04:00
struct poptOption popt_common_debuglevel [ ] = {
{ NULL , 0 , POPT_ARG_CALLBACK , ( void * ) popt_common_callback } ,
{ " debuglevel " , ' d ' , POPT_ARG_STRING , NULL , ' d ' , " Set debug level " , " DEBUGLEVEL " } ,
POPT_TABLEEND
} ;
2011-02-09 15:44:42 +03:00
struct poptOption popt_common_option [ ] = {
{ NULL , 0 , POPT_ARG_CALLBACK | POPT_CBFLAG_POST , ( void * ) popt_common_callback } ,
{ " option " , 0 , POPT_ARG_STRING , NULL , OPT_OPTION , " Set smb.conf option from command line " , " name=value " } ,
POPT_TABLEEND
} ;
2002-11-09 19:57:45 +03:00
2003-04-14 07:30:20 +04:00
/* Handle command line options:
* - U , - - user
* - A , - - authentication - file
* - k , - - use - kerberos
* - N , - - no - pass
2003-07-31 03:49:29 +04:00
* - S , - - signing
2003-08-14 05:08:00 +04:00
* - P - - machine - pass
2008-01-05 11:23:35 +03:00
* - e - - encrypt
2010-01-24 19:07:24 +03:00
* - C - - use - ccache
2003-04-14 07:30:20 +04:00
*/
2017-04-26 03:03:10 +03:00
static struct user_auth_info * cmdline_auth_info ;
2017-04-26 03:01:25 +03:00
struct user_auth_info * popt_get_cmdline_auth_info ( void )
{
return cmdline_auth_info ;
}
void popt_free_cmdline_auth_info ( void )
{
TALLOC_FREE ( cmdline_auth_info ) ;
}
2016-12-09 18:04:38 +03:00
static bool popt_common_credentials_ignore_missing_conf ;
2016-10-21 18:22:03 +03:00
static bool popt_common_credentials_delay_post ;
2016-12-09 18:04:38 +03:00
void popt_common_credentials_set_ignore_missing_conf ( void )
{
popt_common_credentials_delay_post = true ;
}
2016-10-21 18:22:03 +03:00
void popt_common_credentials_set_delay_post ( void )
{
popt_common_credentials_delay_post = true ;
}
void popt_common_credentials_post ( void )
{
2017-04-26 02:32:05 +03:00
if ( get_cmdline_auth_info_use_machine_account ( cmdline_auth_info ) & &
! set_cmdline_auth_info_machine_account_creds ( cmdline_auth_info ) )
2016-10-21 18:22:03 +03:00
{
fprintf ( stderr ,
" Failed to use machine account credentials \n " ) ;
exit ( 1 ) ;
}
2017-04-26 02:32:05 +03:00
set_cmdline_auth_info_getpass ( cmdline_auth_info ) ;
2017-06-19 15:50:33 +03:00
/*
* When we set the username during the handling of the options passed to
* the binary we haven ' t loaded the config yet . This means that we
* didnn ' t take the ' winbind separator ' into account .
*
* The username might contain the domain name and thus it hasn ' t been
* correctly parsed yet . If we have a username we need to set it again
* to run the string parser for the username correctly .
*/
2017-08-29 18:06:21 +03:00
reset_cmdline_auth_info_username ( cmdline_auth_info ) ;
2016-10-21 18:22:03 +03:00
}
2003-04-14 07:30:20 +04:00
2007-12-07 04:16:33 +03:00
static void popt_common_credentials_callback ( poptContext con ,
2003-07-31 03:49:29 +04:00
enum poptCallbackReason reason ,
const struct poptOption * opt ,
const char * arg , const void * data )
2003-04-14 07:30:20 +04:00
{
if ( reason = = POPT_CALLBACK_REASON_PRE ) {
2017-04-26 02:32:05 +03:00
struct user_auth_info * auth_info =
2017-04-26 03:09:18 +03:00
user_auth_info_init ( NULL ) ;
2016-10-21 18:22:03 +03:00
if ( auth_info = = NULL ) {
2016-10-28 13:14:37 +03:00
fprintf ( stderr , " user_auth_info_init() failed \n " ) ;
exit ( 1 ) ;
2003-04-14 07:30:20 +04:00
}
2016-10-28 13:14:37 +03:00
cmdline_auth_info = auth_info ;
2003-04-14 07:30:20 +04:00
return ;
}
2016-10-21 18:22:03 +03:00
if ( reason = = POPT_CALLBACK_REASON_POST ) {
2016-12-09 18:04:38 +03:00
bool ok ;
if ( override_logfile ) {
setup_logging ( lp_logfile ( talloc_tos ( ) ) , DEBUG_FILE ) ;
}
ok = lp_load_client ( get_dyn_CONFIGFILE ( ) ) ;
if ( ! ok ) {
const char * pname = poptGetInvocationName ( con ) ;
fprintf ( stderr , " %s: Can't load %s - run testparm to debug it \n " ,
pname , get_dyn_CONFIGFILE ( ) ) ;
if ( ! popt_common_credentials_ignore_missing_conf ) {
exit ( 1 ) ;
}
}
load_interfaces ( ) ;
2017-04-26 02:32:05 +03:00
set_cmdline_auth_info_guess ( cmdline_auth_info ) ;
2016-10-28 13:14:37 +03:00
2016-10-21 18:22:03 +03:00
if ( popt_common_credentials_delay_post ) {
return ;
}
popt_common_credentials_post ( ) ;
return ;
}
2003-04-14 07:30:20 +04:00
switch ( opt - > val ) {
case ' U ' :
2017-04-26 02:32:05 +03:00
set_cmdline_auth_info_username ( cmdline_auth_info , arg ) ;
2003-04-14 07:30:20 +04:00
break ;
case ' A ' :
2017-04-26 02:32:05 +03:00
set_cmdline_auth_info_from_file ( cmdline_auth_info , arg ) ;
2003-04-14 07:30:20 +04:00
break ;
case ' k ' :
# ifndef HAVE_KRB5
d_printf ( " No kerberos support compiled in \n " ) ;
exit ( 1 ) ;
# else
2017-04-26 02:32:05 +03:00
set_cmdline_auth_info_use_krb5_ticket ( cmdline_auth_info ) ;
2003-04-14 07:30:20 +04:00
# endif
break ;
2003-07-31 03:49:29 +04:00
case ' S ' :
2017-04-26 02:32:05 +03:00
if ( ! set_cmdline_auth_info_signing_state ( cmdline_auth_info ,
arg ) ) {
2007-12-07 05:49:39 +03:00
fprintf ( stderr , " Unknown signing option %s \n " , arg ) ;
exit ( 1 ) ;
2003-07-31 03:49:29 +04:00
}
break ;
2003-08-14 05:08:00 +04:00
case ' P ' :
2017-04-26 02:32:05 +03:00
set_cmdline_auth_info_use_machine_account ( cmdline_auth_info ) ;
2003-08-14 05:08:00 +04:00
break ;
2007-12-07 05:49:39 +03:00
case ' N ' :
2017-04-26 02:32:05 +03:00
set_cmdline_auth_info_password ( cmdline_auth_info , " " ) ;
2007-12-07 05:49:39 +03:00
break ;
2008-01-05 11:23:35 +03:00
case ' e ' :
2017-04-26 02:32:05 +03:00
set_cmdline_auth_info_smb_encrypt ( cmdline_auth_info ) ;
2008-01-05 11:23:35 +03:00
break ;
2010-01-24 19:07:24 +03:00
case ' C ' :
2017-04-26 02:32:05 +03:00
set_cmdline_auth_info_use_ccache ( cmdline_auth_info , true ) ;
2010-01-24 19:07:24 +03:00
break ;
2012-06-11 16:03:16 +04:00
case ' H ' :
2017-04-26 02:32:05 +03:00
set_cmdline_auth_info_use_pw_nt_hash ( cmdline_auth_info , true ) ;
2012-06-11 16:03:16 +04:00
break ;
2003-04-14 07:30:20 +04:00
}
}
2012-11-06 12:27:42 +04:00
/**
* @ brief Burn the commandline password .
*
* This function removes the password from the command line so we
* don ' t leak the password e . g . in ' ps aux ' .
*
* It should be called after processing the options and you should pass down
* argv from main ( ) .
*
* @ param [ in ] argc The number of arguments .
*
* @ param [ in ] argv [ ] The argument array we will find the array .
*/
void popt_burn_cmdline_password ( int argc , char * argv [ ] )
{
bool found = false ;
char * p = NULL ;
int i , ulen = 0 ;
for ( i = 0 ; i < argc ; i + + ) {
p = argv [ i ] ;
if ( strncmp ( p , " -U " , 2 ) = = 0 ) {
ulen = 2 ;
found = true ;
} else if ( strncmp ( p , " --user " , 6 ) = = 0 ) {
ulen = 6 ;
found = true ;
}
if ( found ) {
if ( p = = NULL ) {
return ;
}
if ( strlen ( p ) = = ulen ) {
continue ;
}
p = strchr_m ( p , ' % ' ) ;
if ( p ! = NULL ) {
memset ( p , ' \0 ' , strlen ( p ) ) ;
}
found = false ;
}
}
}
2003-04-14 07:30:20 +04:00
struct poptOption popt_common_credentials [ ] = {
2016-10-21 18:22:03 +03:00
{ NULL , 0 , POPT_ARG_CALLBACK | POPT_CBFLAG_PRE | POPT_CBFLAG_POST ,
( void * ) popt_common_credentials_callback , 0 , NULL } ,
2003-04-14 07:30:20 +04:00
{ " user " , ' U ' , POPT_ARG_STRING , NULL , ' U ' , " Set the network username " , " USERNAME " } ,
2007-12-07 06:06:34 +03:00
{ " no-pass " , ' N ' , POPT_ARG_NONE , NULL , ' N ' , " Don't ask for a password " } ,
2007-12-07 05:49:39 +03:00
{ " kerberos " , ' k ' , POPT_ARG_NONE , NULL , ' k ' , " Use kerberos (active directory) authentication " } ,
2003-04-14 07:30:20 +04:00
{ " authentication-file " , ' A ' , POPT_ARG_STRING , NULL , ' A ' , " Get the credentials from a file " , " FILE " } ,
2003-07-31 03:49:29 +04:00
{ " signing " , ' S ' , POPT_ARG_STRING , NULL , ' S ' , " Set the client signing state " , " on|off|required " } ,
2003-08-14 05:08:00 +04:00
{ " machine-pass " , ' P ' , POPT_ARG_NONE , NULL , ' P ' , " Use stored machine account password " } ,
2015-11-02 18:33:34 +03:00
{ " encrypt " , ' e ' , POPT_ARG_NONE , NULL , ' e ' , " Encrypt SMB transport " } ,
2010-01-24 19:07:24 +03:00
{ " use-ccache " , ' C ' , POPT_ARG_NONE , NULL , ' C ' ,
" Use the winbind ccache for authentication " } ,
2012-06-11 16:03:16 +04:00
{ " pw-nt-hash " , ' \0 ' , POPT_ARG_NONE , NULL , ' H ' ,
" The supplied password is the NT hash " } ,
2003-04-14 07:30:20 +04:00
POPT_TABLEEND
2002-11-09 19:57:45 +03:00
} ;