1996-05-04 07:50:46 +00:00
/*
Unix SMB / Netbios implementation .
Version 1.9 .
Test validity of smb . conf
1998-01-22 13:27:43 +00:00
Copyright ( C ) Karl Auer 1993 , 1994 - 1998
1996-05-04 07:50:46 +00:00
Extensively modified by Andrew Tridgell , 1995
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 .
*/
/*
* Testbed for loadparm . c / params . c
*
* This module simply loads a specified configuration file and
* if successful , dumps it ' s contents to stdout . Note that the
* operation is performed with DEBUGLEVEL at 3.
*
* Useful for a quick ' syntax check ' of a configuration file .
*
*/
# include "includes.h"
# include "smb.h"
/* these live in util.c */
extern FILE * dbf ;
extern int DEBUGLEVEL ;
1998-05-22 01:51:14 +00:00
/***********************************************
Here we do a set of ' hard coded ' checks for bad
configuration settings .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1999-12-13 13:27:58 +00:00
static int do_global_checks ( void )
1998-05-22 01:51:14 +00:00
{
1999-12-13 13:27:58 +00:00
int ret = 0 ;
1998-09-01 20:11:54 +00:00
SMB_STRUCT_STAT st ;
1999-12-13 13:27:58 +00:00
if ( lp_security ( ) = = SEC_DOMAIN & & ! lp_encrypted_passwords ( ) ) {
1998-11-10 20:51:25 +00:00
printf ( " ERROR: in 'security=domain' mode the 'encrypt passwords' parameter must also be set to 'true'. \n " ) ;
1999-12-13 13:27:58 +00:00
ret = 1 ;
1998-11-10 20:51:25 +00:00
}
1998-08-20 03:11:46 +00:00
if ( lp_wins_support ( ) & & * lp_wins_server ( ) ) {
printf ( " ERROR: both 'wins support = true' and 'wins server = <server>' \
1998-05-22 01:51:14 +00:00
cannot be set in the smb . conf file . nmbd will abort with this setting . \ n " );
1999-12-13 13:27:58 +00:00
ret = 1 ;
1998-08-20 03:11:46 +00:00
}
if ( ! directory_exist ( lp_lockdir ( ) , & st ) ) {
printf ( " ERROR: lock directory %s does not exist \n " ,
lp_lockdir ( ) ) ;
1999-12-13 13:27:58 +00:00
ret = 1 ;
1998-08-21 07:25:57 +00:00
} else if ( ( st . st_mode & 0777 ) ! = 0755 ) {
1998-08-21 07:29:42 +00:00
printf ( " WARNING: lock directory %s should have permissions 0755 for browsing to work \n " ,
1998-08-20 03:11:46 +00:00
lp_lockdir ( ) ) ;
1999-12-13 13:27:58 +00:00
ret = 1 ;
}
/*
* Password server sanity checks .
*/
if ( ( lp_security ( ) = = SEC_SERVER | | lp_security ( ) = = SEC_DOMAIN ) & & ! lp_passwordserver ( ) ) {
pstring sec_setting ;
if ( lp_security ( ) = = SEC_SERVER )
pstrcpy ( sec_setting , " server " ) ;
else if ( lp_security ( ) = = SEC_DOMAIN )
pstrcpy ( sec_setting , " domain " ) ;
printf ( " ERROR: The setting 'security=%s' requires the 'password server' parameter be set \
to a valid password server . \ n " , sec_setting );
ret = 1 ;
}
/*
* Password chat sanity checks .
*/
if ( lp_security ( ) = = SEC_USER & & lp_unix_password_sync ( ) ) {
/*
2001-05-10 06:53:19 +00:00
* Check that we have a valid lp_passwd_program ( ) if not using pam .
1999-12-13 13:27:58 +00:00
*/
2001-05-10 06:53:19 +00:00
# ifdef WITH_PAM
if ( ! lp_pam_password_change ( ) ) {
# endif
if ( lp_passwd_program ( ) = = NULL ) {
printf ( " ERROR: the 'unix password sync' parameter is set and there is no valid 'passwd program' \
1999-12-13 13:27:58 +00:00
parameter . \ n " );
ret = 1 ;
2001-05-10 06:53:19 +00:00
} else {
pstring passwd_prog ;
pstring truncated_prog ;
char * p ;
pstrcpy ( passwd_prog , lp_passwd_program ( ) ) ;
p = passwd_prog ;
* truncated_prog = ' \0 ' ;
next_token ( & p , truncated_prog , NULL , sizeof ( pstring ) ) ;
if ( access ( truncated_prog , F_OK ) = = - 1 ) {
printf ( " ERROR: the 'unix password sync' parameter is set and the 'passwd program' (%s) \
cannot be executed ( error was % s ) . \ n " , truncated_prog, strerror(errno) ) ;
ret = 1 ;
}
1999-12-13 13:27:58 +00:00
}
2001-05-10 06:53:19 +00:00
# ifdef WITH_PAM
1999-12-13 13:27:58 +00:00
}
2001-05-10 06:53:19 +00:00
# endif
1999-12-13 13:27:58 +00:00
if ( lp_passwd_chat ( ) = = NULL ) {
printf ( " ERROR: the 'unix password sync' parameter is set and there is no valid 'passwd chat' \
parameter . \ n " );
ret = 1 ;
}
/*
* Check that we have a valid script and that it hasn ' t
* been written to expect the old password .
*/
if ( lp_encrypted_passwords ( ) ) {
if ( strstr ( lp_passwd_chat ( ) , " %o " ) ! = NULL ) {
printf ( " ERROR: the 'passwd chat' script [%s] expects to use the old plaintext password \
via the % % o substitution . With encrypted passwords this is not possible . \ n " , lp_passwd_chat() );
ret = 1 ;
}
}
}
return ret ;
1998-05-22 01:51:14 +00:00
}
1999-12-13 13:27:58 +00:00
static void usage ( char * pname )
{
printf ( " Usage: %s [-sh] [-L servername] [configfilename] [hostname hostIP] \n " , pname ) ;
printf ( " \t -s Suppress prompt for enter \n " ) ;
printf ( " \t -h Print usage \n " ) ;
printf ( " \t -L servername Set %%L macro to servername \n " ) ;
2001-03-26 23:13:02 +00:00
printf ( " \t -t encoding Print parameters with encoding \n " ) ;
1999-12-13 13:27:58 +00:00
printf ( " \t configfilename Configuration file to test \n " ) ;
printf ( " \t hostname hostIP. Hostname and Host IP address to test \n " ) ;
printf ( " \t against \" host allow \" and \" host deny \" \n " ) ;
printf ( " \n " ) ;
}
int main ( int argc , char * argv [ ] )
1996-05-04 07:50:46 +00:00
{
1998-11-19 21:17:58 +00:00
extern char * optarg ;
extern int optind ;
1999-12-13 13:27:58 +00:00
extern fstring local_machine ;
1996-05-04 07:50:46 +00:00
pstring configfile ;
1998-11-19 21:17:58 +00:00
int opt ;
1996-05-04 07:50:46 +00:00
int s ;
1998-11-19 21:17:58 +00:00
BOOL silent_mode = False ;
1999-12-13 13:27:58 +00:00
int ret = 0 ;
2001-03-26 23:13:02 +00:00
pstring term_code ;
* term_code = 0 ;
1996-05-04 07:50:46 +00:00
1996-05-31 15:13:29 +00:00
TimeInit ( ) ;
1996-05-04 07:50:46 +00:00
setup_logging ( argv [ 0 ] , True ) ;
2001-03-26 23:13:02 +00:00
while ( ( opt = getopt ( argc , argv , " shL:t: " ) ) ! = EOF ) {
1998-11-19 21:17:58 +00:00
switch ( opt ) {
case ' s ' :
silent_mode = True ;
break ;
1999-12-13 13:27:58 +00:00
case ' L ' :
fstrcpy ( local_machine , optarg ) ;
break ;
case ' h ' :
usage ( argv [ 0 ] ) ;
exit ( 0 ) ;
break ;
2001-03-26 23:13:02 +00:00
case ' t ' :
pstrcpy ( term_code , optarg ) ;
break ;
1999-12-13 13:27:58 +00:00
default :
printf ( " Incorrect program usage \n " ) ;
usage ( argv [ 0 ] ) ;
exit ( 1 ) ;
break ;
1998-11-19 21:17:58 +00:00
}
}
argc + = ( 1 - optind ) ;
if ( ( argc = = 1 ) | | ( argc = = 3 ) )
1998-05-12 00:55:32 +00:00
pstrcpy ( configfile , CONFIGFILE ) ;
1998-11-19 21:17:58 +00:00
else if ( ( argc = = 2 ) | | ( argc = = 4 ) )
pstrcpy ( configfile , argv [ optind ] ) ;
1996-05-04 07:50:46 +00:00
dbf = stdout ;
DEBUGLEVEL = 2 ;
printf ( " Load smb config files from %s \n " , configfile ) ;
1999-12-13 13:27:58 +00:00
if ( ! lp_load ( configfile , False , True , False ) ) {
1996-05-04 07:50:46 +00:00
printf ( " Error loading services. \n " ) ;
return ( 1 ) ;
1999-12-13 13:27:58 +00:00
}
1996-05-04 07:50:46 +00:00
printf ( " Loaded services file OK. \n " ) ;
1999-12-13 13:27:58 +00:00
ret = do_global_checks ( ) ;
1998-05-22 01:51:14 +00:00
1999-12-13 13:27:58 +00:00
for ( s = 0 ; s < 1000 ; s + + ) {
1996-05-04 07:50:46 +00:00
if ( VALID_SNUM ( s ) )
if ( strlen ( lp_servicename ( s ) ) > 8 ) {
1999-12-13 13:27:58 +00:00
printf ( " WARNING: You have some share names that are longer than 8 chars \n " ) ;
printf ( " These may give errors while browsing or may not be accessible \n to some older clients \n " ) ;
break ;
}
}
for ( s = 0 ; s < 1000 ; s + + ) {
if ( VALID_SNUM ( s ) ) {
2001-06-20 16:54:32 +00:00
char * * deny_list = lp_hostsdeny ( s ) ;
char * * allow_list = lp_hostsallow ( s ) ;
int i ;
1999-12-13 13:27:58 +00:00
if ( deny_list ) {
2001-06-20 16:54:32 +00:00
for ( i = 0 ; deny_list [ i ] ; i + + ) {
2001-07-04 07:36:09 +00:00
char * hasstar = strchr_m ( deny_list [ i ] , ' * ' ) ;
char * hasquery = strchr_m ( deny_list [ i ] , ' ? ' ) ;
2001-06-20 16:54:32 +00:00
if ( hasstar | | hasquery ) {
printf ( " Invalid character %c in hosts deny list (%s) for service %s. \n " ,
hasstar ? * hasstar : * hasquery , deny_list [ i ] , lp_servicename ( s ) ) ;
}
1999-12-13 13:27:58 +00:00
}
1996-05-04 07:50:46 +00:00
}
1999-12-13 13:27:58 +00:00
if ( allow_list ) {
2001-06-20 16:54:32 +00:00
for ( i = 0 ; allow_list [ i ] ; i + + ) {
2001-07-04 07:36:09 +00:00
char * hasstar = strchr_m ( allow_list [ i ] , ' * ' ) ;
char * hasquery = strchr_m ( allow_list [ i ] , ' ? ' ) ;
2001-06-20 16:54:32 +00:00
if ( hasstar | | hasquery ) {
printf ( " Invalid character %c in hosts allow list (%s) for service %s. \n " ,
hasstar ? * hasstar : * hasquery , allow_list [ i ] , lp_servicename ( s ) ) ;
}
1999-12-13 13:27:58 +00:00
}
1998-11-19 21:17:58 +00:00
}
1999-12-13 13:27:58 +00:00
if ( lp_level2_oplocks ( s ) & & ! lp_oplocks ( s ) ) {
printf ( " Invalid combination of parameters for service %s. \
Level II oplocks can only be set if oplocks are also set . \ n " ,
lp_servicename ( s ) ) ;
}
}
}
if ( argc < 3 ) {
if ( ! silent_mode ) {
printf ( " Press enter to see a dump of your service definitions \n " ) ;
fflush ( stdout ) ;
getc ( stdin ) ;
1996-05-04 07:50:46 +00:00
}
2001-07-04 07:15:53 +00:00
lp_dump ( stdout , True , lp_numservices ( ) ) ;
1999-12-13 13:27:58 +00:00
}
1996-05-04 07:50:46 +00:00
1999-12-13 13:27:58 +00:00
if ( argc > = 3 ) {
char * cname ;
char * caddr ;
1996-05-04 07:50:46 +00:00
1999-12-13 13:27:58 +00:00
if ( argc = = 3 ) {
cname = argv [ optind ] ;
caddr = argv [ optind + 1 ] ;
} else {
cname = argv [ optind + 1 ] ;
caddr = argv [ optind + 2 ] ;
}
1998-11-19 21:17:58 +00:00
1999-12-13 13:27:58 +00:00
/* this is totally ugly, a real `quick' hack */
for ( s = 0 ; s < 1000 ; s + + ) {
if ( VALID_SNUM ( s ) ) {
if ( allow_access ( lp_hostsdeny ( s ) , lp_hostsallow ( s ) , cname , caddr ) ) {
printf ( " Allow connection from %s (%s) to %s \n " ,
cname , caddr , lp_servicename ( s ) ) ;
} else {
printf ( " Deny connection from %s (%s) to %s \n " ,
cname , caddr , lp_servicename ( s ) ) ;
}
}
1996-05-04 07:50:46 +00:00
}
1999-12-13 13:27:58 +00:00
}
return ( ret ) ;
1996-05-04 07:50:46 +00:00
}