1996-05-04 11:50:46 +04:00
/*
Unix SMB / Netbios implementation .
Version 1.9 .
Parameter loading functions
1998-01-22 16:27:43 +03:00
Copyright ( C ) Karl Auer 1993 - 1998
1996-05-04 11:50:46 +04:00
Largely re - written by Andrew Tridgell , September 1994
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 .
*/
/*
* Load parameters .
*
* This module provides suitable callback functions for the params
* module . It builds the internal table of service details which is
* then used by the rest of the server .
*
* To add a parameter :
*
* 1 ) add it to the global or service structure definition
* 2 ) add it to the parm_table
* 3 ) add it to the list of available functions ( eg : using FN_GLOBAL_STRING ( ) )
* 4 ) If it ' s a global then initialise it in init_globals . If a local
* ( ie . service ) parameter then initialise it in the sDefault structure
*
*
* Notes :
* The configuration file is processed sequentially for speed . It is NOT
* accessed randomly as happens in ' real ' Windows . For this reason , there
* is a fair bit of sequence - dependent code here - ie . , code which assumes
* that certain things happen before others . In particular , the code which
* happens at the boundary between sections is delicately poised , so be
* careful !
*
*/
# include "includes.h"
1997-09-12 00:17:32 +04:00
/* Set default coding system for KANJI if none specified in Makefile. */
1998-03-03 23:19:14 +03:00
/*
* We treat KANJI specially due to historical precedent ( it was the
* first non - english codepage added to Samba ) . With the new dynamic
* codepage support this is not needed anymore .
*
* The define ' KANJI ' is being overloaded to mean ' use kanji codepage
* by default ' and also ' this is the filename - to - disk conversion
* method to use ' . This really should be removed and all control
* over this left in the smb . conf parameters ' client codepage '
* and ' coding system ' .
*/
1997-09-12 00:17:32 +04:00
# ifndef KANJI
1998-04-03 05:04:34 +04:00
# define KANJI "sbcs"
1997-09-12 00:17:32 +04:00
# endif /* KANJI */
1998-09-29 08:43:40 +04:00
BOOL in_client = False ; /* Not in the client by default */
1996-05-04 11:50:46 +04:00
BOOL bLoaded = False ;
extern int DEBUGLEVEL ;
extern pstring user_socket_options ;
1998-04-25 05:12:08 +04:00
extern pstring global_myname ;
2000-01-07 09:55:36 +03:00
pstring global_scope = " " ;
1996-05-04 11:50:46 +04:00
# ifndef GLOBAL_NAME
# define GLOBAL_NAME "global"
# endif
# ifndef PRINTERS_NAME
# define PRINTERS_NAME "printers"
# endif
# ifndef HOMES_NAME
# define HOMES_NAME "homes"
# endif
/* some helpful bits */
# define pSERVICE(i) ServicePtrs[i]
# define iSERVICE(i) (*pSERVICE(i))
# define LP_SNUM_OK(iService) (((iService) >= 0) && ((iService) < iNumServices) && iSERVICE(iService).valid)
# define VALID(i) iSERVICE(i).valid
1998-03-16 10:23:51 +03:00
int keepalive = DEFAULT_KEEPALIVE ;
1996-05-04 11:50:46 +04:00
extern BOOL use_getwd_cache ;
extern int extra_time_offset ;
1998-03-14 11:27:41 +03:00
static BOOL defaults_saved = False ;
1996-05-04 11:50:46 +04:00
/*
* This structure describes global ( ie . , server - wide ) parameters .
*/
typedef struct
{
1996-10-02 19:41:30 +04:00
char * szPrintcapname ;
char * szLockDir ;
char * szRootdir ;
1996-06-06 15:43:09 +04:00
char * szDefaultService ;
char * szDfree ;
1996-10-02 18:09:22 +04:00
char * szMsgCommand ;
1996-10-02 19:41:30 +04:00
char * szHostsEquiv ;
1996-10-02 18:09:22 +04:00
char * szServerString ;
1996-10-02 19:41:30 +04:00
char * szAutoServices ;
char * szPasswdProgram ;
char * szPasswdChat ;
char * szLogFile ;
char * szConfigFile ;
1996-10-02 18:09:22 +04:00
char * szSMBPasswdFile ;
1996-10-02 19:41:30 +04:00
char * szPasswordServer ;
1996-06-06 15:43:09 +04:00
char * szSocketOptions ;
1996-10-02 18:09:22 +04:00
char * szValidChars ;
char * szWorkGroup ;
1999-12-13 16:27:58 +03:00
char * szDomainAdminGroup ;
char * szDomainGuestGroup ;
char * szDomainAdminUsers ;
char * szDomainGuestUsers ;
char * szDomainHostsallow ;
char * szDomainHostsdeny ;
1996-10-02 19:41:30 +04:00
char * szUsernameMap ;
1999-12-13 16:27:58 +03:00
# ifdef USING_GROUPNAME_MAP
1998-06-13 07:04:00 +04:00
char * szGroupnameMap ;
1999-12-13 16:27:58 +03:00
# endif /* USING_GROUPNAME_MAP */
1996-10-02 19:41:30 +04:00
char * szCharacterSet ;
char * szLogonScript ;
1997-02-02 21:12:36 +03:00
char * szLogonPath ;
1997-10-20 16:10:58 +04:00
char * szLogonDrive ;
char * szLogonHome ;
1996-10-02 19:41:30 +04:00
char * szSmbrun ;
char * szWINSserver ;
1997-11-22 10:09:12 +03:00
char * szCodingSystem ;
1996-10-02 19:41:30 +04:00
char * szInterfaces ;
char * szRemoteAnnounce ;
1997-11-21 17:01:23 +03:00
char * szRemoteBrowseSync ;
1996-10-02 19:41:30 +04:00
char * szSocketAddress ;
1997-05-07 21:56:46 +04:00
char * szNISHomeMapName ;
1997-07-30 23:17:51 +04:00
char * szAnnounceVersion ; /* This is initialised in init_globals */
1997-07-31 22:47:26 +04:00
char * szNetbiosAliases ;
1997-10-22 15:31:37 +04:00
char * szDomainOtherSIDs ;
1999-12-13 16:27:58 +03:00
char * szDomainGroups ;
1997-10-28 22:32:59 +03:00
char * szDriverFile ;
1998-03-16 23:59:47 +03:00
char * szNameResolveOrder ;
1998-05-06 21:43:44 +04:00
char * szLdapServer ;
char * szLdapSuffix ;
1999-12-13 16:27:58 +03:00
char * szLdapFilter ;
char * szLdapRoot ;
char * szLdapRootPassword ;
1998-08-21 15:37:40 +04:00
char * szPanicAction ;
1999-12-13 16:27:58 +03:00
char * szAddUserScript ;
char * szDelUserScript ;
char * szWINSHook ;
2000-01-12 06:09:17 +03:00
# ifdef WITH_UTMP
char * szUtmpDir ;
# endif /* WITH_UTMP */
1996-06-06 15:43:09 +04:00
int max_log_size ;
int mangled_stack ;
int max_xmit ;
int max_mux ;
1998-09-30 05:49:24 +04:00
int max_open_files ;
1996-06-06 15:43:09 +04:00
int max_packet ;
int pwordlevel ;
1997-09-19 21:12:08 +04:00
int unamelevel ;
1996-06-06 15:43:09 +04:00
int deadtime ;
int maxprotocol ;
int security ;
int maxdisksize ;
int lpqcachetime ;
int syslog ;
int os_level ;
int max_ttl ;
1997-12-13 17:16:07 +03:00
int max_wins_ttl ;
int min_wins_ttl ;
1996-06-07 07:34:22 +04:00
int ReadSize ;
1997-12-16 12:20:34 +03:00
int lm_announce ;
int lm_interval ;
1997-05-20 04:32:51 +04:00
int shmem_size ;
1997-06-11 05:03:06 +04:00
int client_code_page ;
1997-07-30 23:17:51 +04:00
int announce_as ; /* This is initialised in init_globals */
1998-05-27 04:30:52 +04:00
int machine_password_timeout ;
1998-08-03 23:07:55 +04:00
int change_notify_timeout ;
1998-08-29 01:46:29 +04:00
int stat_cache_size ;
1998-11-10 23:51:25 +03:00
int map_to_guest ;
1999-12-13 16:27:58 +03:00
int min_passwd_length ;
int oplock_break_wait_time ;
1998-07-29 07:08:05 +04:00
# ifdef WITH_LDAP
1998-05-06 21:43:44 +04:00
int ldap_port ;
1998-07-29 07:08:05 +04:00
# endif /* WITH_LDAP */
# ifdef WITH_SSL
1998-06-16 05:35:52 +04:00
int sslVersion ;
char * sslHostsRequire ;
char * sslHostsResign ;
char * sslCaCertDir ;
char * sslCaCertFile ;
char * sslCert ;
char * sslPrivKey ;
char * sslClientCert ;
char * sslClientPrivKey ;
char * sslCiphers ;
BOOL sslEnabled ;
BOOL sslReqClientCert ;
BOOL sslReqServerCert ;
BOOL sslCompatibility ;
1998-07-29 07:08:05 +04:00
# endif /* WITH_SSL */
1997-07-06 16:06:23 +04:00
BOOL bDNSproxy ;
1996-06-06 15:43:09 +04:00
BOOL bWINSsupport ;
BOOL bWINSproxy ;
1997-05-20 04:32:51 +04:00
BOOL bLocalMaster ;
1996-06-06 15:43:09 +04:00
BOOL bPreferredMaster ;
BOOL bDomainMaster ;
BOOL bDomainLogons ;
BOOL bEncryptPasswords ;
1998-04-30 05:39:22 +04:00
BOOL bUpdateEncrypt ;
1996-06-06 15:43:09 +04:00
BOOL bStripDot ;
BOOL bNullPasswords ;
BOOL bLoadPrinters ;
BOOL bUseRhosts ;
BOOL bReadRaw ;
BOOL bWriteRaw ;
BOOL bReadPrediction ;
BOOL bReadbmpx ;
BOOL bSyslogOnly ;
BOOL bBrowseList ;
1997-05-07 21:56:46 +04:00
BOOL bUnixRealname ;
BOOL bNISHomeMap ;
1997-06-17 00:49:15 +04:00
BOOL bTimeServer ;
1997-10-20 22:52:04 +04:00
BOOL bBindInterfacesOnly ;
1998-03-27 22:59:14 +03:00
BOOL bUnixPasswdSync ;
1998-04-21 03:07:28 +04:00
BOOL bPasswdChatDebug ;
1998-07-31 01:18:57 +04:00
BOOL bOleLockingCompat ;
1998-08-03 23:07:55 +04:00
BOOL bTimestampLogs ;
1998-09-05 07:14:40 +04:00
BOOL bNTSmbSupport ;
1998-10-18 23:29:19 +04:00
BOOL bNTPipeSupport ;
1999-12-13 16:27:58 +03:00
BOOL bNTAclSupport ;
1998-09-06 05:37:14 +04:00
BOOL bStatCache ;
1998-09-18 21:50:18 +04:00
BOOL bKernelOplocks ;
1999-12-13 16:27:58 +03:00
BOOL bAllowTrustedDomains ;
BOOL bRestrictAnonymous ;
BOOL bDebugHiresTimestamp ;
BOOL bDebugPid ;
BOOL bDebugUid ;
1996-05-04 11:50:46 +04:00
} global ;
static global Globals ;
/*
* This structure describes a single service .
*/
typedef struct
{
BOOL valid ;
char * szService ;
char * szPath ;
char * szUsername ;
char * szGuestaccount ;
char * szInvalidUsers ;
char * szValidUsers ;
char * szAdminUsers ;
char * szCopy ;
char * szInclude ;
char * szPreExec ;
char * szPostExec ;
char * szRootPreExec ;
char * szRootPostExec ;
char * szPrintcommand ;
char * szLpqcommand ;
char * szLprmcommand ;
char * szLppausecommand ;
char * szLpresumecommand ;
1998-07-16 04:06:29 +04:00
char * szQueuepausecommand ;
char * szQueueresumecommand ;
1996-05-04 11:50:46 +04:00
char * szPrintername ;
1996-08-13 12:57:55 +04:00
char * szPrinterDriver ;
1997-10-28 22:32:59 +03:00
char * szPrinterDriverLocation ;
1996-05-04 11:50:46 +04:00
char * szDontdescend ;
char * szHostsallow ;
char * szHostsdeny ;
char * szMagicScript ;
char * szMagicOutput ;
char * szMangledMap ;
1997-07-06 17:48:10 +04:00
char * szVetoFiles ;
char * szHideFiles ;
1997-11-17 22:16:38 +03:00
char * szVetoOplockFiles ;
1996-05-04 11:50:46 +04:00
char * comment ;
char * force_user ;
char * force_group ;
char * readlist ;
char * writelist ;
char * volume ;
1998-09-20 19:40:52 +04:00
char * fstype ;
1996-05-04 11:50:46 +04:00
int iMinPrintSpace ;
1999-12-13 16:27:58 +03:00
int iWriteCacheSize ;
1997-07-25 02:42:16 +04:00
int iCreate_mask ;
1997-06-19 04:18:23 +04:00
int iCreate_force_mode ;
1999-12-13 16:27:58 +03:00
int iSecurity_mask ;
int iSecurity_force_mode ;
1997-07-25 02:42:16 +04:00
int iDir_mask ;
1997-06-19 04:18:23 +04:00
int iDir_force_mode ;
1999-12-13 16:27:58 +03:00
int iDir_Security_mask ;
int iDir_Security_force_mode ;
1996-05-04 11:50:46 +04:00
int iMaxConnections ;
int iDefaultCase ;
1997-12-03 06:37:02 +03:00
int iPrinting ;
1999-12-13 16:27:58 +03:00
int iOplockContentionLimit ;
1996-05-04 11:50:46 +04:00
BOOL bAlternatePerm ;
1999-12-13 16:27:58 +03:00
BOOL bPreexecClose ;
BOOL bRootpreexecClose ;
1996-05-04 11:50:46 +04:00
BOOL bRevalidate ;
BOOL bCaseSensitive ;
BOOL bCasePreserve ;
BOOL bShortCasePreserve ;
BOOL bCaseMangle ;
BOOL status ;
BOOL bHideDotFiles ;
BOOL bBrowseable ;
BOOL bAvailable ;
BOOL bRead_only ;
BOOL bNo_set_dir ;
BOOL bGuest_only ;
BOOL bGuest_ok ;
BOOL bPrint_ok ;
BOOL bPostscript ;
BOOL bMap_system ;
BOOL bMap_hidden ;
BOOL bMap_archive ;
BOOL bLocking ;
BOOL bStrictLocking ;
2000-01-12 06:09:17 +03:00
# ifdef WITH_UTMP
BOOL bUtmp ;
# endif
1996-05-04 11:50:46 +04:00
BOOL bShareModes ;
1997-10-02 07:14:32 +04:00
BOOL bOpLocks ;
1999-12-13 16:27:58 +03:00
BOOL bLevel2OpLocks ;
1996-05-04 11:50:46 +04:00
BOOL bOnlyUser ;
BOOL bMangledNames ;
BOOL bWidelinks ;
1997-07-19 00:21:32 +04:00
BOOL bSymlinks ;
1996-05-04 11:50:46 +04:00
BOOL bSyncAlways ;
1998-07-28 22:15:31 +04:00
BOOL bStrictSync ;
1996-05-04 11:50:46 +04:00
char magic_char ;
BOOL * copymap ;
1996-05-31 19:13:29 +04:00
BOOL bDeleteReadonly ;
1996-10-05 14:41:13 +04:00
BOOL bFakeOplocks ;
1997-09-17 05:29:53 +04:00
BOOL bDeleteVetoFiles ;
1997-10-20 22:52:04 +04:00
BOOL bDosFiletimes ;
1998-02-13 10:11:58 +03:00
BOOL bDosFiletimeResolution ;
1998-03-16 23:59:47 +03:00
BOOL bFakeDirCreateTimes ;
1998-09-08 23:21:04 +04:00
BOOL bBlockingLocks ;
2000-01-14 04:41:04 +03:00
BOOL bInheritPerms ;
1996-05-04 11:50:46 +04:00
char dummy [ 3 ] ; /* for alignment */
} service ;
/* This is a default service used to prime a services structure */
static service sDefault =
{
True , /* valid */
NULL , /* szService */
NULL , /* szPath */
NULL , /* szUsername */
1997-07-24 21:25:11 +04:00
NULL , /* szGuestAccount - this is set in init_globals() */
1996-05-04 11:50:46 +04:00
NULL , /* szInvalidUsers */
NULL , /* szValidUsers */
NULL , /* szAdminUsers */
NULL , /* szCopy */
NULL , /* szInclude */
NULL , /* szPreExec */
NULL , /* szPostExec */
NULL , /* szRootPreExec */
NULL , /* szRootPostExec */
NULL , /* szPrintcommand */
NULL , /* szLpqcommand */
NULL , /* szLprmcommand */
NULL , /* szLppausecommand */
NULL , /* szLpresumecommand */
1998-07-16 04:06:29 +04:00
NULL , /* szQueuepausecommand */
NULL , /* szQueueresumecommand */
1996-05-04 11:50:46 +04:00
NULL , /* szPrintername */
1997-07-24 21:25:11 +04:00
NULL , /* szPrinterDriver - this is set in init_globals() */
1997-10-28 22:32:59 +03:00
NULL , /* szPrinterDriverLocation */
1996-05-04 11:50:46 +04:00
NULL , /* szDontdescend */
NULL , /* szHostsallow */
NULL , /* szHostsdeny */
NULL , /* szMagicScript */
NULL , /* szMagicOutput */
NULL , /* szMangledMap */
1997-07-06 17:48:10 +04:00
NULL , /* szVetoFiles */
1997-07-24 21:25:11 +04:00
NULL , /* szHideFiles */
1997-11-17 22:16:38 +03:00
NULL , /* szVetoOplockFiles */
1996-05-04 11:50:46 +04:00
NULL , /* comment */
NULL , /* force user */
NULL , /* force group */
NULL , /* readlist */
NULL , /* writelist */
NULL , /* volume */
1998-09-20 19:40:52 +04:00
NULL , /* fstype */
1996-05-04 11:50:46 +04:00
0 , /* iMinPrintSpace */
1999-12-13 16:27:58 +03:00
0 , /* iWriteCacheSize */
1997-07-25 02:42:16 +04:00
0744 , /* iCreate_mask */
1997-07-01 05:19:13 +04:00
0000 , /* iCreate_force_mode */
1999-12-13 16:27:58 +03:00
- 1 , /* iSecurity_mask */
- 1 , /* iSecurity_force_mode */
1997-07-25 02:42:16 +04:00
0755 , /* iDir_mask */
1997-06-19 04:18:23 +04:00
0000 , /* iDir_force_mode */
1999-12-13 16:27:58 +03:00
- 1 , /* iDir_Security_mask */
- 1 , /* iDir_Security_force_mode */
1996-05-04 11:50:46 +04:00
0 , /* iMaxConnections */
CASE_LOWER , /* iDefaultCase */
1997-12-03 06:37:02 +03:00
DEFAULT_PRINTING , /* iPrinting */
1999-12-13 16:27:58 +03:00
2 , /* iOplockContentionLimit */
1996-05-04 11:50:46 +04:00
False , /* bAlternatePerm */
1999-12-13 16:27:58 +03:00
False , /* bPreexecClose */
False , /* bRootpreexecClose */
1996-05-04 11:50:46 +04:00
False , /* revalidate */
False , /* case sensitive */
1998-06-06 00:46:05 +04:00
True , /* case preserve */
True , /* short case preserve */
1996-05-04 11:50:46 +04:00
False , /* case mangle */
True , /* status */
True , /* bHideDotFiles */
True , /* bBrowseable */
True , /* bAvailable */
True , /* bRead_only */
True , /* bNo_set_dir */
False , /* bGuest_only */
False , /* bGuest_ok */
False , /* bPrint_ok */
False , /* bPostscript */
False , /* bMap_system */
False , /* bMap_hidden */
True , /* bMap_archive */
True , /* bLocking */
False , /* bStrictLocking */
2000-01-12 06:09:17 +03:00
# ifdef WITH_UTMP
False , /* bUtmp */
# endif
1996-05-04 11:50:46 +04:00
True , /* bShareModes */
1997-10-02 07:14:32 +04:00
True , /* bOpLocks */
1999-12-13 16:27:58 +03:00
True , /* bLevel2OpLocks */
1996-05-04 11:50:46 +04:00
False , /* bOnlyUser */
True , /* bMangledNames */
True , /* bWidelinks */
1997-07-19 00:21:32 +04:00
True , /* bSymlinks */
1996-05-04 11:50:46 +04:00
False , /* bSyncAlways */
1998-07-28 22:15:31 +04:00
False , /* bStrictSync */
1996-05-04 11:50:46 +04:00
' ~ ' , /* magic char */
NULL , /* copymap */
1996-05-31 19:13:29 +04:00
False , /* bDeleteReadonly */
1996-10-05 14:41:13 +04:00
False , /* bFakeOplocks */
1997-09-17 05:29:53 +04:00
False , /* bDeleteVetoFiles */
1997-10-20 22:52:04 +04:00
False , /* bDosFiletimes */
1998-02-13 10:11:58 +03:00
False , /* bDosFiletimeResolution */
1998-03-16 23:59:47 +03:00
False , /* bFakeDirCreateTimes */
1998-09-08 23:21:04 +04:00
True , /* bBlockingLocks */
2000-01-14 04:41:04 +03:00
False , /* bInheritPerms */
1996-05-04 11:50:46 +04:00
" " /* dummy */
} ;
/* local variables */
static service * * ServicePtrs = NULL ;
static int iNumServices = 0 ;
static int iServiceIndex = 0 ;
static BOOL bInGlobalSection = True ;
static BOOL bGlobalOnly = False ;
1997-07-30 23:17:51 +04:00
static int default_server_announce ;
1996-05-04 11:50:46 +04:00
# define NUMPARAMETERS (sizeof(parm_table) / sizeof(struct parm_struct))
/* prototypes for the special type handlers */
static BOOL handle_valid_chars ( char * pszParmValue , char * * ptr ) ;
static BOOL handle_include ( char * pszParmValue , char * * ptr ) ;
static BOOL handle_copy ( char * pszParmValue , char * * ptr ) ;
1997-11-22 10:09:12 +03:00
static BOOL handle_character_set ( char * pszParmValue , char * * ptr ) ;
static BOOL handle_coding_system ( char * pszParmValue , char * * ptr ) ;
1999-12-13 16:27:58 +03:00
static BOOL handle_client_code_page ( char * pszParmValue , char * * ptr ) ;
1996-05-04 11:50:46 +04:00
1997-08-05 05:31:55 +04:00
static void set_default_server_announce_type ( void ) ;
1997-11-22 10:09:12 +03:00
static struct enum_list enum_protocol [ ] = { { PROTOCOL_NT1 , " NT1 " } , { PROTOCOL_LANMAN2 , " LANMAN2 " } ,
{ PROTOCOL_LANMAN1 , " LANMAN1 " } , { PROTOCOL_CORE , " CORE " } ,
{ PROTOCOL_COREPLUS , " COREPLUS " } ,
{ PROTOCOL_COREPLUS , " CORE+ " } , { - 1 , NULL } } ;
1998-04-22 04:56:38 +04:00
static struct enum_list enum_security [ ] = { { SEC_SHARE , " SHARE " } , { SEC_USER , " USER " } ,
{ SEC_SERVER , " SERVER " } , { SEC_DOMAIN , " DOMAIN " } ,
{ - 1 , NULL } } ;
1997-11-22 10:09:12 +03:00
static struct enum_list enum_printing [ ] = { { PRINT_SYSV , " sysv " } , { PRINT_AIX , " aix " } ,
{ PRINT_HPUX , " hpux " } , { PRINT_BSD , " bsd " } ,
{ PRINT_QNX , " qnx " } , { PRINT_PLP , " plp " } ,
1998-04-02 05:01:24 +04:00
{ PRINT_LPRNG , " lprng " } , { PRINT_SOFTQ , " softq " } ,
1999-12-13 16:27:58 +03:00
{ PRINT_CUPS , " cups " } , { - 1 , NULL } } ;
1997-11-22 10:09:12 +03:00
1999-12-13 16:27:58 +03:00
/* Types of machine we can announce as. */
# define ANNOUNCE_AS_NT_SERVER 1
# define ANNOUNCE_AS_WIN95 2
# define ANNOUNCE_AS_WFW 3
# define ANNOUNCE_AS_NT_WORKSTATION 4
static struct enum_list enum_announce_as [ ] = { { ANNOUNCE_AS_NT_SERVER , " NT " } , { ANNOUNCE_AS_NT_SERVER , " NT Server " } , { ANNOUNCE_AS_NT_WORKSTATION , " NT Workstation " } , { ANNOUNCE_AS_WIN95 , " win95 " } , { ANNOUNCE_AS_WFW , " WfW " } , { - 1 , NULL } } ;
1997-11-22 10:09:12 +03:00
static struct enum_list enum_case [ ] = { { CASE_LOWER , " lower " } , { CASE_UPPER , " upper " } , { - 1 , NULL } } ;
1999-12-13 16:27:58 +03:00
static struct enum_list enum_lm_announce [ ] = { { 0 , " False " } , { 1 , " True " } , { 2 , " Auto " } , { - 1 , NULL } } ;
1997-12-16 12:20:34 +03:00
1998-11-10 23:51:25 +03:00
/*
Do you want session setups at user level security with a invalid
password to be rejected or allowed in as guest ? WinNT rejects them
but it can be a pain as it means " net view " needs to use a password
You have 3 choices in the setting of map_to_guest :
" Never " means session setups with an invalid password
are rejected . This is the default .
" Bad User " means session setups with an invalid password
are rejected , unless the username does not exist , in which case it
is treated as a guest login
" Bad Password " means session setups with an invalid password
are treated as a guest login
Note that map_to_guest only has an effect in user or server
level security .
*/
static struct enum_list enum_map_to_guest [ ] = { { NEVER_MAP_TO_GUEST , " Never " } , { MAP_TO_GUEST_ON_BAD_USER , " Bad User " } , { MAP_TO_GUEST_ON_BAD_PASSWORD , " Bad Password " } , { - 1 , NULL } } ;
1998-07-29 07:08:05 +04:00
# ifdef WITH_SSL
1998-06-16 22:25:36 +04:00
static struct enum_list enum_ssl_version [ ] = { { SMB_SSL_V2 , " ssl2 " } , { SMB_SSL_V3 , " ssl3 " } ,
1998-06-16 05:35:52 +04:00
{ SMB_SSL_V23 , " ssl2or3 " } , { SMB_SSL_TLS1 , " tls1 " } , { - 1 , NULL } } ;
# endif
1998-03-14 11:27:41 +03:00
/* note that we do not initialise the defaults union - it is not allowed in ANSI C */
1998-03-08 17:14:49 +03:00
static struct parm_struct parm_table [ ] =
1996-05-04 11:50:46 +04:00
{
1998-03-14 11:27:41 +03:00
{ " Base Options " , P_SEP , P_SEPARATOR } ,
2000-01-29 03:03:50 +03:00
{ " coding system " , P_STRING , P_GLOBAL , & Globals . szCodingSystem , handle_coding_system , NULL , 0 } ,
{ " client code page " , P_INTEGER , P_GLOBAL , & Globals . client_code_page , handle_client_code_page , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " comment " , P_STRING , P_LOCAL , & sDefault . comment , NULL , NULL , FLAG_BASIC | FLAG_SHARE | FLAG_PRINT | FLAG_DOS_STRING } ,
{ " path " , P_STRING , P_LOCAL , & sDefault . szPath , NULL , NULL , FLAG_BASIC | FLAG_SHARE | FLAG_PRINT | FLAG_DOS_STRING } ,
{ " directory " , P_STRING , P_LOCAL , & sDefault . szPath , NULL , NULL , FLAG_DOS_STRING } ,
{ " workgroup " , P_USTRING , P_GLOBAL , & Globals . szWorkGroup , NULL , NULL , FLAG_BASIC | FLAG_DOS_STRING } ,
{ " netbios name " , P_UGSTRING , P_GLOBAL , global_myname , NULL , NULL , FLAG_BASIC | FLAG_DOS_STRING } ,
{ " netbios aliases " , P_STRING , P_GLOBAL , & Globals . szNetbiosAliases , NULL , NULL , FLAG_DOS_STRING } ,
2000-01-07 11:48:04 +03:00
{ " netbios scope " , P_UGSTRING , P_GLOBAL , global_scope , NULL , NULL , FLAG_DOS_STRING } ,
1999-12-13 16:27:58 +03:00
{ " server string " , P_STRING , P_GLOBAL , & Globals . szServerString , NULL , NULL , FLAG_BASIC | FLAG_DOS_STRING } ,
1998-03-14 11:27:41 +03:00
{ " interfaces " , P_STRING , P_GLOBAL , & Globals . szInterfaces , NULL , NULL , FLAG_BASIC } ,
{ " bind interfaces only " , P_BOOL , P_GLOBAL , & Globals . bBindInterfacesOnly , NULL , NULL , 0 } ,
{ " Security Options " , P_SEP , P_SEPARATOR } ,
1998-03-08 17:14:49 +03:00
{ " security " , P_ENUM , P_GLOBAL , & Globals . security , NULL , enum_security , FLAG_BASIC } ,
{ " encrypt passwords " , P_BOOL , P_GLOBAL , & Globals . bEncryptPasswords , NULL , NULL , FLAG_BASIC } ,
1998-04-30 05:39:22 +04:00
{ " update encrypted " , P_BOOL , P_GLOBAL , & Globals . bUpdateEncrypt , NULL , NULL , FLAG_BASIC } ,
1999-12-13 16:27:58 +03:00
{ " allow trusted domains " , P_BOOL , P_GLOBAL , & Globals . bAllowTrustedDomains , NULL , NULL , 0 } ,
{ " alternate permissions " , P_BOOL , P_LOCAL , & sDefault . bAlternatePerm , NULL , NULL , FLAG_GLOBAL | FLAG_DEPRECATED } ,
{ " hosts equiv " , P_STRING , P_GLOBAL , & Globals . szHostsEquiv , NULL , NULL , 0 } ,
{ " min passwd length " , P_INTEGER , P_GLOBAL , & Globals . min_passwd_length , NULL , NULL , 0 } ,
{ " min password length " , P_INTEGER , P_GLOBAL , & Globals . min_passwd_length , NULL , NULL , 0 } ,
1998-11-10 23:51:25 +03:00
{ " map to guest " , P_ENUM , P_GLOBAL , & Globals . map_to_guest , NULL , enum_map_to_guest , 0 } ,
1998-03-08 17:14:49 +03:00
{ " null passwords " , P_BOOL , P_GLOBAL , & Globals . bNullPasswords , NULL , NULL , 0 } ,
{ " password server " , P_STRING , P_GLOBAL , & Globals . szPasswordServer , NULL , NULL , 0 } ,
{ " smb passwd file " , P_STRING , P_GLOBAL , & Globals . szSMBPasswdFile , NULL , NULL , 0 } ,
{ " root directory " , P_STRING , P_GLOBAL , & Globals . szRootdir , NULL , NULL , 0 } ,
{ " root dir " , P_STRING , P_GLOBAL , & Globals . szRootdir , NULL , NULL , 0 } ,
{ " root " , P_STRING , P_GLOBAL , & Globals . szRootdir , NULL , NULL , 0 } ,
{ " passwd program " , P_STRING , P_GLOBAL , & Globals . szPasswdProgram , NULL , NULL , 0 } ,
{ " passwd chat " , P_STRING , P_GLOBAL , & Globals . szPasswdChat , NULL , NULL , 0 } ,
1998-04-21 03:07:28 +04:00
{ " passwd chat debug " , P_BOOL , P_GLOBAL , & Globals . bPasswdChatDebug , NULL , NULL , 0 } ,
1998-03-14 11:27:41 +03:00
{ " username map " , P_STRING , P_GLOBAL , & Globals . szUsernameMap , NULL , NULL , 0 } ,
{ " password level " , P_INTEGER , P_GLOBAL , & Globals . pwordlevel , NULL , NULL , 0 } ,
{ " username level " , P_INTEGER , P_GLOBAL , & Globals . unamelevel , NULL , NULL , 0 } ,
1998-03-27 22:59:14 +03:00
{ " unix password sync " , P_BOOL , P_GLOBAL , & Globals . bUnixPasswdSync , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " restrict anonymous " , P_BOOL , P_GLOBAL , & Globals . bRestrictAnonymous , NULL , NULL , 0 } ,
{ " revalidate " , P_BOOL , P_LOCAL , & sDefault . bRevalidate , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE } ,
{ " use rhosts " , P_BOOL , P_GLOBAL , & Globals . bUseRhosts , NULL , NULL , 0 } ,
{ " username " , P_STRING , P_LOCAL , & sDefault . szUsername , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE } ,
1998-03-14 11:27:41 +03:00
{ " user " , P_STRING , P_LOCAL , & sDefault . szUsername , NULL , NULL , 0 } ,
{ " users " , P_STRING , P_LOCAL , & sDefault . szUsername , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " guest account " , P_STRING , P_LOCAL , & sDefault . szGuestaccount , NULL , NULL , FLAG_BASIC | FLAG_SHARE | FLAG_PRINT | FLAG_GLOBAL } ,
{ " invalid users " , P_STRING , P_LOCAL , & sDefault . szInvalidUsers , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE } ,
{ " valid users " , P_STRING , P_LOCAL , & sDefault . szValidUsers , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE } ,
{ " admin users " , P_STRING , P_LOCAL , & sDefault . szAdminUsers , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE } ,
{ " read list " , P_STRING , P_LOCAL , & sDefault . readlist , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE } ,
{ " write list " , P_STRING , P_LOCAL , & sDefault . writelist , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE } ,
{ " force user " , P_STRING , P_LOCAL , & sDefault . force_user , NULL , NULL , FLAG_SHARE } ,
{ " force group " , P_STRING , P_LOCAL , & sDefault . force_group , NULL , NULL , FLAG_SHARE } ,
1998-03-14 11:27:41 +03:00
{ " group " , P_STRING , P_LOCAL , & sDefault . force_group , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " read only " , P_BOOL , P_LOCAL , & sDefault . bRead_only , NULL , NULL , FLAG_BASIC | FLAG_SHARE } ,
1998-03-14 11:27:41 +03:00
{ " write ok " , P_BOOLREV , P_LOCAL , & sDefault . bRead_only , NULL , NULL , 0 } ,
{ " writeable " , P_BOOLREV , P_LOCAL , & sDefault . bRead_only , NULL , NULL , 0 } ,
{ " writable " , P_BOOLREV , P_LOCAL , & sDefault . bRead_only , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " create mask " , P_OCTAL , P_LOCAL , & sDefault . iCreate_mask , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE } ,
1998-03-14 11:27:41 +03:00
{ " create mode " , P_OCTAL , P_LOCAL , & sDefault . iCreate_mask , NULL , NULL , FLAG_GLOBAL } ,
1999-12-13 16:27:58 +03:00
{ " force create mode " , P_OCTAL , P_LOCAL , & sDefault . iCreate_force_mode , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE } ,
{ " security mask " , P_OCTAL , P_LOCAL , & sDefault . iSecurity_mask , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE } ,
{ " force security mode " , P_OCTAL , P_LOCAL , & sDefault . iSecurity_force_mode , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE } ,
{ " directory mask " , P_OCTAL , P_LOCAL , & sDefault . iDir_mask , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE } ,
1998-03-14 11:27:41 +03:00
{ " directory mode " , P_OCTAL , P_LOCAL , & sDefault . iDir_mask , NULL , NULL , FLAG_GLOBAL } ,
1999-12-13 16:27:58 +03:00
{ " force directory mode " , P_OCTAL , P_LOCAL , & sDefault . iDir_force_mode , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE } ,
{ " directory security mask " , P_OCTAL , P_LOCAL , & sDefault . iDir_Security_mask , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE } ,
{ " force directory security mode " , P_OCTAL , P_LOCAL , & sDefault . iDir_Security_force_mode , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE } ,
2000-01-14 04:41:04 +03:00
{ " inherit permissions " , P_BOOL , P_LOCAL , & sDefault . bInheritPerms , NULL , NULL , FLAG_SHARE } ,
1999-12-13 16:27:58 +03:00
{ " guest only " , P_BOOL , P_LOCAL , & sDefault . bGuest_only , NULL , NULL , FLAG_SHARE } ,
1998-03-14 11:27:41 +03:00
{ " only guest " , P_BOOL , P_LOCAL , & sDefault . bGuest_only , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " guest ok " , P_BOOL , P_LOCAL , & sDefault . bGuest_ok , NULL , NULL , FLAG_BASIC | FLAG_SHARE | FLAG_PRINT } ,
1998-03-14 11:27:41 +03:00
{ " public " , P_BOOL , P_LOCAL , & sDefault . bGuest_ok , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " only user " , P_BOOL , P_LOCAL , & sDefault . bOnlyUser , NULL , NULL , FLAG_SHARE } ,
{ " hosts allow " , P_STRING , P_LOCAL , & sDefault . szHostsallow , NULL , NULL , FLAG_GLOBAL | FLAG_BASIC | FLAG_SHARE | FLAG_PRINT } ,
1998-03-14 11:27:41 +03:00
{ " allow hosts " , P_STRING , P_LOCAL , & sDefault . szHostsallow , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " hosts deny " , P_STRING , P_LOCAL , & sDefault . szHostsdeny , NULL , NULL , FLAG_GLOBAL | FLAG_BASIC | FLAG_SHARE | FLAG_PRINT } ,
1998-03-14 11:27:41 +03:00
{ " deny hosts " , P_STRING , P_LOCAL , & sDefault . szHostsdeny , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
1998-07-29 07:08:05 +04:00
# ifdef WITH_SSL
1998-06-16 05:35:52 +04:00
{ " Secure Socket Layer Options " , P_SEP , P_SEPARATOR } ,
{ " ssl " , P_BOOL , P_GLOBAL , & Globals . sslEnabled , NULL , NULL , 0 } ,
{ " ssl hosts " , P_STRING , P_GLOBAL , & Globals . sslHostsRequire , NULL , NULL , 0 } ,
{ " ssl hosts resign " , P_STRING , P_GLOBAL , & Globals . sslHostsResign , NULL , NULL , 0 } ,
{ " ssl CA certDir " , P_STRING , P_GLOBAL , & Globals . sslCaCertDir , NULL , NULL , 0 } ,
{ " ssl CA certFile " , P_STRING , P_GLOBAL , & Globals . sslCaCertFile , NULL , NULL , 0 } ,
{ " ssl server cert " , P_STRING , P_GLOBAL , & Globals . sslCert , NULL , NULL , 0 } ,
{ " ssl server key " , P_STRING , P_GLOBAL , & Globals . sslPrivKey , NULL , NULL , 0 } ,
{ " ssl client cert " , P_STRING , P_GLOBAL , & Globals . sslClientCert , NULL , NULL , 0 } ,
{ " ssl client key " , P_STRING , P_GLOBAL , & Globals . sslClientPrivKey , NULL , NULL , 0 } ,
{ " ssl require clientcert " , P_BOOL , P_GLOBAL , & Globals . sslReqClientCert , NULL , NULL , 0 } ,
{ " ssl require servercert " , P_BOOL , P_GLOBAL , & Globals . sslReqServerCert , NULL , NULL , 0 } ,
{ " ssl ciphers " , P_STRING , P_GLOBAL , & Globals . sslCiphers , NULL , NULL , 0 } ,
{ " ssl version " , P_ENUM , P_GLOBAL , & Globals . sslVersion , NULL , enum_ssl_version , 0 } ,
{ " ssl compatibility " , P_BOOL , P_GLOBAL , & Globals . sslCompatibility , NULL , NULL , 0 } ,
1998-07-29 07:08:05 +04:00
# endif /* WITH_SSL */
1998-06-16 05:35:52 +04:00
1998-03-14 11:27:41 +03:00
{ " Logging Options " , P_SEP , P_SEPARATOR } ,
{ " log level " , P_INTEGER , P_GLOBAL , & DEBUGLEVEL , NULL , NULL , FLAG_BASIC } ,
{ " debuglevel " , P_INTEGER , P_GLOBAL , & DEBUGLEVEL , NULL , NULL , 0 } ,
{ " syslog " , P_INTEGER , P_GLOBAL , & Globals . syslog , NULL , NULL , 0 } ,
{ " syslog only " , P_BOOL , P_GLOBAL , & Globals . bSyslogOnly , NULL , NULL , 0 } ,
{ " log file " , P_STRING , P_GLOBAL , & Globals . szLogFile , NULL , NULL , 0 } ,
{ " max log size " , P_INTEGER , P_GLOBAL , & Globals . max_log_size , NULL , NULL , 0 } ,
1998-08-03 23:07:55 +04:00
{ " timestamp logs " , P_BOOL , P_GLOBAL , & Globals . bTimestampLogs , NULL , NULL , 0 } ,
1998-08-04 05:01:26 +04:00
{ " debug timestamp " , P_BOOL , P_GLOBAL , & Globals . bTimestampLogs , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " debug hires timestamp " , P_BOOL , P_GLOBAL , & Globals . bDebugHiresTimestamp , NULL , NULL , 0 } ,
{ " debug pid " , P_BOOL , P_GLOBAL , & Globals . bDebugPid , NULL , NULL , 0 } ,
{ " debug uid " , P_BOOL , P_GLOBAL , & Globals . bDebugUid , NULL , NULL , 0 } ,
{ " status " , P_BOOL , P_LOCAL , & sDefault . status , NULL , NULL , FLAG_GLOBAL | FLAG_SHARE | FLAG_PRINT } ,
1998-03-14 11:27:41 +03:00
{ " Protocol Options " , P_SEP , P_SEPARATOR } ,
{ " protocol " , P_ENUM , P_GLOBAL , & Globals . maxprotocol , NULL , enum_protocol , 0 } ,
{ " read bmpx " , P_BOOL , P_GLOBAL , & Globals . bReadbmpx , NULL , NULL , 0 } ,
{ " read raw " , P_BOOL , P_GLOBAL , & Globals . bReadRaw , NULL , NULL , 0 } ,
{ " write raw " , P_BOOL , P_GLOBAL , & Globals . bWriteRaw , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " nt smb support " , P_BOOL , P_GLOBAL , & Globals . bNTSmbSupport , NULL , NULL , 0 } ,
{ " nt pipe support " , P_BOOL , P_GLOBAL , & Globals . bNTPipeSupport , NULL , NULL , 0 } ,
{ " nt acl support " , P_BOOL , P_GLOBAL , & Globals . bNTAclSupport , NULL , NULL , 0 } ,
1998-03-14 11:27:41 +03:00
{ " announce version " , P_STRING , P_GLOBAL , & Globals . szAnnounceVersion , NULL , NULL , 0 } ,
{ " announce as " , P_ENUM , P_GLOBAL , & Globals . announce_as , NULL , enum_announce_as , 0 } ,
{ " max mux " , P_INTEGER , P_GLOBAL , & Globals . max_mux , NULL , NULL , 0 } ,
{ " max xmit " , P_INTEGER , P_GLOBAL , & Globals . max_xmit , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " name resolve order " , P_STRING , P_GLOBAL , & Globals . szNameResolveOrder , NULL , NULL , 0 } ,
1998-03-14 11:27:41 +03:00
{ " max packet " , P_INTEGER , P_GLOBAL , & Globals . max_packet , NULL , NULL , 0 } ,
{ " packet size " , P_INTEGER , P_GLOBAL , & Globals . max_packet , NULL , NULL , 0 } ,
{ " max ttl " , P_INTEGER , P_GLOBAL , & Globals . max_ttl , NULL , NULL , 0 } ,
{ " max wins ttl " , P_INTEGER , P_GLOBAL , & Globals . max_wins_ttl , NULL , NULL , 0 } ,
{ " min wins ttl " , P_INTEGER , P_GLOBAL , & Globals . min_wins_ttl , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " time server " , P_BOOL , P_GLOBAL , & Globals . bTimeServer , NULL , NULL , 0 } ,
1998-03-14 11:27:41 +03:00
{ " Tuning Options " , P_SEP , P_SEPARATOR } ,
1998-08-03 23:07:55 +04:00
{ " change notify timeout " , P_INTEGER , P_GLOBAL , & Globals . change_notify_timeout , NULL , NULL , 0 } ,
1998-08-29 01:46:29 +04:00
{ " deadtime " , P_INTEGER , P_GLOBAL , & Globals . deadtime , NULL , NULL , 0 } ,
1998-03-14 11:27:41 +03:00
{ " getwd cache " , P_BOOL , P_GLOBAL , & use_getwd_cache , NULL , NULL , 0 } ,
{ " keepalive " , P_INTEGER , P_GLOBAL , & keepalive , NULL , NULL , 0 } ,
1998-08-29 01:46:29 +04:00
{ " lpq cache time " , P_INTEGER , P_GLOBAL , & Globals . lpqcachetime , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " max connections " , P_INTEGER , P_LOCAL , & sDefault . iMaxConnections , NULL , NULL , FLAG_SHARE } ,
1998-08-29 01:46:29 +04:00
{ " max disk size " , P_INTEGER , P_GLOBAL , & Globals . maxdisksize , NULL , NULL , 0 } ,
1998-09-30 05:49:24 +04:00
{ " max open files " , P_INTEGER , P_GLOBAL , & Globals . max_open_files , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " min print space " , P_INTEGER , P_LOCAL , & sDefault . iMinPrintSpace , NULL , NULL , FLAG_PRINT } ,
1998-08-29 01:46:29 +04:00
{ " read prediction " , P_BOOL , P_GLOBAL , & Globals . bReadPrediction , NULL , NULL , 0 } ,
{ " read size " , P_INTEGER , P_GLOBAL , & Globals . ReadSize , NULL , NULL , 0 } ,
{ " shared mem size " , P_INTEGER , P_GLOBAL , & Globals . shmem_size , NULL , NULL , 0 } ,
{ " socket options " , P_GSTRING , P_GLOBAL , user_socket_options , NULL , NULL , 0 } ,
{ " stat cache size " , P_INTEGER , P_GLOBAL , & Globals . stat_cache_size , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " strict sync " , P_BOOL , P_LOCAL , & sDefault . bStrictSync , NULL , NULL , FLAG_SHARE } ,
{ " sync always " , P_BOOL , P_LOCAL , & sDefault . bSyncAlways , NULL , NULL , FLAG_SHARE } ,
{ " write cache size " , P_INTEGER , P_LOCAL , & sDefault . iWriteCacheSize , NULL , NULL , FLAG_SHARE } ,
1998-03-14 11:27:41 +03:00
{ " Printing Options " , P_SEP , P_SEPARATOR } ,
1999-12-13 16:27:58 +03:00
{ " load printers " , P_BOOL , P_GLOBAL , & Globals . bLoadPrinters , NULL , NULL , FLAG_PRINT } ,
{ " printcap name " , P_STRING , P_GLOBAL , & Globals . szPrintcapname , NULL , NULL , FLAG_PRINT } ,
1998-03-14 11:27:41 +03:00
{ " printcap " , P_STRING , P_GLOBAL , & Globals . szPrintcapname , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " printer driver file " , P_STRING , P_GLOBAL , & Globals . szDriverFile , NULL , NULL , FLAG_PRINT } ,
2000-01-20 20:16:07 +03:00
{ " printable " , P_BOOL , P_LOCAL , & sDefault . bPrint_ok , NULL , NULL , FLAG_PRINT } ,
{ " print ok " , P_BOOL , P_LOCAL , & sDefault . bPrint_ok , NULL , NULL , 0 } ,
1998-03-14 11:27:41 +03:00
{ " postscript " , P_BOOL , P_LOCAL , & sDefault . bPostscript , NULL , NULL , FLAG_PRINT } ,
{ " printing " , P_ENUM , P_LOCAL , & sDefault . iPrinting , NULL , enum_printing , FLAG_PRINT | FLAG_GLOBAL } ,
{ " print command " , P_STRING , P_LOCAL , & sDefault . szPrintcommand , NULL , NULL , FLAG_PRINT | FLAG_GLOBAL } ,
{ " lpq command " , P_STRING , P_LOCAL , & sDefault . szLpqcommand , NULL , NULL , FLAG_PRINT | FLAG_GLOBAL } ,
{ " lprm command " , P_STRING , P_LOCAL , & sDefault . szLprmcommand , NULL , NULL , FLAG_PRINT | FLAG_GLOBAL } ,
1999-12-13 16:27:58 +03:00
{ " lppause command " , P_STRING , P_LOCAL , & sDefault . szLppausecommand , NULL , NULL , FLAG_PRINT | FLAG_GLOBAL } ,
{ " lpresume command " , P_STRING , P_LOCAL , & sDefault . szLpresumecommand , NULL , NULL , FLAG_PRINT | FLAG_GLOBAL } ,
{ " queuepause command " , P_STRING , P_LOCAL , & sDefault . szQueuepausecommand , NULL , NULL , FLAG_PRINT | FLAG_GLOBAL } ,
{ " queueresume command " , P_STRING , P_LOCAL , & sDefault . szQueueresumecommand , NULL , NULL , FLAG_PRINT | FLAG_GLOBAL } ,
1998-07-16 04:06:29 +04:00
1998-03-14 11:27:41 +03:00
{ " printer name " , P_STRING , P_LOCAL , & sDefault . szPrintername , NULL , NULL , FLAG_PRINT } ,
{ " printer " , P_STRING , P_LOCAL , & sDefault . szPrintername , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " printer driver " , P_STRING , P_LOCAL , & sDefault . szPrinterDriver , NULL , NULL , FLAG_PRINT } ,
{ " printer driver location " , P_STRING , P_LOCAL , & sDefault . szPrinterDriverLocation , NULL , NULL , FLAG_PRINT | FLAG_GLOBAL } ,
1998-03-14 11:27:41 +03:00
{ " Filename Handling " , P_SEP , P_SEPARATOR } ,
{ " strip dot " , P_BOOL , P_GLOBAL , & Globals . bStripDot , NULL , NULL , 0 } ,
{ " character set " , P_STRING , P_GLOBAL , & Globals . szCharacterSet , handle_character_set , NULL , 0 } ,
{ " mangled stack " , P_INTEGER , P_GLOBAL , & Globals . mangled_stack , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " default case " , P_ENUM , P_LOCAL , & sDefault . iDefaultCase , NULL , enum_case , FLAG_SHARE } ,
{ " case sensitive " , P_BOOL , P_LOCAL , & sDefault . bCaseSensitive , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
1998-03-14 11:27:41 +03:00
{ " casesignames " , P_BOOL , P_LOCAL , & sDefault . bCaseSensitive , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " preserve case " , P_BOOL , P_LOCAL , & sDefault . bCasePreserve , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " short preserve case " , P_BOOL , P_LOCAL , & sDefault . bShortCasePreserve , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " mangle case " , P_BOOL , P_LOCAL , & sDefault . bCaseMangle , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " mangling char " , P_CHAR , P_LOCAL , & sDefault . magic_char , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " hide dot files " , P_BOOL , P_LOCAL , & sDefault . bHideDotFiles , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " delete veto files " , P_BOOL , P_LOCAL , & sDefault . bDeleteVetoFiles , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " veto files " , P_STRING , P_LOCAL , & sDefault . szVetoFiles , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL | FLAG_DOS_STRING } ,
{ " hide files " , P_STRING , P_LOCAL , & sDefault . szHideFiles , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL | FLAG_DOS_STRING } ,
{ " veto oplock files " , P_STRING , P_LOCAL , & sDefault . szVetoOplockFiles , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL | FLAG_DOS_STRING } ,
{ " map system " , P_BOOL , P_LOCAL , & sDefault . bMap_system , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " map hidden " , P_BOOL , P_LOCAL , & sDefault . bMap_hidden , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " map archive " , P_BOOL , P_LOCAL , & sDefault . bMap_archive , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " mangled names " , P_BOOL , P_LOCAL , & sDefault . bMangledNames , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " mangled map " , P_STRING , P_LOCAL , & sDefault . szMangledMap , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
1998-09-06 05:37:14 +04:00
{ " stat cache " , P_BOOL , P_GLOBAL , & Globals . bStatCache , NULL , NULL , 0 } ,
1998-03-14 11:27:41 +03:00
{ " Domain Options " , P_SEP , P_SEPARATOR } ,
1999-12-13 16:27:58 +03:00
{ " domain groups " , P_STRING , P_GLOBAL , & Globals . szDomainGroups , NULL , NULL , 0 } ,
{ " domain admin group " , P_STRING , P_GLOBAL , & Globals . szDomainAdminGroup , NULL , NULL , 0 } ,
{ " domain guest group " , P_STRING , P_GLOBAL , & Globals . szDomainGuestGroup , NULL , NULL , 0 } ,
{ " domain admin users " , P_STRING , P_GLOBAL , & Globals . szDomainAdminUsers , NULL , NULL , 0 } ,
{ " domain guest users " , P_STRING , P_GLOBAL , & Globals . szDomainGuestUsers , NULL , NULL , 0 } ,
# ifdef USING_GROUPNAME_MAP
{ " groupname map " , P_STRING , P_GLOBAL , & Globals . szGroupnameMap , NULL , NULL , 0 } ,
# endif /* USING_GROUPNAME_MAP */
1998-05-27 04:30:52 +04:00
{ " machine password timeout " , P_INTEGER , P_GLOBAL , & Globals . machine_password_timeout , NULL , NULL , 0 } ,
1998-03-12 00:11:04 +03:00
1998-03-14 11:27:41 +03:00
{ " Logon Options " , P_SEP , P_SEPARATOR } ,
1999-12-13 16:27:58 +03:00
{ " add user script " , P_STRING , P_GLOBAL , & Globals . szAddUserScript , NULL , NULL , 0 } ,
{ " delete user script " , P_STRING , P_GLOBAL , & Globals . szDelUserScript , NULL , NULL , 0 } ,
{ " logon script " , P_STRING , P_GLOBAL , & Globals . szLogonScript , NULL , NULL , FLAG_DOS_STRING } ,
{ " logon path " , P_STRING , P_GLOBAL , & Globals . szLogonPath , NULL , NULL , FLAG_DOS_STRING } ,
1998-03-08 17:14:49 +03:00
{ " logon drive " , P_STRING , P_GLOBAL , & Globals . szLogonDrive , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " logon home " , P_STRING , P_GLOBAL , & Globals . szLogonHome , NULL , NULL , FLAG_DOS_STRING } ,
1998-03-14 11:27:41 +03:00
{ " domain logons " , P_BOOL , P_GLOBAL , & Globals . bDomainLogons , NULL , NULL , 0 } ,
{ " Browse Options " , P_SEP , P_SEPARATOR } ,
1998-05-08 05:41:27 +04:00
{ " os level " , P_INTEGER , P_GLOBAL , & Globals . os_level , NULL , NULL , FLAG_BASIC } ,
1999-12-13 16:27:58 +03:00
{ " lm announce " , P_ENUM , P_GLOBAL , & Globals . lm_announce , NULL , enum_lm_announce , 0 } ,
1998-03-08 17:14:49 +03:00
{ " lm interval " , P_INTEGER , P_GLOBAL , & Globals . lm_interval , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " preferred master " , P_BOOL , P_GLOBAL , & Globals . bPreferredMaster , NULL , NULL , FLAG_BASIC } ,
{ " prefered master " , P_BOOL , P_GLOBAL , & Globals . bPreferredMaster , NULL , NULL , 0 } ,
1998-05-08 05:41:27 +04:00
{ " local master " , P_BOOL , P_GLOBAL , & Globals . bLocalMaster , NULL , NULL , FLAG_BASIC } ,
1999-12-13 16:27:58 +03:00
{ " domain master " , P_BOOL , P_GLOBAL , & Globals . bDomainMaster , NULL , NULL , FLAG_BASIC } ,
1998-03-08 17:14:49 +03:00
{ " browse list " , P_BOOL , P_GLOBAL , & Globals . bBrowseList , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " browseable " , P_BOOL , P_LOCAL , & sDefault . bBrowseable , NULL , NULL , FLAG_BASIC | FLAG_SHARE | FLAG_PRINT } ,
1998-03-14 11:27:41 +03:00
{ " browsable " , P_BOOL , P_LOCAL , & sDefault . bBrowseable , NULL , NULL , 0 } ,
{ " WINS Options " , P_SEP , P_SEPARATOR } ,
{ " dns proxy " , P_BOOL , P_GLOBAL , & Globals . bDNSproxy , NULL , NULL , 0 } ,
{ " wins proxy " , P_BOOL , P_GLOBAL , & Globals . bWINSproxy , NULL , NULL , 0 } ,
{ " wins server " , P_STRING , P_GLOBAL , & Globals . szWINSserver , NULL , NULL , FLAG_BASIC } ,
1998-09-18 03:06:57 +04:00
{ " wins support " , P_BOOL , P_GLOBAL , & Globals . bWINSsupport , NULL , NULL , FLAG_BASIC } ,
1999-12-13 16:27:58 +03:00
{ " wins hook " , P_STRING , P_GLOBAL , & Globals . szWINSHook , NULL , NULL , 0 } ,
1998-03-14 11:27:41 +03:00
{ " Locking Options " , P_SEP , P_SEPARATOR } ,
1999-12-13 16:27:58 +03:00
{ " blocking locks " , P_BOOL , P_LOCAL , & sDefault . bBlockingLocks , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " fake oplocks " , P_BOOL , P_LOCAL , & sDefault . bFakeOplocks , NULL , NULL , FLAG_SHARE } ,
1998-09-18 21:50:18 +04:00
{ " kernel oplocks " , P_BOOL , P_GLOBAL , & Globals . bKernelOplocks , NULL , NULL , FLAG_GLOBAL } ,
1999-12-13 16:27:58 +03:00
{ " locking " , P_BOOL , P_LOCAL , & sDefault . bLocking , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
2000-01-12 06:09:17 +03:00
# ifdef WITH_UTMP
{ " utmp " , P_BOOL , P_LOCAL , & sDefault . bUtmp , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
# endif
1998-09-18 03:06:57 +04:00
{ " ole locking compatibility " , P_BOOL , P_GLOBAL , & Globals . bOleLockingCompat , NULL , NULL , FLAG_GLOBAL } ,
1999-12-13 16:27:58 +03:00
{ " oplocks " , P_BOOL , P_LOCAL , & sDefault . bOpLocks , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " level2 oplocks " , P_BOOL , P_LOCAL , & sDefault . bLevel2OpLocks , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " oplock break wait time " , P_INTEGER , P_GLOBAL , & Globals . oplock_break_wait_time , NULL , NULL , FLAG_GLOBAL } ,
{ " oplock contention limit " , P_INTEGER , P_LOCAL , & sDefault . iOplockContentionLimit , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " strict locking " , P_BOOL , P_LOCAL , & sDefault . bStrictLocking , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " share modes " , P_BOOL , P_LOCAL , & sDefault . bShareModes , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
1998-03-14 11:27:41 +03:00
1998-07-29 07:08:05 +04:00
# ifdef WITH_LDAP
1998-05-06 21:43:44 +04:00
{ " Ldap Options " , P_SEP , P_SEPARATOR } ,
{ " ldap server " , P_STRING , P_GLOBAL , & Globals . szLdapServer , NULL , NULL , 0 } ,
{ " ldap port " , P_INTEGER , P_GLOBAL , & Globals . ldap_port , NULL , NULL , 0 } ,
{ " ldap suffix " , P_STRING , P_GLOBAL , & Globals . szLdapSuffix , NULL , NULL , 0 } ,
1999-12-13 16:27:58 +03:00
{ " ldap filter " , P_STRING , P_GLOBAL , & Globals . szLdapFilter , NULL , NULL , 0 } ,
{ " ldap root " , P_STRING , P_GLOBAL , & Globals . szLdapRoot , NULL , NULL , 0 } ,
{ " ldap root passwd " , P_STRING , P_GLOBAL , & Globals . szLdapRootPassword , NULL , NULL , 0 } ,
1998-07-29 07:08:05 +04:00
# endif /* WITH_LDAP */
1998-05-06 21:43:44 +04:00
1998-03-14 11:27:41 +03:00
{ " Miscellaneous Options " , P_SEP , P_SEPARATOR } ,
{ " smbrun " , P_STRING , P_GLOBAL , & Globals . szSmbrun , NULL , NULL , 0 } ,
{ " config file " , P_STRING , P_GLOBAL , & Globals . szConfigFile , NULL , NULL , FLAG_HIDE } ,
{ " preload " , P_STRING , P_GLOBAL , & Globals . szAutoServices , NULL , NULL , 0 } ,
{ " auto services " , P_STRING , P_GLOBAL , & Globals . szAutoServices , NULL , NULL , 0 } ,
{ " lock dir " , P_STRING , P_GLOBAL , & Globals . szLockDir , NULL , NULL , 0 } ,
{ " lock directory " , P_STRING , P_GLOBAL , & Globals . szLockDir , NULL , NULL , 0 } ,
2000-01-12 06:09:17 +03:00
# ifdef WITH_UTMP
{ " utmp dir " , P_STRING , P_GLOBAL , & Globals . szUtmpDir , NULL , NULL , 0 } ,
{ " utmp directory " , P_STRING , P_GLOBAL , & Globals . szUtmpDir , NULL , NULL , 0 } ,
# endif /* WITH_UTMP */
1998-03-14 11:27:41 +03:00
{ " default service " , P_STRING , P_GLOBAL , & Globals . szDefaultService , NULL , NULL , 0 } ,
{ " default " , P_STRING , P_GLOBAL , & Globals . szDefaultService , NULL , NULL , 0 } ,
{ " message command " , P_STRING , P_GLOBAL , & Globals . szMsgCommand , NULL , NULL , 0 } ,
{ " dfree command " , P_STRING , P_GLOBAL , & Globals . szDfree , NULL , NULL , 0 } ,
{ " valid chars " , P_STRING , P_GLOBAL , & Globals . szValidChars , handle_valid_chars , NULL , 0 } ,
{ " remote announce " , P_STRING , P_GLOBAL , & Globals . szRemoteAnnounce , NULL , NULL , 0 } ,
{ " remote browse sync " , P_STRING , P_GLOBAL , & Globals . szRemoteBrowseSync , NULL , NULL , 0 } ,
{ " socket address " , P_STRING , P_GLOBAL , & Globals . szSocketAddress , NULL , NULL , 0 } ,
{ " homedir map " , P_STRING , P_GLOBAL , & Globals . szNISHomeMapName , NULL , NULL , 0 } ,
{ " time offset " , P_INTEGER , P_GLOBAL , & extra_time_offset , NULL , NULL , 0 } ,
1998-03-08 17:14:49 +03:00
{ " unix realname " , P_BOOL , P_GLOBAL , & Globals . bUnixRealname , NULL , NULL , 0 } ,
{ " NIS homedir " , P_BOOL , P_GLOBAL , & Globals . bNISHomeMap , NULL , NULL , 0 } ,
{ " -valid " , P_BOOL , P_LOCAL , & sDefault . valid , NULL , NULL , FLAG_HIDE } ,
{ " copy " , P_STRING , P_LOCAL , & sDefault . szCopy , handle_copy , NULL , FLAG_HIDE } ,
{ " include " , P_STRING , P_LOCAL , & sDefault . szInclude , handle_include , NULL , FLAG_HIDE } ,
1999-12-13 16:27:58 +03:00
{ " exec " , P_STRING , P_LOCAL , & sDefault . szPreExec , NULL , NULL , FLAG_SHARE | FLAG_PRINT } ,
1998-03-08 17:14:49 +03:00
{ " preexec " , P_STRING , P_LOCAL , & sDefault . szPreExec , NULL , NULL , 0 } ,
2000-01-18 08:11:29 +03:00
{ " preexec close " , P_BOOL , P_LOCAL , & sDefault . bPreexecClose , NULL , NULL , FLAG_SHARE } ,
1999-12-13 16:27:58 +03:00
{ " postexec " , P_STRING , P_LOCAL , & sDefault . szPostExec , NULL , NULL , FLAG_SHARE | FLAG_PRINT } ,
{ " root preexec " , P_STRING , P_LOCAL , & sDefault . szRootPreExec , NULL , NULL , FLAG_SHARE | FLAG_PRINT } ,
2000-01-18 08:11:29 +03:00
{ " root preexec close " , P_BOOL , P_LOCAL , & sDefault . bRootpreexecClose , NULL , NULL , FLAG_SHARE } ,
1999-12-13 16:27:58 +03:00
{ " root postexec " , P_STRING , P_LOCAL , & sDefault . szRootPostExec , NULL , NULL , FLAG_SHARE | FLAG_PRINT } ,
{ " available " , P_BOOL , P_LOCAL , & sDefault . bAvailable , NULL , NULL , FLAG_BASIC | FLAG_SHARE | FLAG_PRINT } ,
{ " volume " , P_STRING , P_LOCAL , & sDefault . volume , NULL , NULL , FLAG_SHARE } ,
{ " fstype " , P_STRING , P_LOCAL , & sDefault . fstype , NULL , NULL , FLAG_SHARE } ,
{ " set directory " , P_BOOLREV , P_LOCAL , & sDefault . bNo_set_dir , NULL , NULL , FLAG_SHARE } ,
{ " wide links " , P_BOOL , P_LOCAL , & sDefault . bWidelinks , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " follow symlinks " , P_BOOL , P_LOCAL , & sDefault . bSymlinks , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " dont descend " , P_STRING , P_LOCAL , & sDefault . szDontdescend , NULL , NULL , FLAG_SHARE } ,
{ " magic script " , P_STRING , P_LOCAL , & sDefault . szMagicScript , NULL , NULL , FLAG_SHARE } ,
{ " magic output " , P_STRING , P_LOCAL , & sDefault . szMagicOutput , NULL , NULL , FLAG_SHARE } ,
{ " delete readonly " , P_BOOL , P_LOCAL , & sDefault . bDeleteReadonly , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " dos filetimes " , P_BOOL , P_LOCAL , & sDefault . bDosFiletimes , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
{ " dos filetime resolution " , P_BOOL , P_LOCAL , & sDefault . bDosFiletimeResolution , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
1998-03-16 23:59:47 +03:00
1999-12-13 16:27:58 +03:00
{ " fake directory create times " , P_BOOL , P_LOCAL , & sDefault . bFakeDirCreateTimes , NULL , NULL , FLAG_SHARE | FLAG_GLOBAL } ,
1998-08-21 15:37:40 +04:00
{ " panic action " , P_STRING , P_GLOBAL , & Globals . szPanicAction , NULL , NULL , 0 } ,
1998-03-08 17:14:49 +03:00
{ NULL , P_BOOL , P_NONE , NULL , NULL , NULL , 0 }
1996-05-04 11:50:46 +04:00
} ;
/***************************************************************************
Initialise the global parameter structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static void init_globals ( void )
{
static BOOL done_init = False ;
pstring s ;
if ( ! done_init )
{
int i ;
1999-12-13 16:27:58 +03:00
memset ( ( void * ) & Globals , ' \0 ' , sizeof ( Globals ) ) ;
1996-05-04 11:50:46 +04:00
for ( i = 0 ; parm_table [ i ] . label ; i + + )
1996-08-19 15:17:29 +04:00
if ( ( parm_table [ i ] . type = = P_STRING | |
parm_table [ i ] . type = = P_USTRING ) & &
1996-05-04 11:50:46 +04:00
parm_table [ i ] . ptr )
2000-01-16 14:18:04 +03:00
string_set ( parm_table [ i ] . ptr , " " ) ;
1996-05-04 11:50:46 +04:00
string_set ( & sDefault . szGuestaccount , GUEST_ACCOUNT ) ;
1996-10-11 09:49:42 +04:00
string_set ( & sDefault . szPrinterDriver , " NULL " ) ;
1998-09-20 19:40:52 +04:00
string_set ( & sDefault . fstype , FSTYPE_STRING ) ;
1996-05-04 11:50:46 +04:00
done_init = True ;
}
DEBUG ( 3 , ( " Initialising global parameters \n " ) ) ;
string_set ( & Globals . szSMBPasswdFile , SMB_PASSWD_FILE ) ;
1999-12-13 16:27:58 +03:00
/*
* Allow the default PASSWD_CHAT to be overridden in local . h .
*/
string_set ( & Globals . szPasswdChat , DEFAULT_PASSWD_CHAT ) ;
1996-05-04 11:50:46 +04:00
string_set ( & Globals . szWorkGroup , WORKGROUP ) ;
1998-11-10 03:37:14 +03:00
string_set ( & Globals . szPasswdProgram , PASSWD_PROGRAM ) ;
1996-05-04 11:50:46 +04:00
string_set ( & Globals . szPrintcapname , PRINTCAP_NAME ) ;
1997-10-28 22:32:59 +03:00
string_set ( & Globals . szDriverFile , DRIVERFILE ) ;
1996-05-04 11:50:46 +04:00
string_set ( & Globals . szLockDir , LOCKDIR ) ;
string_set ( & Globals . szRootdir , " / " ) ;
2000-01-13 03:42:04 +03:00
# ifdef WITH_UTMP
2000-01-12 06:09:17 +03:00
string_set ( & Globals . szUtmpDir , " " ) ;
2000-01-13 03:42:04 +03:00
# endif /* WITH_UTMP */
1996-06-01 19:25:30 +04:00
string_set ( & Globals . szSmbrun , SMBRUN ) ;
1996-08-19 15:17:29 +04:00
string_set ( & Globals . szSocketAddress , " 0.0.0.0 " ) ;
1998-05-12 04:55:32 +04:00
pstrcpy ( s , " Samba " ) ;
pstrcat ( s , VERSION ) ;
1996-05-04 11:50:46 +04:00
string_set ( & Globals . szServerString , s ) ;
1998-05-12 04:55:32 +04:00
slprintf ( s , sizeof ( s ) - 1 , " %d.%d " , DEFAULT_MAJOR_VERSION , DEFAULT_MINOR_VERSION ) ;
1997-07-30 23:17:51 +04:00
string_set ( & Globals . szAnnounceVersion , s ) ;
1997-10-20 16:10:58 +04:00
1998-11-09 07:17:11 +03:00
pstrcpy ( user_socket_options , DEFAULT_SOCKET_OPTIONS ) ;
1997-10-20 16:10:58 +04:00
string_set ( & Globals . szLogonDrive , " " ) ;
/* %N is the NIS auto.home server if -DAUTOHOME is used, else same as %L */
string_set ( & Globals . szLogonHome , " \\ \\ %N \\ %U " ) ;
string_set ( & Globals . szLogonPath , " \\ \\ %N \\ %U \\ profile " ) ;
1998-09-28 13:22:06 +04:00
1998-03-16 23:59:47 +03:00
string_set ( & Globals . szNameResolveOrder , " lmhosts host wins bcast " ) ;
1996-05-04 11:50:46 +04:00
Globals . bLoadPrinters = True ;
Globals . bUseRhosts = False ;
Globals . max_packet = 65535 ;
Globals . mangled_stack = 50 ;
1997-06-06 20:14:17 +04:00
Globals . max_xmit = 65535 ;
1997-07-01 05:19:13 +04:00
Globals . max_mux = 50 ; /* This is *needed* for profile support. */
1996-05-04 11:50:46 +04:00
Globals . lpqcachetime = 10 ;
Globals . pwordlevel = 0 ;
1997-09-19 21:12:08 +04:00
Globals . unamelevel = 0 ;
1996-05-04 11:50:46 +04:00
Globals . deadtime = 0 ;
Globals . max_log_size = 5000 ;
1998-09-30 05:49:24 +04:00
Globals . max_open_files = MAX_OPEN_FILES ;
1996-05-04 11:50:46 +04:00
Globals . maxprotocol = PROTOCOL_NT1 ;
1998-07-15 01:23:59 +04:00
Globals . security = SEC_USER ;
1996-05-04 11:50:46 +04:00
Globals . bEncryptPasswords = False ;
1998-04-30 05:39:22 +04:00
Globals . bUpdateEncrypt = False ;
1996-05-04 11:50:46 +04:00
Globals . bReadRaw = True ;
Globals . bWriteRaw = True ;
Globals . bReadPrediction = False ;
1999-12-13 16:27:58 +03:00
Globals . bReadbmpx = False ;
1996-05-04 11:50:46 +04:00
Globals . bNullPasswords = False ;
Globals . bStripDot = False ;
Globals . syslog = 1 ;
Globals . bSyslogOnly = False ;
1998-08-03 23:07:55 +04:00
Globals . bTimestampLogs = True ;
1999-12-13 16:27:58 +03:00
Globals . bDebugHiresTimestamp = False ;
Globals . bDebugPid = False ;
Globals . bDebugUid = False ;
1998-08-03 23:07:55 +04:00
Globals . max_ttl = 60 * 60 * 24 * 3 ; /* 3 days default. */
Globals . max_wins_ttl = 60 * 60 * 24 * 6 ; /* 6 days default. */
Globals . min_wins_ttl = 60 * 60 * 6 ; /* 6 hours default. */
Globals . machine_password_timeout = 60 * 60 * 24 * 7 ; /* 7 days default. */
Globals . change_notify_timeout = 60 ; /* 1 minute default. */
1996-06-07 07:34:22 +04:00
Globals . ReadSize = 16 * 1024 ;
1997-12-16 12:20:34 +03:00
Globals . lm_announce = 2 ; /* = Auto: send only if LM clients found */
Globals . lm_interval = 60 ;
1997-05-20 04:32:51 +04:00
Globals . shmem_size = SHMEM_SIZE ;
1998-08-29 01:46:29 +04:00
Globals . stat_cache_size = 50 ; /* Number of stat translations we'll keep */
1999-12-13 16:27:58 +03:00
Globals . announce_as = ANNOUNCE_AS_NT_SERVER ;
1997-05-07 21:56:46 +04:00
Globals . bUnixRealname = False ;
1998-07-29 07:08:05 +04:00
# if (defined(HAVE_NETGROUP) && defined(WITH_AUTOMOUNT))
1997-05-07 21:56:46 +04:00
Globals . bNISHomeMap = False ;
1998-08-08 05:15:14 +04:00
# ifdef WITH_NISPLUS_HOME
1998-04-10 00:48:48 +04:00
string_set ( & Globals . szNISHomeMapName , " auto_home.org_dir " ) ;
# else
1997-05-07 21:56:46 +04:00
string_set ( & Globals . szNISHomeMapName , " auto.home " ) ;
1998-04-10 00:48:48 +04:00
# endif
1997-05-07 21:56:46 +04:00
# endif
1997-06-11 05:03:06 +04:00
Globals . client_code_page = DEFAULT_CLIENT_CODE_PAGE ;
1997-06-17 00:49:15 +04:00
Globals . bTimeServer = False ;
1997-10-20 22:52:04 +04:00
Globals . bBindInterfacesOnly = False ;
1998-03-27 22:59:14 +03:00
Globals . bUnixPasswdSync = False ;
1998-04-21 03:07:28 +04:00
Globals . bPasswdChatDebug = False ;
1998-07-31 01:18:57 +04:00
Globals . bOleLockingCompat = True ;
1998-09-05 07:14:40 +04:00
Globals . bNTSmbSupport = True ; /* Do NT SMB's by default. */
1998-10-18 23:29:19 +04:00
Globals . bNTPipeSupport = True ; /* Do NT pipes by default. */
1999-12-13 16:27:58 +03:00
Globals . bNTAclSupport = True ; /* Use NT ACLs by default. */
1998-09-06 05:37:14 +04:00
Globals . bStatCache = True ; /* use stat cache by default */
1999-12-13 16:27:58 +03:00
Globals . bRestrictAnonymous = False ;
1998-11-10 23:51:25 +03:00
Globals . map_to_guest = 0 ; /* By Default, "Never" */
1999-12-13 16:27:58 +03:00
Globals . min_passwd_length = MINPASSWDLENGTH ; /* By Default, 5. */
Globals . oplock_break_wait_time = 10 ; /* By Default, 10 msecs. */
1996-05-04 11:50:46 +04:00
1998-07-29 07:08:05 +04:00
# ifdef WITH_LDAP
1998-05-06 21:43:44 +04:00
/* default values for ldap */
string_set ( & Globals . szLdapServer , " localhost " ) ;
Globals . ldap_port = 389 ;
1998-07-29 07:08:05 +04:00
# endif /* WITH_LDAP */
1998-05-06 21:43:44 +04:00
1998-07-29 07:08:05 +04:00
# ifdef WITH_SSL
1998-06-16 05:35:52 +04:00
Globals . sslVersion = SMB_SSL_V23 ;
1999-12-13 16:27:58 +03:00
string_set ( & Globals . sslHostsRequire , " " ) ;
string_set ( & Globals . sslHostsResign , " " ) ;
string_set ( & Globals . sslCaCertDir , " " ) ;
string_set ( & Globals . sslCaCertFile , " " ) ;
string_set ( & Globals . sslCert , " " ) ;
string_set ( & Globals . sslPrivKey , " " ) ;
string_set ( & Globals . sslClientCert , " " ) ;
string_set ( & Globals . sslClientPrivKey , " " ) ;
string_set ( & Globals . sslCiphers , " " ) ;
1998-06-16 05:35:52 +04:00
Globals . sslEnabled = False ;
Globals . sslReqClientCert = False ;
Globals . sslReqServerCert = False ;
Globals . sslCompatibility = False ;
1998-07-29 07:08:05 +04:00
# endif /* WITH_SSL */
1998-06-16 05:35:52 +04:00
1997-05-20 04:32:51 +04:00
/* these parameters are set to defaults that are more appropriate
for the increasing samba install base :
as a member of the workgroup , that will possibly become a
_local_ master browser ( lm = True ) . this is opposed to a forced
local master browser startup ( pm = True ) .
doesn ' t provide WINS server service by default ( wsupp = False ) ,
and doesn ' t provide domain master browser services by default , either .
*/
1999-12-13 16:27:58 +03:00
Globals . os_level = 20 ;
Globals . bPreferredMaster = False ;
1997-05-20 04:32:51 +04:00
Globals . bLocalMaster = True ;
1999-12-13 16:27:58 +03:00
Globals . bDomainMaster = False ;
1997-05-20 04:32:51 +04:00
Globals . bDomainLogons = False ;
Globals . bBrowseList = True ;
Globals . bWINSsupport = False ;
Globals . bWINSproxy = False ;
1997-07-06 16:06:23 +04:00
Globals . bDNSproxy = True ;
1998-03-03 23:19:14 +03:00
1998-09-18 21:50:18 +04:00
/*
1998-09-30 05:05:51 +04:00
* smbd will check at runtime to see if this value
* will really be used or not .
1998-09-18 21:50:18 +04:00
*/
1998-09-30 05:05:51 +04:00
Globals . bKernelOplocks = True ;
1998-09-18 21:50:18 +04:00
1999-12-13 16:27:58 +03:00
Globals . bAllowTrustedDomains = True ;
1999-03-01 19:31:14 +03:00
1998-03-03 23:19:14 +03:00
/*
* This must be done last as it checks the value in
* client_code_page .
*/
interpret_coding_system ( KANJI ) ;
1996-05-04 11:50:46 +04:00
}
/***************************************************************************
Initialise the sDefault parameter structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static void init_locals ( void )
{
/* choose defaults depending on the type of printing */
1997-12-03 06:37:02 +03:00
switch ( sDefault . iPrinting )
1996-05-04 11:50:46 +04:00
{
case PRINT_BSD :
case PRINT_AIX :
1999-12-13 16:27:58 +03:00
case PRINT_LPRNG :
1996-05-31 19:13:29 +04:00
case PRINT_PLP :
2000-01-16 14:18:04 +03:00
string_set ( & sDefault . szLpqcommand , " lpq -P%p " ) ;
string_set ( & sDefault . szLprmcommand , " lprm -P%p %j " ) ;
string_set ( & sDefault . szPrintcommand , " lpr -r -P%p %s " ) ;
1996-05-04 11:50:46 +04:00
break ;
1999-12-13 16:27:58 +03:00
case PRINT_CUPS :
2000-01-16 14:18:04 +03:00
string_set ( & sDefault . szLpqcommand , " /usr/bin/lpstat -o%p " ) ;
string_set ( & sDefault . szLprmcommand , " /usr/bin/cancel %p-%j " ) ;
string_set ( & sDefault . szPrintcommand , " /usr/bin/lp -d%p -oraw %s; rm %s " ) ;
string_set ( & sDefault . szQueuepausecommand , " /usr/bin/disable %p " ) ;
string_set ( & sDefault . szQueueresumecommand , " /usr/bin/enable %p " ) ;
1999-04-27 14:43:32 +04:00
break ;
1996-05-04 11:50:46 +04:00
case PRINT_SYSV :
case PRINT_HPUX :
2000-01-16 14:18:04 +03:00
string_set ( & sDefault . szLpqcommand , " lpstat -o%p " ) ;
string_set ( & sDefault . szLprmcommand , " cancel %p-%j " ) ;
string_set ( & sDefault . szPrintcommand , " lp -c -d%p %s; rm %s " ) ;
1999-12-13 16:27:58 +03:00
# ifdef HPUX
2000-01-16 14:18:04 +03:00
string_set ( & sDefault . szQueuepausecommand , " disable %p " ) ;
string_set ( & sDefault . szQueueresumecommand , " enable %p " ) ;
1999-12-13 16:27:58 +03:00
# else /* SYSV */
2000-01-16 14:18:04 +03:00
string_set ( & sDefault . szLppausecommand , " lp -i %p-%j -H hold " ) ;
string_set ( & sDefault . szLpresumecommand , " lp -i %p-%j -H resume " ) ;
string_set ( & sDefault . szQueuepausecommand , " lpc stop %p " ) ;
string_set ( & sDefault . szQueueresumecommand , " lpc start %p " ) ;
1998-07-29 07:08:05 +04:00
# endif /* SYSV */
1996-05-04 11:50:46 +04:00
break ;
case PRINT_QNX :
2000-01-16 14:18:04 +03:00
string_set ( & sDefault . szLpqcommand , " lpq -P%p " ) ;
string_set ( & sDefault . szLprmcommand , " lprm -P%p %j " ) ;
string_set ( & sDefault . szPrintcommand , " lp -r -P%p %s " ) ;
1996-05-04 11:50:46 +04:00
break ;
1998-04-02 05:01:24 +04:00
case PRINT_SOFTQ :
2000-01-16 14:18:04 +03:00
string_set ( & sDefault . szLpqcommand , " qstat -l -d%p " ) ;
string_set ( & sDefault . szLprmcommand , " qstat -s -j%j -c " ) ;
string_set ( & sDefault . szPrintcommand , " lp -d%p -s %s; rm %s " ) ;
string_set ( & sDefault . szLppausecommand , " qstat -s -j%j -h " ) ;
string_set ( & sDefault . szLpresumecommand , " qstat -s -j%j -r " ) ;
1998-04-02 05:01:24 +04:00
break ;
1996-05-04 11:50:46 +04:00
}
}
2000-01-05 09:36:36 +03:00
static TALLOC_CTX * lp_talloc ;
1997-11-03 22:24:45 +03:00
/******************************************************************* a
2000-01-05 09:36:36 +03:00
free up temporary memory - called from the main loop
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void lp_talloc_free ( void )
{
if ( ! lp_talloc ) return ;
talloc_destroy ( lp_talloc ) ;
lp_talloc = NULL ;
}
/*******************************************************************
convenience routine to grab string parameters into temporary memory
1997-11-03 22:24:45 +03:00
and run standard_sub_basic on them . The buffers can be written to by
callers without affecting the source string .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1999-12-13 16:27:58 +03:00
static char * lp_string ( const char * s )
1997-11-02 23:35:20 +03:00
{
2000-01-05 09:36:36 +03:00
size_t len = s ? strlen ( s ) : 0 ;
char * ret ;
1997-11-02 23:35:20 +03:00
2000-01-05 09:36:36 +03:00
if ( ! lp_talloc ) lp_talloc = talloc_init ( ) ;
ret = ( char * ) talloc ( lp_talloc , len + 100 ) ; /* leave room for substitution */
1997-11-02 23:35:20 +03:00
2000-01-05 09:36:36 +03:00
if ( ! ret ) return NULL ;
1997-11-02 23:35:20 +03:00
2000-01-05 09:36:36 +03:00
if ( ! s )
* ret = 0 ;
else
StrnCpy ( ret , s , len ) ;
1997-11-02 23:35:20 +03:00
2000-01-05 09:36:36 +03:00
trim_string ( ret , " \" " , " \" " ) ;
1997-11-02 23:35:20 +03:00
2000-01-05 09:36:36 +03:00
standard_sub_basic ( ret ) ;
return ( ret ) ;
1996-05-04 11:50:46 +04:00
}
/*
In this section all the functions that are used to access the
parameters from the rest of the program are defined
*/
# define FN_GLOBAL_STRING(fn_name,ptr) \
char * fn_name ( void ) { return ( lp_string ( * ( char * * ) ( ptr ) ? * ( char * * ) ( ptr ) : " " ) ) ; }
# define FN_GLOBAL_BOOL(fn_name,ptr) \
BOOL fn_name ( void ) { return ( * ( BOOL * ) ( ptr ) ) ; }
# define FN_GLOBAL_CHAR(fn_name,ptr) \
char fn_name ( void ) { return ( * ( char * ) ( ptr ) ) ; }
# define FN_GLOBAL_INTEGER(fn_name,ptr) \
int fn_name ( void ) { return ( * ( int * ) ( ptr ) ) ; }
# define FN_LOCAL_STRING(fn_name,val) \
char * fn_name ( int i ) { return ( lp_string ( ( LP_SNUM_OK ( i ) & & pSERVICE ( i ) - > val ) ? pSERVICE ( i ) - > val : sDefault . val ) ) ; }
# define FN_LOCAL_BOOL(fn_name,val) \
BOOL fn_name ( int i ) { return ( LP_SNUM_OK ( i ) ? pSERVICE ( i ) - > val : sDefault . val ) ; }
# define FN_LOCAL_CHAR(fn_name,val) \
char fn_name ( int i ) { return ( LP_SNUM_OK ( i ) ? pSERVICE ( i ) - > val : sDefault . val ) ; }
# define FN_LOCAL_INTEGER(fn_name,val) \
int fn_name ( int i ) { return ( LP_SNUM_OK ( i ) ? pSERVICE ( i ) - > val : sDefault . val ) ; }
FN_GLOBAL_STRING ( lp_logfile , & Globals . szLogFile )
1996-06-01 19:25:30 +04:00
FN_GLOBAL_STRING ( lp_smbrun , & Globals . szSmbrun )
1996-05-04 11:50:46 +04:00
FN_GLOBAL_STRING ( lp_configfile , & Globals . szConfigFile )
FN_GLOBAL_STRING ( lp_smb_passwd_file , & Globals . szSMBPasswdFile )
FN_GLOBAL_STRING ( lp_serverstring , & Globals . szServerString )
FN_GLOBAL_STRING ( lp_printcapname , & Globals . szPrintcapname )
FN_GLOBAL_STRING ( lp_lockdir , & Globals . szLockDir )
2000-01-12 06:09:17 +03:00
# ifdef WITH_UTMP
FN_GLOBAL_STRING ( lp_utmpdir , & Globals . szUtmpDir )
# endif /* WITH_UTMP */
1996-05-04 11:50:46 +04:00
FN_GLOBAL_STRING ( lp_rootdir , & Globals . szRootdir )
FN_GLOBAL_STRING ( lp_defaultservice , & Globals . szDefaultService )
FN_GLOBAL_STRING ( lp_msg_command , & Globals . szMsgCommand )
2000-01-06 04:41:27 +03:00
FN_GLOBAL_STRING ( lp_dfree_command , & Globals . szDfree )
1996-05-04 11:50:46 +04:00
FN_GLOBAL_STRING ( lp_hosts_equiv , & Globals . szHostsEquiv )
FN_GLOBAL_STRING ( lp_auto_services , & Globals . szAutoServices )
FN_GLOBAL_STRING ( lp_passwd_program , & Globals . szPasswdProgram )
FN_GLOBAL_STRING ( lp_passwd_chat , & Globals . szPasswdChat )
FN_GLOBAL_STRING ( lp_passwordserver , & Globals . szPasswordServer )
1998-03-16 23:59:47 +03:00
FN_GLOBAL_STRING ( lp_name_resolve_order , & Globals . szNameResolveOrder )
1996-05-04 11:50:46 +04:00
FN_GLOBAL_STRING ( lp_workgroup , & Globals . szWorkGroup )
FN_GLOBAL_STRING ( lp_username_map , & Globals . szUsernameMap )
1999-12-13 16:27:58 +03:00
# ifdef USING_GROUPNAME_MAP
1998-09-08 23:21:04 +04:00
FN_GLOBAL_STRING ( lp_groupname_map , & Globals . szGroupnameMap )
1999-12-13 16:27:58 +03:00
# endif /* USING_GROUPNAME_MAP */
1996-05-04 11:50:46 +04:00
FN_GLOBAL_STRING ( lp_logon_script , & Globals . szLogonScript )
1997-02-02 21:12:36 +03:00
FN_GLOBAL_STRING ( lp_logon_path , & Globals . szLogonPath )
1997-10-20 16:10:58 +04:00
FN_GLOBAL_STRING ( lp_logon_drive , & Globals . szLogonDrive )
FN_GLOBAL_STRING ( lp_logon_home , & Globals . szLogonHome )
1996-08-16 17:03:26 +04:00
FN_GLOBAL_STRING ( lp_remote_announce , & Globals . szRemoteAnnounce )
1997-11-21 17:01:23 +03:00
FN_GLOBAL_STRING ( lp_remote_browse_sync , & Globals . szRemoteBrowseSync )
1996-06-01 19:25:30 +04:00
FN_GLOBAL_STRING ( lp_wins_server , & Globals . szWINSserver )
1996-06-06 15:43:09 +04:00
FN_GLOBAL_STRING ( lp_interfaces , & Globals . szInterfaces )
1996-08-19 15:17:29 +04:00
FN_GLOBAL_STRING ( lp_socket_address , & Globals . szSocketAddress )
1997-05-07 21:56:46 +04:00
FN_GLOBAL_STRING ( lp_nis_home_map_name , & Globals . szNISHomeMapName )
1998-09-05 09:07:05 +04:00
static FN_GLOBAL_STRING ( lp_announce_version , & Globals . szAnnounceVersion )
1997-07-31 22:47:26 +04:00
FN_GLOBAL_STRING ( lp_netbios_aliases , & Globals . szNetbiosAliases )
1997-10-28 22:32:59 +03:00
FN_GLOBAL_STRING ( lp_driverfile , & Globals . szDriverFile )
1998-08-25 01:49:10 +04:00
FN_GLOBAL_STRING ( lp_panic_action , & Globals . szPanicAction )
1999-12-13 16:27:58 +03:00
FN_GLOBAL_STRING ( lp_adduser_script , & Globals . szAddUserScript )
FN_GLOBAL_STRING ( lp_deluser_script , & Globals . szDelUserScript )
FN_GLOBAL_STRING ( lp_wins_hook , & Globals . szWINSHook )
FN_GLOBAL_STRING ( lp_domain_groups , & Globals . szDomainGroups )
FN_GLOBAL_STRING ( lp_domain_admin_group , & Globals . szDomainAdminGroup )
FN_GLOBAL_STRING ( lp_domain_guest_group , & Globals . szDomainGuestGroup )
FN_GLOBAL_STRING ( lp_domain_admin_users , & Globals . szDomainAdminUsers )
FN_GLOBAL_STRING ( lp_domain_guest_users , & Globals . szDomainGuestUsers )
1996-05-04 11:50:46 +04:00
1998-07-29 07:08:05 +04:00
# ifdef WITH_LDAP
1998-05-06 21:43:44 +04:00
FN_GLOBAL_STRING ( lp_ldap_server , & Globals . szLdapServer ) ;
FN_GLOBAL_STRING ( lp_ldap_suffix , & Globals . szLdapSuffix ) ;
1999-12-13 16:27:58 +03:00
FN_GLOBAL_STRING ( lp_ldap_filter , & Globals . szLdapFilter ) ;
FN_GLOBAL_STRING ( lp_ldap_root , & Globals . szLdapRoot ) ;
FN_GLOBAL_STRING ( lp_ldap_rootpasswd , & Globals . szLdapRootPassword ) ;
1998-07-29 07:08:05 +04:00
# endif /* WITH_LDAP */
1998-05-06 21:43:44 +04:00
1998-07-29 07:08:05 +04:00
# ifdef WITH_SSL
1998-06-16 05:35:52 +04:00
FN_GLOBAL_INTEGER ( lp_ssl_version , & Globals . sslVersion ) ;
FN_GLOBAL_STRING ( lp_ssl_hosts , & Globals . sslHostsRequire ) ;
FN_GLOBAL_STRING ( lp_ssl_hosts_resign , & Globals . sslHostsResign ) ;
FN_GLOBAL_STRING ( lp_ssl_cacertdir , & Globals . sslCaCertDir ) ;
FN_GLOBAL_STRING ( lp_ssl_cacertfile , & Globals . sslCaCertFile ) ;
FN_GLOBAL_STRING ( lp_ssl_cert , & Globals . sslCert ) ;
FN_GLOBAL_STRING ( lp_ssl_privkey , & Globals . sslPrivKey ) ;
FN_GLOBAL_STRING ( lp_ssl_client_cert , & Globals . sslClientCert ) ;
FN_GLOBAL_STRING ( lp_ssl_client_privkey , & Globals . sslClientPrivKey ) ;
FN_GLOBAL_STRING ( lp_ssl_ciphers , & Globals . sslCiphers ) ;
FN_GLOBAL_BOOL ( lp_ssl_enabled , & Globals . sslEnabled ) ;
FN_GLOBAL_BOOL ( lp_ssl_reqClientCert , & Globals . sslReqClientCert ) ;
FN_GLOBAL_BOOL ( lp_ssl_reqServerCert , & Globals . sslReqServerCert ) ;
FN_GLOBAL_BOOL ( lp_ssl_compatibility , & Globals . sslCompatibility ) ;
1998-07-29 07:08:05 +04:00
# endif /* WITH_SSL */
1998-06-16 05:35:52 +04:00
1997-07-06 16:06:23 +04:00
FN_GLOBAL_BOOL ( lp_dns_proxy , & Globals . bDNSproxy )
1996-06-04 10:42:03 +04:00
FN_GLOBAL_BOOL ( lp_wins_support , & Globals . bWINSsupport )
1997-12-03 06:50:05 +03:00
FN_GLOBAL_BOOL ( lp_we_are_a_wins_server , & Globals . bWINSsupport )
1996-06-04 19:14:47 +04:00
FN_GLOBAL_BOOL ( lp_wins_proxy , & Globals . bWINSproxy )
1997-05-20 04:32:51 +04:00
FN_GLOBAL_BOOL ( lp_local_master , & Globals . bLocalMaster )
1999-12-13 16:27:58 +03:00
FN_GLOBAL_BOOL ( lp_domain_master , & Globals . bDomainMaster )
1996-05-04 11:50:46 +04:00
FN_GLOBAL_BOOL ( lp_domain_logons , & Globals . bDomainLogons )
1999-12-13 16:27:58 +03:00
FN_GLOBAL_BOOL ( lp_preferred_master , & Globals . bPreferredMaster )
1996-05-04 11:50:46 +04:00
FN_GLOBAL_BOOL ( lp_load_printers , & Globals . bLoadPrinters )
FN_GLOBAL_BOOL ( lp_use_rhosts , & Globals . bUseRhosts )
FN_GLOBAL_BOOL ( lp_readprediction , & Globals . bReadPrediction )
FN_GLOBAL_BOOL ( lp_readbmpx , & Globals . bReadbmpx )
FN_GLOBAL_BOOL ( lp_readraw , & Globals . bReadRaw )
FN_GLOBAL_BOOL ( lp_writeraw , & Globals . bWriteRaw )
FN_GLOBAL_BOOL ( lp_null_passwords , & Globals . bNullPasswords )
FN_GLOBAL_BOOL ( lp_strip_dot , & Globals . bStripDot )
FN_GLOBAL_BOOL ( lp_encrypted_passwords , & Globals . bEncryptPasswords )
1998-04-30 05:39:22 +04:00
FN_GLOBAL_BOOL ( lp_update_encrypted , & Globals . bUpdateEncrypt )
1996-05-04 11:50:46 +04:00
FN_GLOBAL_BOOL ( lp_syslog_only , & Globals . bSyslogOnly )
1998-08-03 23:07:55 +04:00
FN_GLOBAL_BOOL ( lp_timestamp_logs , & Globals . bTimestampLogs )
1999-12-13 16:27:58 +03:00
FN_GLOBAL_BOOL ( lp_debug_hires_timestamp , & Globals . bDebugHiresTimestamp )
FN_GLOBAL_BOOL ( lp_debug_pid , & Globals . bDebugPid )
FN_GLOBAL_BOOL ( lp_debug_uid , & Globals . bDebugUid )
1996-05-04 11:50:46 +04:00
FN_GLOBAL_BOOL ( lp_browse_list , & Globals . bBrowseList )
1997-05-07 21:56:46 +04:00
FN_GLOBAL_BOOL ( lp_unix_realname , & Globals . bUnixRealname )
FN_GLOBAL_BOOL ( lp_nis_home_map , & Globals . bNISHomeMap )
1998-09-05 09:07:05 +04:00
static FN_GLOBAL_BOOL ( lp_time_server , & Globals . bTimeServer )
1997-10-20 22:52:04 +04:00
FN_GLOBAL_BOOL ( lp_bind_interfaces_only , & Globals . bBindInterfacesOnly )
1998-03-27 22:59:14 +03:00
FN_GLOBAL_BOOL ( lp_unix_password_sync , & Globals . bUnixPasswdSync )
1998-04-21 03:07:28 +04:00
FN_GLOBAL_BOOL ( lp_passwd_chat_debug , & Globals . bPasswdChatDebug )
1998-07-31 01:18:57 +04:00
FN_GLOBAL_BOOL ( lp_ole_locking_compat , & Globals . bOleLockingCompat )
1998-09-05 07:14:40 +04:00
FN_GLOBAL_BOOL ( lp_nt_smb_support , & Globals . bNTSmbSupport )
1998-10-18 23:29:19 +04:00
FN_GLOBAL_BOOL ( lp_nt_pipe_support , & Globals . bNTPipeSupport )
1999-12-13 16:27:58 +03:00
FN_GLOBAL_BOOL ( lp_nt_acl_support , & Globals . bNTAclSupport )
1998-09-06 05:37:14 +04:00
FN_GLOBAL_BOOL ( lp_stat_cache , & Globals . bStatCache )
1999-12-13 16:27:58 +03:00
FN_GLOBAL_BOOL ( lp_allow_trusted_domains , & Globals . bAllowTrustedDomains )
FN_GLOBAL_BOOL ( lp_restrict_anonymous , & Globals . bRestrictAnonymous )
1996-05-04 11:50:46 +04:00
FN_GLOBAL_INTEGER ( lp_os_level , & Globals . os_level )
FN_GLOBAL_INTEGER ( lp_max_ttl , & Globals . max_ttl )
1997-12-13 17:16:07 +03:00
FN_GLOBAL_INTEGER ( lp_max_wins_ttl , & Globals . max_wins_ttl )
FN_GLOBAL_INTEGER ( lp_min_wins_ttl , & Globals . max_wins_ttl )
1996-05-04 11:50:46 +04:00
FN_GLOBAL_INTEGER ( lp_max_log_size , & Globals . max_log_size )
1998-09-30 05:49:24 +04:00
FN_GLOBAL_INTEGER ( lp_max_open_files , & Globals . max_open_files )
1996-05-04 11:50:46 +04:00
FN_GLOBAL_INTEGER ( lp_maxxmit , & Globals . max_xmit )
FN_GLOBAL_INTEGER ( lp_maxmux , & Globals . max_mux )
FN_GLOBAL_INTEGER ( lp_passwordlevel , & Globals . pwordlevel )
1997-09-19 21:12:08 +04:00
FN_GLOBAL_INTEGER ( lp_usernamelevel , & Globals . unamelevel )
1996-06-07 07:34:22 +04:00
FN_GLOBAL_INTEGER ( lp_readsize , & Globals . ReadSize )
1997-05-20 04:32:51 +04:00
FN_GLOBAL_INTEGER ( lp_shmem_size , & Globals . shmem_size )
1996-05-04 11:50:46 +04:00
FN_GLOBAL_INTEGER ( lp_deadtime , & Globals . deadtime )
FN_GLOBAL_INTEGER ( lp_maxprotocol , & Globals . maxprotocol )
FN_GLOBAL_INTEGER ( lp_security , & Globals . security )
FN_GLOBAL_INTEGER ( lp_maxdisksize , & Globals . maxdisksize )
FN_GLOBAL_INTEGER ( lp_lpqcachetime , & Globals . lpqcachetime )
FN_GLOBAL_INTEGER ( lp_syslog , & Globals . syslog )
1997-06-11 05:03:06 +04:00
FN_GLOBAL_INTEGER ( lp_client_code_page , & Globals . client_code_page )
1998-09-05 09:07:05 +04:00
static FN_GLOBAL_INTEGER ( lp_announce_as , & Globals . announce_as )
1997-12-16 12:20:34 +03:00
FN_GLOBAL_INTEGER ( lp_lm_announce , & Globals . lm_announce )
FN_GLOBAL_INTEGER ( lp_lm_interval , & Globals . lm_interval )
1998-05-27 04:30:52 +04:00
FN_GLOBAL_INTEGER ( lp_machine_password_timeout , & Globals . machine_password_timeout )
1998-08-03 23:07:55 +04:00
FN_GLOBAL_INTEGER ( lp_change_notify_timeout , & Globals . change_notify_timeout )
1998-08-29 01:46:29 +04:00
FN_GLOBAL_INTEGER ( lp_stat_cache_size , & Globals . stat_cache_size )
1998-11-10 23:51:25 +03:00
FN_GLOBAL_INTEGER ( lp_map_to_guest , & Globals . map_to_guest )
1999-12-13 16:27:58 +03:00
FN_GLOBAL_INTEGER ( lp_min_passwd_length , & Globals . min_passwd_length )
FN_GLOBAL_INTEGER ( lp_oplock_break_wait_time , & Globals . oplock_break_wait_time )
1996-05-04 11:50:46 +04:00
1998-07-29 07:08:05 +04:00
# ifdef WITH_LDAP
1998-05-06 21:43:44 +04:00
FN_GLOBAL_INTEGER ( lp_ldap_port , & Globals . ldap_port )
1998-07-29 07:08:05 +04:00
# endif /* WITH_LDAP */
1998-05-06 21:43:44 +04:00
1996-05-04 11:50:46 +04:00
FN_LOCAL_STRING ( lp_preexec , szPreExec )
FN_LOCAL_STRING ( lp_postexec , szPostExec )
FN_LOCAL_STRING ( lp_rootpreexec , szRootPreExec )
FN_LOCAL_STRING ( lp_rootpostexec , szRootPostExec )
FN_LOCAL_STRING ( lp_servicename , szService )
FN_LOCAL_STRING ( lp_pathname , szPath )
FN_LOCAL_STRING ( lp_dontdescend , szDontdescend )
FN_LOCAL_STRING ( lp_username , szUsername )
FN_LOCAL_STRING ( lp_guestaccount , szGuestaccount )
FN_LOCAL_STRING ( lp_invalid_users , szInvalidUsers )
FN_LOCAL_STRING ( lp_valid_users , szValidUsers )
FN_LOCAL_STRING ( lp_admin_users , szAdminUsers )
FN_LOCAL_STRING ( lp_printcommand , szPrintcommand )
FN_LOCAL_STRING ( lp_lpqcommand , szLpqcommand )
FN_LOCAL_STRING ( lp_lprmcommand , szLprmcommand )
FN_LOCAL_STRING ( lp_lppausecommand , szLppausecommand )
FN_LOCAL_STRING ( lp_lpresumecommand , szLpresumecommand )
1998-07-16 04:06:29 +04:00
FN_LOCAL_STRING ( lp_queuepausecommand , szQueuepausecommand )
FN_LOCAL_STRING ( lp_queueresumecommand , szQueueresumecommand )
1996-05-04 11:50:46 +04:00
FN_LOCAL_STRING ( lp_printername , szPrintername )
1996-08-13 12:57:55 +04:00
FN_LOCAL_STRING ( lp_printerdriver , szPrinterDriver )
1996-05-04 11:50:46 +04:00
FN_LOCAL_STRING ( lp_hostsallow , szHostsallow )
FN_LOCAL_STRING ( lp_hostsdeny , szHostsdeny )
FN_LOCAL_STRING ( lp_magicscript , szMagicScript )
FN_LOCAL_STRING ( lp_magicoutput , szMagicOutput )
FN_LOCAL_STRING ( lp_comment , comment )
FN_LOCAL_STRING ( lp_force_user , force_user )
FN_LOCAL_STRING ( lp_force_group , force_group )
FN_LOCAL_STRING ( lp_readlist , readlist )
FN_LOCAL_STRING ( lp_writelist , writelist )
1998-09-20 19:40:52 +04:00
FN_LOCAL_STRING ( lp_fstype , fstype )
1998-09-05 09:07:05 +04:00
static FN_LOCAL_STRING ( lp_volume , volume )
1996-05-04 11:50:46 +04:00
FN_LOCAL_STRING ( lp_mangled_map , szMangledMap )
1997-07-06 17:48:10 +04:00
FN_LOCAL_STRING ( lp_veto_files , szVetoFiles )
FN_LOCAL_STRING ( lp_hide_files , szHideFiles )
1997-12-20 13:52:00 +03:00
FN_LOCAL_STRING ( lp_veto_oplocks , szVetoOplockFiles )
1997-10-28 22:32:59 +03:00
FN_LOCAL_STRING ( lp_driverlocation , szPrinterDriverLocation )
1996-05-04 11:50:46 +04:00
1999-12-13 16:27:58 +03:00
FN_LOCAL_BOOL ( lp_preexec_close , bPreexecClose )
FN_LOCAL_BOOL ( lp_rootpreexec_close , bRootpreexecClose )
1996-05-04 11:50:46 +04:00
FN_LOCAL_BOOL ( lp_revalidate , bRevalidate )
FN_LOCAL_BOOL ( lp_casesensitive , bCaseSensitive )
FN_LOCAL_BOOL ( lp_preservecase , bCasePreserve )
FN_LOCAL_BOOL ( lp_shortpreservecase , bShortCasePreserve )
FN_LOCAL_BOOL ( lp_casemangle , bCaseMangle )
FN_LOCAL_BOOL ( lp_status , status )
FN_LOCAL_BOOL ( lp_hide_dot_files , bHideDotFiles )
FN_LOCAL_BOOL ( lp_browseable , bBrowseable )
FN_LOCAL_BOOL ( lp_readonly , bRead_only )
FN_LOCAL_BOOL ( lp_no_set_dir , bNo_set_dir )
FN_LOCAL_BOOL ( lp_guest_ok , bGuest_ok )
FN_LOCAL_BOOL ( lp_guest_only , bGuest_only )
FN_LOCAL_BOOL ( lp_print_ok , bPrint_ok )
FN_LOCAL_BOOL ( lp_postscript , bPostscript )
FN_LOCAL_BOOL ( lp_map_hidden , bMap_hidden )
FN_LOCAL_BOOL ( lp_map_archive , bMap_archive )
FN_LOCAL_BOOL ( lp_locking , bLocking )
FN_LOCAL_BOOL ( lp_strict_locking , bStrictLocking )
2000-01-12 06:09:17 +03:00
# ifdef WITH_UTMP
FN_LOCAL_BOOL ( lp_utmp , bUtmp )
# endif
1996-05-04 11:50:46 +04:00
FN_LOCAL_BOOL ( lp_share_modes , bShareModes )
1997-10-02 07:14:32 +04:00
FN_LOCAL_BOOL ( lp_oplocks , bOpLocks )
1999-12-13 16:27:58 +03:00
FN_LOCAL_BOOL ( lp_level2_oplocks , bLevel2OpLocks )
1996-05-04 11:50:46 +04:00
FN_LOCAL_BOOL ( lp_onlyuser , bOnlyUser )
FN_LOCAL_BOOL ( lp_manglednames , bMangledNames )
FN_LOCAL_BOOL ( lp_widelinks , bWidelinks )
1997-07-19 00:21:32 +04:00
FN_LOCAL_BOOL ( lp_symlinks , bSymlinks )
1996-05-04 11:50:46 +04:00
FN_LOCAL_BOOL ( lp_syncalways , bSyncAlways )
1998-07-28 22:15:31 +04:00
FN_LOCAL_BOOL ( lp_strict_sync , bStrictSync )
1996-05-04 11:50:46 +04:00
FN_LOCAL_BOOL ( lp_map_system , bMap_system )
1996-05-31 19:13:29 +04:00
FN_LOCAL_BOOL ( lp_delete_readonly , bDeleteReadonly )
1996-10-05 14:41:13 +04:00
FN_LOCAL_BOOL ( lp_fake_oplocks , bFakeOplocks )
1997-09-17 05:29:53 +04:00
FN_LOCAL_BOOL ( lp_recursive_veto_delete , bDeleteVetoFiles )
1997-10-20 22:52:04 +04:00
FN_LOCAL_BOOL ( lp_dos_filetimes , bDosFiletimes )
1998-02-13 10:11:58 +03:00
FN_LOCAL_BOOL ( lp_dos_filetime_resolution , bDosFiletimeResolution )
1998-03-16 23:59:47 +03:00
FN_LOCAL_BOOL ( lp_fake_dir_create_times , bFakeDirCreateTimes )
1998-09-08 23:21:04 +04:00
FN_LOCAL_BOOL ( lp_blocking_locks , bBlockingLocks )
2000-01-14 04:41:04 +03:00
FN_LOCAL_BOOL ( lp_inherit_perms , bInheritPerms )
1996-05-04 11:50:46 +04:00
1999-12-13 16:27:58 +03:00
FN_LOCAL_INTEGER ( lp_create_mask , iCreate_mask )
1997-06-19 04:18:23 +04:00
FN_LOCAL_INTEGER ( lp_force_create_mode , iCreate_force_mode )
1999-12-13 16:27:58 +03:00
FN_LOCAL_INTEGER ( _lp_security_mask , iSecurity_mask )
FN_LOCAL_INTEGER ( _lp_force_security_mode , iSecurity_force_mode )
FN_LOCAL_INTEGER ( lp_dir_mask , iDir_mask )
1997-06-19 04:18:23 +04:00
FN_LOCAL_INTEGER ( lp_force_dir_mode , iDir_force_mode )
1999-12-13 16:27:58 +03:00
FN_LOCAL_INTEGER ( _lp_dir_security_mask , iDir_Security_mask )
FN_LOCAL_INTEGER ( _lp_force_dir_security_mode , iDir_Security_force_mode )
1996-05-04 11:50:46 +04:00
FN_LOCAL_INTEGER ( lp_max_connections , iMaxConnections )
FN_LOCAL_INTEGER ( lp_defaultcase , iDefaultCase )
FN_LOCAL_INTEGER ( lp_minprintspace , iMinPrintSpace )
1997-12-03 06:37:02 +03:00
FN_LOCAL_INTEGER ( lp_printing , iPrinting )
1999-12-13 16:27:58 +03:00
FN_LOCAL_INTEGER ( lp_oplock_contention_limit , iOplockContentionLimit )
FN_LOCAL_INTEGER ( lp_write_cache_size , iWriteCacheSize )
1996-05-04 11:50:46 +04:00
FN_LOCAL_CHAR ( lp_magicchar , magic_char )
/* local prototypes */
static int strwicmp ( char * psz1 , char * psz2 ) ;
static int map_parameter ( char * pszParmName ) ;
static BOOL set_boolean ( BOOL * pb , char * pszParmValue ) ;
static int getservicebyname ( char * pszServiceName , service * pserviceDest ) ;
static void copy_service ( service * pserviceDest ,
service * pserviceSource ,
BOOL * pcopymapDest ) ;
static BOOL service_ok ( int iService ) ;
static BOOL do_parameter ( char * pszParmName , char * pszParmValue ) ;
static BOOL do_section ( char * pszSectionName ) ;
static void init_copymap ( service * pservice ) ;
/***************************************************************************
initialise a service to the defaults
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static void init_service ( service * pservice )
{
1999-12-13 16:27:58 +03:00
memset ( ( char * ) pservice , ' \0 ' , sizeof ( service ) ) ;
1996-05-04 11:50:46 +04:00
copy_service ( pservice , & sDefault , NULL ) ;
}
/***************************************************************************
free the dynamically allocated parts of a service struct
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static void free_service ( service * pservice )
{
int i ;
if ( ! pservice )
return ;
1998-01-24 15:34:16 +03:00
if ( pservice - > szService )
DEBUG ( 5 , ( " free_service: Freeing service %s \n " , pservice - > szService ) ) ;
1998-01-24 15:26:17 +03:00
string_free ( & pservice - > szService ) ;
if ( pservice - > copymap )
{
free ( pservice - > copymap ) ;
pservice - > copymap = NULL ;
}
1996-05-04 11:50:46 +04:00
for ( i = 0 ; parm_table [ i ] . label ; i + + )
1996-08-19 15:17:29 +04:00
if ( ( parm_table [ i ] . type = = P_STRING | |
1998-01-24 15:26:17 +03:00
parm_table [ i ] . type = = P_USTRING ) & &
1996-08-19 15:17:29 +04:00
parm_table [ i ] . class = = P_LOCAL )
1996-05-04 11:50:46 +04:00
string_free ( ( char * * ) ( ( ( char * ) pservice ) + PTR_DIFF ( parm_table [ i ] . ptr , & sDefault ) ) ) ;
}
/***************************************************************************
add a new service to the services array initialising it with the given
service
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static int add_a_service ( service * pservice , char * name )
{
int i ;
service tservice ;
int num_to_alloc = iNumServices + 1 ;
tservice = * pservice ;
/* it might already exist */
if ( name )
{
i = getservicebyname ( name , NULL ) ;
if ( i > = 0 )
return ( i ) ;
}
/* find an invalid one */
for ( i = 0 ; i < iNumServices ; i + + )
if ( ! pSERVICE ( i ) - > valid )
break ;
/* if not, then create one */
if ( i = = iNumServices )
{
ServicePtrs = ( service * * ) Realloc ( ServicePtrs , sizeof ( service * ) * num_to_alloc ) ;
if ( ServicePtrs )
pSERVICE ( iNumServices ) = ( service * ) malloc ( sizeof ( service ) ) ;
if ( ! ServicePtrs | | ! pSERVICE ( iNumServices ) )
return ( - 1 ) ;
iNumServices + + ;
}
else
free_service ( pSERVICE ( i ) ) ;
pSERVICE ( i ) - > valid = True ;
init_service ( pSERVICE ( i ) ) ;
copy_service ( pSERVICE ( i ) , & tservice , NULL ) ;
1999-12-13 16:27:58 +03:00
if ( name ) {
1996-05-04 11:50:46 +04:00
string_set ( & iSERVICE ( i ) . szService , name ) ;
1999-12-13 16:27:58 +03:00
unix_to_dos ( iSERVICE ( i ) . szService , True ) ;
}
1996-05-04 11:50:46 +04:00
return ( i ) ;
}
/***************************************************************************
add a new home service , with the specified home directory , defaults coming
from service ifrom
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lp_add_home ( char * pszHomename , int iDefaultService , char * pszHomedir )
{
int i = add_a_service ( pSERVICE ( iDefaultService ) , pszHomename ) ;
if ( i < 0 )
return ( False ) ;
if ( ! ( * ( iSERVICE ( i ) . szPath ) ) | | strequal ( iSERVICE ( i ) . szPath , lp_pathname ( - 1 ) ) )
string_set ( & iSERVICE ( i ) . szPath , pszHomedir ) ;
if ( ! ( * ( iSERVICE ( i ) . comment ) ) )
{
pstring comment ;
1998-05-19 01:30:57 +04:00
slprintf ( comment , sizeof ( comment ) - 1 ,
1998-05-11 10:38:36 +04:00
" Home directory of %s " , pszHomename ) ;
1996-05-04 11:50:46 +04:00
string_set ( & iSERVICE ( i ) . comment , comment ) ;
}
iSERVICE ( i ) . bAvailable = sDefault . bAvailable ;
iSERVICE ( i ) . bBrowseable = sDefault . bBrowseable ;
DEBUG ( 3 , ( " adding home directory %s at %s \n " , pszHomename , pszHomedir ) ) ;
return ( True ) ;
}
/***************************************************************************
add a new service , based on an old one
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
int lp_add_service ( char * pszService , int iDefaultService )
{
return ( add_a_service ( pSERVICE ( iDefaultService ) , pszService ) ) ;
}
/***************************************************************************
add the IPC service
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL lp_add_ipc ( void )
{
pstring comment ;
int i = add_a_service ( & sDefault , " IPC$ " ) ;
if ( i < 0 )
return ( False ) ;
1998-05-19 01:30:57 +04:00
slprintf ( comment , sizeof ( comment ) - 1 ,
1998-05-11 10:38:36 +04:00
" IPC Service (%s) " , Globals . szServerString ) ;
1996-05-04 11:50:46 +04:00
1996-10-24 04:09:08 +04:00
string_set ( & iSERVICE ( i ) . szPath , tmpdir ( ) ) ;
1996-05-04 11:50:46 +04:00
string_set ( & iSERVICE ( i ) . szUsername , " " ) ;
string_set ( & iSERVICE ( i ) . comment , comment ) ;
1998-09-30 14:52:48 +04:00
string_set ( & iSERVICE ( i ) . fstype , " IPC " ) ;
1996-05-04 11:50:46 +04:00
iSERVICE ( i ) . status = False ;
iSERVICE ( i ) . iMaxConnections = 0 ;
iSERVICE ( i ) . bAvailable = True ;
iSERVICE ( i ) . bRead_only = True ;
iSERVICE ( i ) . bGuest_only = False ;
iSERVICE ( i ) . bGuest_ok = True ;
iSERVICE ( i ) . bPrint_ok = False ;
iSERVICE ( i ) . bBrowseable = sDefault . bBrowseable ;
DEBUG ( 3 , ( " adding IPC service \n " ) ) ;
return ( True ) ;
}
/***************************************************************************
add a new printer service , with defaults coming from service iFrom
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lp_add_printer ( char * pszPrintername , int iDefaultService )
{
char * comment = " From Printcap " ;
int i = add_a_service ( pSERVICE ( iDefaultService ) , pszPrintername ) ;
if ( i < 0 )
return ( False ) ;
/* note that we do NOT default the availability flag to True - */
/* we take it from the default service passed. This allows all */
/* dynamic printers to be disabled by disabling the [printers] */
/* entry (if/when the 'available' keyword is implemented!). */
/* the printer name is set to the service name. */
string_set ( & iSERVICE ( i ) . szPrintername , pszPrintername ) ;
string_set ( & iSERVICE ( i ) . comment , comment ) ;
iSERVICE ( i ) . bBrowseable = sDefault . bBrowseable ;
1997-05-28 00:28:45 +04:00
/* Printers cannot be read_only. */
iSERVICE ( i ) . bRead_only = False ;
/* No share modes on printer services. */
iSERVICE ( i ) . bShareModes = False ;
1997-10-02 07:14:32 +04:00
/* No oplocks on printer services. */
iSERVICE ( i ) . bOpLocks = False ;
1997-07-30 23:17:51 +04:00
/* Printer services must be printable. */
iSERVICE ( i ) . bPrint_ok = True ;
1996-05-04 11:50:46 +04:00
DEBUG ( 3 , ( " adding printer service %s \n " , pszPrintername ) ) ;
return ( True ) ;
}
/***************************************************************************
Do a case - insensitive , whitespace - ignoring string compare .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static int strwicmp ( char * psz1 , char * psz2 )
{
/* if BOTH strings are NULL, return TRUE, if ONE is NULL return */
/* appropriate value. */
if ( psz1 = = psz2 )
return ( 0 ) ;
else
if ( psz1 = = NULL )
return ( - 1 ) ;
else
if ( psz2 = = NULL )
return ( 1 ) ;
/* sync the strings on first non-whitespace */
while ( 1 )
{
while ( isspace ( * psz1 ) )
psz1 + + ;
while ( isspace ( * psz2 ) )
psz2 + + ;
if ( toupper ( * psz1 ) ! = toupper ( * psz2 ) | | * psz1 = = ' \0 ' | | * psz2 = = ' \0 ' )
break ;
psz1 + + ;
psz2 + + ;
}
return ( * psz1 - * psz2 ) ;
}
/***************************************************************************
Map a parameter ' s string representation to something we can use .
Returns False if the parameter string is not recognised , else TRUE .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static int map_parameter ( char * pszParmName )
{
int iIndex ;
if ( * pszParmName = = ' - ' )
return ( - 1 ) ;
for ( iIndex = 0 ; parm_table [ iIndex ] . label ; iIndex + + )
if ( strwicmp ( parm_table [ iIndex ] . label , pszParmName ) = = 0 )
return ( iIndex ) ;
DEBUG ( 0 , ( " Unknown parameter encountered: \" %s \" \n " , pszParmName ) ) ;
return ( - 1 ) ;
}
/***************************************************************************
Set a boolean variable from the text value stored in the passed string .
Returns True in success , False if the passed string does not correctly
represent a boolean .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL set_boolean ( BOOL * pb , char * pszParmValue )
{
BOOL bRetval ;
bRetval = True ;
if ( strwicmp ( pszParmValue , " yes " ) = = 0 | |
strwicmp ( pszParmValue , " true " ) = = 0 | |
strwicmp ( pszParmValue , " 1 " ) = = 0 )
* pb = True ;
else
if ( strwicmp ( pszParmValue , " no " ) = = 0 | |
strwicmp ( pszParmValue , " False " ) = = 0 | |
strwicmp ( pszParmValue , " 0 " ) = = 0 )
* pb = False ;
else
{
1998-09-28 16:52:51 +04:00
DEBUG ( 0 , ( " ERROR: Badly formed boolean in configuration file: \" %s \" . \n " ,
1996-05-04 11:50:46 +04:00
pszParmValue ) ) ;
bRetval = False ;
}
return ( bRetval ) ;
}
/***************************************************************************
Find a service by name . Otherwise works like get_service .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static int getservicebyname ( char * pszServiceName , service * pserviceDest )
{
int iService ;
for ( iService = iNumServices - 1 ; iService > = 0 ; iService - - )
if ( VALID ( iService ) & &
strwicmp ( iSERVICE ( iService ) . szService , pszServiceName ) = = 0 )
{
if ( pserviceDest ! = NULL )
copy_service ( pserviceDest , pSERVICE ( iService ) , NULL ) ;
break ;
}
return ( iService ) ;
}
/***************************************************************************
Copy a service structure to another
If pcopymapDest is NULL then copy all fields
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static void copy_service ( service * pserviceDest ,
service * pserviceSource ,
BOOL * pcopymapDest )
{
int i ;
BOOL bcopyall = ( pcopymapDest = = NULL ) ;
for ( i = 0 ; parm_table [ i ] . label ; i + + )
if ( parm_table [ i ] . ptr & & parm_table [ i ] . class = = P_LOCAL & &
( bcopyall | | pcopymapDest [ i ] ) )
{
void * def_ptr = parm_table [ i ] . ptr ;
void * src_ptr =
( ( char * ) pserviceSource ) + PTR_DIFF ( def_ptr , & sDefault ) ;
void * dest_ptr =
( ( char * ) pserviceDest ) + PTR_DIFF ( def_ptr , & sDefault ) ;
switch ( parm_table [ i ] . type )
{
case P_BOOL :
case P_BOOLREV :
* ( BOOL * ) dest_ptr = * ( BOOL * ) src_ptr ;
break ;
case P_INTEGER :
1997-11-22 10:09:12 +03:00
case P_ENUM :
1996-05-04 11:50:46 +04:00
case P_OCTAL :
* ( int * ) dest_ptr = * ( int * ) src_ptr ;
break ;
case P_CHAR :
* ( char * ) dest_ptr = * ( char * ) src_ptr ;
break ;
case P_STRING :
string_set ( dest_ptr , * ( char * * ) src_ptr ) ;
break ;
1996-08-19 15:17:29 +04:00
case P_USTRING :
string_set ( dest_ptr , * ( char * * ) src_ptr ) ;
strupper ( * ( char * * ) dest_ptr ) ;
break ;
1996-05-04 11:50:46 +04:00
default :
break ;
}
}
if ( bcopyall )
{
init_copymap ( pserviceDest ) ;
if ( pserviceSource - > copymap )
memcpy ( ( void * ) pserviceDest - > copymap ,
( void * ) pserviceSource - > copymap , sizeof ( BOOL ) * NUMPARAMETERS ) ;
}
}
/***************************************************************************
Check a service for consistency . Return False if the service is in any way
incomplete or faulty , else True .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL service_ok ( int iService )
{
BOOL bRetval ;
bRetval = True ;
if ( iSERVICE ( iService ) . szService [ 0 ] = = ' \0 ' )
{
DEBUG ( 0 , ( " The following message indicates an internal error: \n " ) ) ;
DEBUG ( 0 , ( " No service name in service entry. \n " ) ) ;
bRetval = False ;
}
/* The [printers] entry MUST be printable. I'm all for flexibility, but */
/* I can't see why you'd want a non-printable printer service... */
if ( strwicmp ( iSERVICE ( iService ) . szService , PRINTERS_NAME ) = = 0 )
if ( ! iSERVICE ( iService ) . bPrint_ok )
{
DEBUG ( 0 , ( " WARNING: [%s] service MUST be printable! \n " ,
iSERVICE ( iService ) . szService ) ) ;
iSERVICE ( iService ) . bPrint_ok = True ;
}
if ( iSERVICE ( iService ) . szPath [ 0 ] = = ' \0 ' & &
strwicmp ( iSERVICE ( iService ) . szService , HOMES_NAME ) ! = 0 )
{
1996-10-24 04:09:08 +04:00
DEBUG ( 0 , ( " No path in service %s - using %s \n " , iSERVICE ( iService ) . szService , tmpdir ( ) ) ) ;
string_set ( & iSERVICE ( iService ) . szPath , tmpdir ( ) ) ;
1996-05-04 11:50:46 +04:00
}
/* If a service is flagged unavailable, log the fact at level 0. */
if ( ! iSERVICE ( iService ) . bAvailable )
DEBUG ( 1 , ( " NOTE: Service %s is flagged unavailable. \n " ,
iSERVICE ( iService ) . szService ) ) ;
return ( bRetval ) ;
}
static struct file_lists {
struct file_lists * next ;
char * name ;
time_t modtime ;
} * file_lists = NULL ;
/*******************************************************************
keep a linked list of all config files so we know when one has changed
it ' s date and needs to be reloaded
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static void add_to_file_list ( char * fname )
{
struct file_lists * f = file_lists ;
while ( f ) {
if ( f - > name & & ! strcmp ( f - > name , fname ) ) break ;
f = f - > next ;
}
if ( ! f ) {
f = ( struct file_lists * ) malloc ( sizeof ( file_lists [ 0 ] ) ) ;
if ( ! f ) return ;
f - > next = file_lists ;
f - > name = strdup ( fname ) ;
if ( ! f - > name ) {
free ( f ) ;
return ;
}
file_lists = f ;
}
{
pstring n2 ;
1997-09-26 22:55:29 +04:00
pstrcpy ( n2 , fname ) ;
1996-05-04 11:50:46 +04:00
standard_sub_basic ( n2 ) ;
f - > modtime = file_modtime ( n2 ) ;
}
}
/*******************************************************************
check if a config file has changed date
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lp_file_list_changed ( void )
{
struct file_lists * f = file_lists ;
1997-09-05 21:16:21 +04:00
DEBUG ( 6 , ( " lp_file_list_changed() \n " ) ) ;
while ( f )
{
1996-05-04 11:50:46 +04:00
pstring n2 ;
1997-09-05 21:16:21 +04:00
time_t mod_time ;
1997-09-26 22:55:29 +04:00
pstrcpy ( n2 , f - > name ) ;
1996-05-04 11:50:46 +04:00
standard_sub_basic ( n2 ) ;
1997-09-05 21:16:21 +04:00
1998-08-04 02:10:53 +04:00
DEBUGADD ( 6 , ( " file %s -> %s last mod_time: %s \n " ,
f - > name , n2 , ctime ( & f - > modtime ) ) ) ;
1997-09-05 21:16:21 +04:00
mod_time = file_modtime ( n2 ) ;
1997-10-20 03:22:03 +04:00
if ( f - > modtime ! = mod_time ) {
1998-08-04 02:10:53 +04:00
DEBUGADD ( 6 , ( " file %s modified: %s \n " , n2 , ctime ( & mod_time ) ) ) ;
1997-10-20 03:22:03 +04:00
f - > modtime = mod_time ;
return ( True ) ;
1997-09-05 21:16:21 +04:00
}
1998-08-04 02:10:53 +04:00
f = f - > next ;
1996-05-04 11:50:46 +04:00
}
return ( False ) ;
}
/***************************************************************************
handle the interpretation of the coding system parameter
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1997-11-22 10:09:12 +03:00
static BOOL handle_coding_system ( char * pszParmValue , char * * ptr )
1996-05-04 11:50:46 +04:00
{
1997-11-22 10:09:12 +03:00
string_set ( ptr , pszParmValue ) ;
interpret_coding_system ( pszParmValue ) ;
return ( True ) ;
1996-05-04 11:50:46 +04:00
}
/***************************************************************************
1999-12-13 16:27:58 +03:00
Handle the interpretation of the character set system parameter .
1996-05-04 11:50:46 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1999-12-13 16:27:58 +03:00
static char * saved_character_set = NULL ;
1997-11-22 10:09:12 +03:00
static BOOL handle_character_set ( char * pszParmValue , char * * ptr )
1996-05-04 11:50:46 +04:00
{
1999-12-13 16:27:58 +03:00
/* A dependency here is that the parameter client code page should be
set before this is called .
*/
1997-11-22 10:09:12 +03:00
string_set ( ptr , pszParmValue ) ;
1999-12-13 16:27:58 +03:00
strupper ( * ptr ) ;
saved_character_set = strdup ( * ptr ) ;
interpret_character_set ( * ptr , lp_client_code_page ( ) ) ;
1997-11-22 10:09:12 +03:00
return ( True ) ;
1996-05-04 11:50:46 +04:00
}
1999-12-13 16:27:58 +03:00
/***************************************************************************
Handle the interpretation of the client code page parameter .
We handle this separately so that we can reset the character set
parameter in case this came before ' client code page ' in the smb . conf .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL handle_client_code_page ( char * pszParmValue , char * * ptr )
{
Globals . client_code_page = atoi ( pszParmValue ) ;
if ( saved_character_set ! = NULL )
interpret_character_set ( saved_character_set , lp_client_code_page ( ) ) ;
return ( True ) ;
}
1997-07-30 23:17:51 +04:00
1996-05-04 11:50:46 +04:00
/***************************************************************************
handle the valid chars lines
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1999-12-13 16:27:58 +03:00
1996-05-04 11:50:46 +04:00
static BOOL handle_valid_chars ( char * pszParmValue , char * * ptr )
{
string_set ( ptr , pszParmValue ) ;
1997-08-13 03:02:45 +04:00
/* A dependency here is that the parameter client code page must be
set before this is called - as calling codepage_initialise ( )
would overwrite the valid char lines .
*/
codepage_initialise ( lp_client_code_page ( ) ) ;
1996-05-04 11:50:46 +04:00
add_char_string ( pszParmValue ) ;
return ( True ) ;
}
/***************************************************************************
handle the include operation
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1999-12-13 16:27:58 +03:00
1996-05-04 11:50:46 +04:00
static BOOL handle_include ( char * pszParmValue , char * * ptr )
{
pstring fname ;
1997-09-26 22:55:29 +04:00
pstrcpy ( fname , pszParmValue ) ;
1996-05-04 11:50:46 +04:00
add_to_file_list ( fname ) ;
standard_sub_basic ( fname ) ;
string_set ( ptr , fname ) ;
if ( file_exist ( fname , NULL ) )
return ( pm_process ( fname , do_section , do_parameter ) ) ;
DEBUG ( 2 , ( " Can't find include file %s \n " , fname ) ) ;
return ( False ) ;
}
/***************************************************************************
handle the interpretation of the copy parameter
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL handle_copy ( char * pszParmValue , char * * ptr )
{
BOOL bRetval ;
int iTemp ;
service serviceTemp ;
string_set ( ptr , pszParmValue ) ;
init_service ( & serviceTemp ) ;
bRetval = False ;
DEBUG ( 3 , ( " Copying service from service %s \n " , pszParmValue ) ) ;
if ( ( iTemp = getservicebyname ( pszParmValue , & serviceTemp ) ) > = 0 )
{
if ( iTemp = = iServiceIndex )
{
DEBUG ( 0 , ( " Can't copy service %s - unable to copy self! \n " ,
pszParmValue ) ) ;
}
else
{
copy_service ( pSERVICE ( iServiceIndex ) ,
& serviceTemp ,
iSERVICE ( iServiceIndex ) . copymap ) ;
bRetval = True ;
}
}
else
{
DEBUG ( 0 , ( " Unable to copy service - source not found: %s \n " ,
pszParmValue ) ) ;
bRetval = False ;
}
free_service ( & serviceTemp ) ;
return ( bRetval ) ;
}
/***************************************************************************
initialise a copymap
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static void init_copymap ( service * pservice )
{
int i ;
if ( pservice - > copymap ) free ( pservice - > copymap ) ;
pservice - > copymap = ( BOOL * ) malloc ( sizeof ( BOOL ) * NUMPARAMETERS ) ;
if ( ! pservice - > copymap )
1999-12-13 16:27:58 +03:00
DEBUG ( 0 , ( " Couldn't allocate copymap!! (size %d) \n " , ( int ) NUMPARAMETERS ) ) ;
else
for ( i = 0 ; i < NUMPARAMETERS ; i + + )
pservice - > copymap [ i ] = True ;
1996-05-04 11:50:46 +04:00
}
1998-03-08 17:14:49 +03:00
/***************************************************************************
return the local pointer to a parameter given the service number and the
pointer into the default structure
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void * lp_local_ptr ( int snum , void * ptr )
{
return ( void * ) ( ( ( char * ) pSERVICE ( snum ) ) + PTR_DIFF ( ptr , & sDefault ) ) ;
}
1996-05-04 11:50:46 +04:00
/***************************************************************************
1997-09-11 06:19:04 +04:00
Process a parameter for a particular service number . If snum < 0
then assume we are in the globals
1996-05-04 11:50:46 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1997-09-11 06:19:04 +04:00
BOOL lp_do_parameter ( int snum , char * pszParmName , char * pszParmValue )
1996-05-04 11:50:46 +04:00
{
1997-11-22 10:09:12 +03:00
int parmnum , i ;
1996-05-04 11:50:46 +04:00
void * parm_ptr = NULL ; /* where we are going to store the result */
void * def_ptr = NULL ;
parmnum = map_parameter ( pszParmName ) ;
if ( parmnum < 0 )
{
DEBUG ( 0 , ( " Ignoring unknown parameter \" %s \" \n " , pszParmName ) ) ;
return ( True ) ;
}
1998-08-26 05:57:17 +04:00
if ( parm_table [ parmnum ] . flags & FLAG_DEPRECATED ) {
DEBUG ( 1 , ( " WARNING: The \" %s \" option is deprecated \n " ,
pszParmName ) ) ;
}
1996-05-04 11:50:46 +04:00
def_ptr = parm_table [ parmnum ] . ptr ;
/* we might point at a service, the default service or a global */
1997-09-11 06:19:04 +04:00
if ( snum < 0 ) {
1996-05-04 11:50:46 +04:00
parm_ptr = def_ptr ;
1997-09-11 06:19:04 +04:00
} else {
if ( parm_table [ parmnum ] . class = = P_GLOBAL ) {
1996-05-04 11:50:46 +04:00
DEBUG ( 0 , ( " Global parameter %s found in service section! \n " , pszParmName ) ) ;
return ( True ) ;
}
1997-09-11 06:19:04 +04:00
parm_ptr = ( ( char * ) pSERVICE ( snum ) ) + PTR_DIFF ( def_ptr , & sDefault ) ;
}
1996-05-04 11:50:46 +04:00
1997-09-11 06:19:04 +04:00
if ( snum > = 0 ) {
if ( ! iSERVICE ( snum ) . copymap )
init_copymap ( pSERVICE ( snum ) ) ;
/* this handles the aliases - set the copymap for other entries with
the same data pointer */
for ( i = 0 ; parm_table [ i ] . label ; i + + )
if ( parm_table [ i ] . ptr = = parm_table [ parmnum ] . ptr )
iSERVICE ( snum ) . copymap [ i ] = False ;
}
1996-05-04 11:50:46 +04:00
/* if it is a special case then go ahead */
1997-09-11 06:19:04 +04:00
if ( parm_table [ parmnum ] . special ) {
1998-04-13 23:24:06 +04:00
parm_table [ parmnum ] . special ( pszParmValue , ( char * * ) parm_ptr ) ;
1997-09-11 06:19:04 +04:00
return ( True ) ;
}
1996-05-04 11:50:46 +04:00
/* now switch on the type of variable it is */
switch ( parm_table [ parmnum ] . type )
{
case P_BOOL :
set_boolean ( parm_ptr , pszParmValue ) ;
break ;
case P_BOOLREV :
set_boolean ( parm_ptr , pszParmValue ) ;
* ( BOOL * ) parm_ptr = ! * ( BOOL * ) parm_ptr ;
break ;
case P_INTEGER :
* ( int * ) parm_ptr = atoi ( pszParmValue ) ;
break ;
case P_CHAR :
* ( char * ) parm_ptr = * pszParmValue ;
break ;
case P_OCTAL :
sscanf ( pszParmValue , " %o " , ( int * ) parm_ptr ) ;
break ;
case P_STRING :
string_set ( parm_ptr , pszParmValue ) ;
1999-12-13 16:27:58 +03:00
if ( parm_table [ parmnum ] . flags & FLAG_DOS_STRING )
unix_to_dos ( * ( char * * ) parm_ptr , True ) ;
1996-05-04 11:50:46 +04:00
break ;
1996-08-19 15:17:29 +04:00
case P_USTRING :
string_set ( parm_ptr , pszParmValue ) ;
1999-12-13 16:27:58 +03:00
if ( parm_table [ parmnum ] . flags & FLAG_DOS_STRING )
unix_to_dos ( * ( char * * ) parm_ptr , True ) ;
1996-08-19 15:17:29 +04:00
strupper ( * ( char * * ) parm_ptr ) ;
break ;
1996-05-04 11:50:46 +04:00
case P_GSTRING :
1998-05-12 04:55:32 +04:00
pstrcpy ( ( char * ) parm_ptr , pszParmValue ) ;
1999-12-13 16:27:58 +03:00
if ( parm_table [ parmnum ] . flags & FLAG_DOS_STRING )
unix_to_dos ( ( char * ) parm_ptr , True ) ;
1996-05-04 11:50:46 +04:00
break ;
1996-08-19 15:17:29 +04:00
case P_UGSTRING :
1998-05-12 04:55:32 +04:00
pstrcpy ( ( char * ) parm_ptr , pszParmValue ) ;
1999-12-13 16:27:58 +03:00
if ( parm_table [ parmnum ] . flags & FLAG_DOS_STRING )
unix_to_dos ( ( char * ) parm_ptr , True ) ;
1996-08-19 15:17:29 +04:00
strupper ( ( char * ) parm_ptr ) ;
break ;
1997-11-22 10:09:12 +03:00
case P_ENUM :
for ( i = 0 ; parm_table [ parmnum ] . enum_list [ i ] . name ; i + + ) {
if ( strequal ( pszParmValue , parm_table [ parmnum ] . enum_list [ i ] . name ) ) {
* ( int * ) parm_ptr = parm_table [ parmnum ] . enum_list [ i ] . value ;
break ;
}
}
break ;
1998-03-14 11:27:41 +03:00
case P_SEP :
break ;
1996-05-04 11:50:46 +04:00
}
return ( True ) ;
}
1997-09-11 06:19:04 +04:00
/***************************************************************************
Process a parameter .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1998-08-03 22:13:13 +04:00
static BOOL do_parameter ( char * pszParmName , char * pszParmValue )
1997-09-11 06:19:04 +04:00
{
1998-08-03 22:13:13 +04:00
if ( ! bInGlobalSection & & bGlobalOnly )
return ( True ) ;
1997-09-11 06:19:04 +04:00
1998-08-03 22:13:13 +04:00
DEBUGADD ( 3 , ( " doing parameter %s = %s \n " , pszParmName , pszParmValue ) ) ;
1997-09-11 06:19:04 +04:00
1998-08-03 22:13:13 +04:00
return ( lp_do_parameter ( bInGlobalSection ? - 2 : iServiceIndex ,
pszParmName ,
pszParmValue ) ) ;
1997-09-11 06:19:04 +04:00
}
1996-05-04 11:50:46 +04:00
/***************************************************************************
print a parameter of the specified type
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1997-11-22 10:09:12 +03:00
static void print_parameter ( struct parm_struct * p , void * ptr , FILE * f )
1996-05-04 11:50:46 +04:00
{
1997-11-22 10:09:12 +03:00
int i ;
switch ( p - > type ) {
case P_ENUM :
for ( i = 0 ; p - > enum_list [ i ] . name ; i + + ) {
if ( * ( int * ) ptr = = p - > enum_list [ i ] . value ) {
fprintf ( f , " %s " , p - > enum_list [ i ] . name ) ;
break ;
}
}
break ;
case P_BOOL :
fprintf ( f , " %s " , BOOLSTR ( * ( BOOL * ) ptr ) ) ;
break ;
1996-05-04 11:50:46 +04:00
1997-11-22 10:09:12 +03:00
case P_BOOLREV :
fprintf ( f , " %s " , BOOLSTR ( ! * ( BOOL * ) ptr ) ) ;
break ;
1996-05-04 11:50:46 +04:00
1997-11-22 10:09:12 +03:00
case P_INTEGER :
fprintf ( f , " %d " , * ( int * ) ptr ) ;
break ;
1996-05-04 11:50:46 +04:00
1997-11-22 10:09:12 +03:00
case P_CHAR :
fprintf ( f , " %c " , * ( char * ) ptr ) ;
break ;
1996-05-04 11:50:46 +04:00
1997-11-22 10:09:12 +03:00
case P_OCTAL :
1999-12-13 16:27:58 +03:00
fprintf ( f , " %s " , octal_string ( * ( int * ) ptr ) ) ;
1997-11-22 10:09:12 +03:00
break ;
1996-05-04 11:50:46 +04:00
1997-11-22 10:09:12 +03:00
case P_GSTRING :
case P_UGSTRING :
if ( ( char * ) ptr )
fprintf ( f , " %s " , ( char * ) ptr ) ;
break ;
case P_STRING :
case P_USTRING :
if ( * ( char * * ) ptr )
fprintf ( f , " %s " , * ( char * * ) ptr ) ;
break ;
1998-03-14 11:27:41 +03:00
case P_SEP :
break ;
1997-11-22 10:09:12 +03:00
}
1996-05-04 11:50:46 +04:00
}
/***************************************************************************
check if two parameters are equal
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL equal_parameter ( parm_type type , void * ptr1 , void * ptr2 )
{
switch ( type )
{
case P_BOOL :
case P_BOOLREV :
return ( * ( ( BOOL * ) ptr1 ) = = * ( ( BOOL * ) ptr2 ) ) ;
case P_INTEGER :
1997-11-22 10:09:12 +03:00
case P_ENUM :
1996-05-04 11:50:46 +04:00
case P_OCTAL :
return ( * ( ( int * ) ptr1 ) = = * ( ( int * ) ptr2 ) ) ;
case P_CHAR :
return ( * ( ( char * ) ptr1 ) = = * ( ( char * ) ptr2 ) ) ;
case P_GSTRING :
1996-08-19 15:17:29 +04:00
case P_UGSTRING :
1996-05-04 11:50:46 +04:00
{
char * p1 = ( char * ) ptr1 , * p2 = ( char * ) ptr2 ;
if ( p1 & & ! * p1 ) p1 = NULL ;
if ( p2 & & ! * p2 ) p2 = NULL ;
return ( p1 = = p2 | | strequal ( p1 , p2 ) ) ;
}
case P_STRING :
1996-08-19 15:17:29 +04:00
case P_USTRING :
1996-05-04 11:50:46 +04:00
{
char * p1 = * ( char * * ) ptr1 , * p2 = * ( char * * ) ptr2 ;
if ( p1 & & ! * p1 ) p1 = NULL ;
if ( p2 & & ! * p2 ) p2 = NULL ;
return ( p1 = = p2 | | strequal ( p1 , p2 ) ) ;
}
1998-03-14 11:27:41 +03:00
case P_SEP :
break ;
1996-05-04 11:50:46 +04:00
}
return ( False ) ;
}
/***************************************************************************
Process a new section ( service ) . At this stage all sections are services .
Later we ' ll have special sections that permit server parameters to be set .
Returns True on success , False on failure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL do_section ( char * pszSectionName )
{
BOOL bRetval ;
BOOL isglobal = ( ( strwicmp ( pszSectionName , GLOBAL_NAME ) = = 0 ) | |
( strwicmp ( pszSectionName , GLOBAL_NAME2 ) = = 0 ) ) ;
bRetval = False ;
/* if we were in a global section then do the local inits */
if ( bInGlobalSection & & ! isglobal )
init_locals ( ) ;
/* if we've just struck a global section, note the fact. */
bInGlobalSection = isglobal ;
/* check for multiple global sections */
if ( bInGlobalSection )
{
1998-08-03 22:13:13 +04:00
DEBUG ( 3 , ( " Processing section \" [%s] \" \n " , pszSectionName ) ) ;
1996-05-04 11:50:46 +04:00
return ( True ) ;
}
if ( ! bInGlobalSection & & bGlobalOnly ) return ( True ) ;
/* if we have a current service, tidy it up before moving on */
bRetval = True ;
if ( iServiceIndex > = 0 )
bRetval = service_ok ( iServiceIndex ) ;
/* if all is still well, move to the next record in the services array */
if ( bRetval )
{
/* We put this here to avoid an odd message order if messages are */
/* issued by the post-processing of a previous section. */
DEBUG ( 2 , ( " Processing section \" [%s] \" \n " , pszSectionName ) ) ;
if ( ( iServiceIndex = add_a_service ( & sDefault , pszSectionName ) ) < 0 )
{
DEBUG ( 0 , ( " Failed to add a new service \n " ) ) ;
return ( False ) ;
}
}
return ( bRetval ) ;
}
1998-03-14 11:27:41 +03:00
/***************************************************************************
determine if a partcular base parameter is currently set to the default value .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL is_default ( int i )
{
if ( ! defaults_saved ) return False ;
switch ( parm_table [ i ] . type ) {
case P_STRING :
case P_USTRING :
return strequal ( parm_table [ i ] . def . svalue , * ( char * * ) parm_table [ i ] . ptr ) ;
case P_GSTRING :
case P_UGSTRING :
return strequal ( parm_table [ i ] . def . svalue , ( char * ) parm_table [ i ] . ptr ) ;
case P_BOOL :
case P_BOOLREV :
return parm_table [ i ] . def . bvalue = = * ( BOOL * ) parm_table [ i ] . ptr ;
case P_CHAR :
return parm_table [ i ] . def . cvalue = = * ( char * ) parm_table [ i ] . ptr ;
case P_INTEGER :
case P_OCTAL :
case P_ENUM :
return parm_table [ i ] . def . ivalue = = * ( int * ) parm_table [ i ] . ptr ;
case P_SEP :
break ;
}
return False ;
}
1996-05-04 11:50:46 +04:00
/***************************************************************************
Display the contents of the global structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1997-09-11 06:19:04 +04:00
static void dump_globals ( FILE * f )
1996-05-04 11:50:46 +04:00
{
1998-03-14 11:27:41 +03:00
int i ;
1999-12-13 16:27:58 +03:00
fprintf ( f , " # Global parameters \n [global] \n " ) ;
1998-03-14 11:27:41 +03:00
for ( i = 0 ; parm_table [ i ] . label ; i + + )
if ( parm_table [ i ] . class = = P_GLOBAL & &
parm_table [ i ] . ptr & &
( i = = 0 | | ( parm_table [ i ] . ptr ! = parm_table [ i - 1 ] . ptr ) ) ) {
if ( defaults_saved & & is_default ( i ) ) continue ;
fprintf ( f , " \t %s = " , parm_table [ i ] . label ) ;
print_parameter ( & parm_table [ i ] , parm_table [ i ] . ptr , f ) ;
fprintf ( f , " \n " ) ;
}
1996-05-04 11:50:46 +04:00
}
1998-03-14 14:24:01 +03:00
/***************************************************************************
return True if a local parameter is currently set to the global default
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lp_is_default ( int snum , struct parm_struct * parm )
{
int pdiff = PTR_DIFF ( parm - > ptr , & sDefault ) ;
return equal_parameter ( parm - > type ,
( ( char * ) pSERVICE ( snum ) ) + pdiff ,
( ( char * ) & sDefault ) + pdiff ) ;
}
1996-05-04 11:50:46 +04:00
/***************************************************************************
Display the contents of a single services record .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1997-09-11 06:19:04 +04:00
static void dump_a_service ( service * pService , FILE * f )
1996-05-04 11:50:46 +04:00
{
1998-03-14 11:27:41 +03:00
int i ;
if ( pService ! = & sDefault )
fprintf ( f , " \n [%s] \n " , pService - > szService ) ;
for ( i = 0 ; parm_table [ i ] . label ; i + + )
if ( parm_table [ i ] . class = = P_LOCAL & &
parm_table [ i ] . ptr & &
( * parm_table [ i ] . label ! = ' - ' ) & &
( i = = 0 | | ( parm_table [ i ] . ptr ! = parm_table [ i - 1 ] . ptr ) ) ) {
int pdiff = PTR_DIFF ( parm_table [ i ] . ptr , & sDefault ) ;
if ( pService = = & sDefault ) {
if ( defaults_saved & & is_default ( i ) ) continue ;
} else {
if ( equal_parameter ( parm_table [ i ] . type ,
( ( char * ) pService ) + pdiff ,
( ( char * ) & sDefault ) + pdiff ) )
continue ;
}
1996-05-04 11:50:46 +04:00
1998-03-14 11:27:41 +03:00
fprintf ( f , " \t %s = " , parm_table [ i ] . label ) ;
print_parameter ( & parm_table [ i ] ,
( ( char * ) pService ) + pdiff , f ) ;
fprintf ( f , " \n " ) ;
}
1996-05-04 11:50:46 +04:00
}
1997-09-11 06:19:04 +04:00
/***************************************************************************
1998-03-14 11:27:41 +03:00
return info about the next service in a service . snum = = - 1 gives the globals
1997-09-11 06:19:04 +04:00
1998-03-14 11:27:41 +03:00
return NULL when out of parameters
1997-09-11 06:19:04 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1998-03-08 17:14:49 +03:00
struct parm_struct * lp_next_parameter ( int snum , int * i , int allparameters )
1997-09-11 06:19:04 +04:00
{
1998-03-14 11:27:41 +03:00
if ( snum = = - 1 ) {
1997-09-11 06:19:04 +04:00
/* do the globals */
1998-03-14 11:27:41 +03:00
for ( ; parm_table [ * i ] . label ; ( * i ) + + ) {
if ( parm_table [ * i ] . class = = P_SEPARATOR )
1998-03-08 17:14:49 +03:00
return & parm_table [ ( * i ) + + ] ;
1998-03-14 11:27:41 +03:00
if ( ! parm_table [ * i ] . ptr | | ( * parm_table [ * i ] . label = = ' - ' ) )
continue ;
if ( ( * i ) > 0 & & ( parm_table [ * i ] . ptr = = parm_table [ ( * i ) - 1 ] . ptr ) )
continue ;
return & parm_table [ ( * i ) + + ] ;
}
1997-09-11 06:19:04 +04:00
} else {
1998-03-14 11:27:41 +03:00
service * pService = pSERVICE ( snum ) ;
for ( ; parm_table [ * i ] . label ; ( * i ) + + ) {
if ( parm_table [ * i ] . class = = P_SEPARATOR )
return & parm_table [ ( * i ) + + ] ;
1997-09-11 06:19:04 +04:00
if ( parm_table [ * i ] . class = = P_LOCAL & &
parm_table [ * i ] . ptr & &
( * parm_table [ * i ] . label ! = ' - ' ) & &
( ( * i ) = = 0 | |
( parm_table [ * i ] . ptr ! = parm_table [ ( * i ) - 1 ] . ptr ) ) ) {
int pdiff = PTR_DIFF ( parm_table [ * i ] . ptr , & sDefault ) ;
1998-03-14 11:27:41 +03:00
if ( allparameters | |
1997-09-11 06:19:04 +04:00
! equal_parameter ( parm_table [ * i ] . type ,
( ( char * ) pService ) + pdiff ,
( ( char * ) & sDefault ) + pdiff ) ) {
1998-03-08 17:14:49 +03:00
return & parm_table [ ( * i ) + + ] ;
1997-09-11 06:19:04 +04:00
}
}
1998-03-14 11:27:41 +03:00
}
1997-09-11 06:19:04 +04:00
}
1998-03-14 11:27:41 +03:00
return NULL ;
1997-09-11 06:19:04 +04:00
}
1996-05-04 11:50:46 +04:00
#if 0
/***************************************************************************
Display the contents of a single copy structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static void dump_copy_map ( BOOL * pcopymap )
{
int i ;
if ( ! pcopymap ) return ;
printf ( " \n \t Non-Copied parameters: \n " ) ;
for ( i = 0 ; parm_table [ i ] . label ; i + + )
if ( parm_table [ i ] . class = = P_LOCAL & &
parm_table [ i ] . ptr & & ! pcopymap [ i ] & &
( i = = 0 | | ( parm_table [ i ] . ptr ! = parm_table [ i - 1 ] . ptr ) ) )
{
printf ( " \t \t %s \n " , parm_table [ i ] . label ) ;
}
}
# endif
/***************************************************************************
Return TRUE if the passed service number is within range .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lp_snum_ok ( int iService )
{
return ( LP_SNUM_OK ( iService ) & & iSERVICE ( iService ) . bAvailable ) ;
}
/***************************************************************************
1998-08-14 21:38:29 +04:00
auto - load some home services
1996-05-04 11:50:46 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static void lp_add_auto_services ( char * str )
{
1998-08-14 21:38:29 +04:00
char * s ;
char * p ;
int homes ;
1996-05-04 11:50:46 +04:00
1998-08-14 21:38:29 +04:00
if ( ! str ) return ;
1996-05-04 11:50:46 +04:00
1998-08-14 21:38:29 +04:00
s = strdup ( str ) ;
if ( ! s ) return ;
1996-05-04 11:50:46 +04:00
1998-08-14 21:38:29 +04:00
homes = lp_servicenumber ( HOMES_NAME ) ;
for ( p = strtok ( s , LIST_SEP ) ; p ; p = strtok ( NULL , LIST_SEP ) ) {
1999-12-13 16:27:58 +03:00
char * home = get_user_home_dir ( p ) ;
1998-08-14 21:38:29 +04:00
if ( lp_servicenumber ( p ) > = 0 ) continue ;
if ( home & & homes > = 0 ) {
lp_add_home ( p , homes , home ) ;
}
}
free ( s ) ;
1996-05-04 11:50:46 +04:00
}
/***************************************************************************
auto - load one printer
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1998-08-14 21:38:29 +04:00
void lp_add_one_printer ( char * name , char * comment )
1996-05-04 11:50:46 +04:00
{
1998-08-14 21:38:29 +04:00
int printers = lp_servicenumber ( PRINTERS_NAME ) ;
int i ;
1996-05-04 11:50:46 +04:00
1998-08-14 21:38:29 +04:00
if ( lp_servicenumber ( name ) < 0 ) {
lp_add_printer ( name , printers ) ;
if ( ( i = lp_servicenumber ( name ) ) > = 0 )
string_set ( & iSERVICE ( i ) . comment , comment ) ;
}
1996-05-04 11:50:46 +04:00
}
/***************************************************************************
have we loaded a services file yet ?
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lp_loaded ( void )
{
return ( bLoaded ) ;
}
/***************************************************************************
unload unused services
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void lp_killunused ( BOOL ( * snumused ) ( int ) )
{
int i ;
for ( i = 0 ; i < iNumServices ; i + + )
1997-09-11 06:19:04 +04:00
if ( VALID ( i ) & & ( ! snumused | | ! snumused ( i ) ) )
1996-05-04 11:50:46 +04:00
{
iSERVICE ( i ) . valid = False ;
free_service ( pSERVICE ( i ) ) ;
}
}
1998-03-14 11:27:41 +03:00
/***************************************************************************
save the curent values of all global and sDefault parameters into the
defaults union . This allows swat and testparm to show only the
changed ( ie . non - default ) parameters .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static void lp_save_defaults ( void )
{
int i ;
for ( i = 0 ; parm_table [ i ] . label ; i + + ) {
if ( i > 0 & & parm_table [ i ] . ptr = = parm_table [ i - 1 ] . ptr ) continue ;
switch ( parm_table [ i ] . type ) {
case P_STRING :
case P_USTRING :
parm_table [ i ] . def . svalue = strdup ( * ( char * * ) parm_table [ i ] . ptr ) ;
break ;
case P_GSTRING :
case P_UGSTRING :
parm_table [ i ] . def . svalue = strdup ( ( char * ) parm_table [ i ] . ptr ) ;
break ;
case P_BOOL :
case P_BOOLREV :
parm_table [ i ] . def . bvalue = * ( BOOL * ) parm_table [ i ] . ptr ;
break ;
case P_CHAR :
parm_table [ i ] . def . cvalue = * ( char * ) parm_table [ i ] . ptr ;
break ;
case P_INTEGER :
case P_OCTAL :
case P_ENUM :
parm_table [ i ] . def . ivalue = * ( int * ) parm_table [ i ] . ptr ;
break ;
case P_SEP :
break ;
}
}
defaults_saved = True ;
}
1996-05-04 11:50:46 +04:00
/***************************************************************************
Load the services array from the services file . Return True on success ,
False on failure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1998-03-14 11:27:41 +03:00
BOOL lp_load ( char * pszFname , BOOL global_only , BOOL save_defaults , BOOL add_ipc )
1996-05-04 11:50:46 +04:00
{
pstring n2 ;
BOOL bRetval ;
2000-01-05 09:36:36 +03:00
1996-05-04 11:50:46 +04:00
add_to_file_list ( pszFname ) ;
bRetval = False ;
bInGlobalSection = True ;
bGlobalOnly = global_only ;
init_globals ( ) ;
1998-03-14 11:27:41 +03:00
if ( save_defaults ) {
init_locals ( ) ;
lp_save_defaults ( ) ;
}
1996-05-04 11:50:46 +04:00
1997-09-26 22:55:29 +04:00
pstrcpy ( n2 , pszFname ) ;
1996-05-04 11:50:46 +04:00
standard_sub_basic ( n2 ) ;
/* We get sections first, so have to start 'behind' to make up */
iServiceIndex = - 1 ;
bRetval = pm_process ( n2 , do_section , do_parameter ) ;
/* finish up the last section */
DEBUG ( 3 , ( " pm_process() returned %s \n " , BOOLSTR ( bRetval ) ) ) ;
if ( bRetval )
if ( iServiceIndex > = 0 )
bRetval = service_ok ( iServiceIndex ) ;
lp_add_auto_services ( lp_auto_services ( ) ) ;
1998-03-14 11:27:41 +03:00
if ( add_ipc )
lp_add_ipc ( ) ;
1996-05-04 11:50:46 +04:00
1997-07-30 23:17:51 +04:00
set_default_server_announce_type ( ) ;
1998-10-07 03:46:01 +04:00
bLoaded = True ;
/* Now we check bWINSsupport and set szWINSserver to 127.0.0.1 */
/* if bWINSsupport is true and we are in the client */
1998-09-29 08:43:40 +04:00
if ( in_client & & Globals . bWINSsupport ) {
string_set ( & Globals . szWINSserver , " 127.0.0.1 " ) ;
}
1996-05-04 11:50:46 +04:00
return ( bRetval ) ;
}
1999-12-13 16:27:58 +03:00
/***************************************************************************
reset the max number of services
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void lp_resetnumservices ( void )
{
iNumServices = 0 ;
}
1996-05-04 11:50:46 +04:00
/***************************************************************************
return the max number of services
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
int lp_numservices ( void )
{
return ( iNumServices ) ;
}
/***************************************************************************
Display the contents of the services array in human - readable form .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1999-12-13 16:27:58 +03:00
void lp_dump ( FILE * f , BOOL show_defaults , int maxtoprint )
1996-05-04 11:50:46 +04:00
{
int iService ;
1998-03-17 17:46:17 +03:00
if ( show_defaults ) {
1998-03-17 14:44:16 +03:00
defaults_saved = False ;
}
1997-09-11 06:19:04 +04:00
dump_globals ( f ) ;
1996-05-04 11:50:46 +04:00
1997-09-11 06:19:04 +04:00
dump_a_service ( & sDefault , f ) ;
1996-05-04 11:50:46 +04:00
1999-12-13 16:27:58 +03:00
for ( iService = 0 ; iService < maxtoprint ; iService + + )
lp_dump_one ( f , show_defaults , iService ) ;
}
/***************************************************************************
Display the contents of one service in human - readable form .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void lp_dump_one ( FILE * f , BOOL show_defaults , int snum )
{
if ( VALID ( snum ) )
{
if ( iSERVICE ( snum ) . szService [ 0 ] = = ' \0 ' )
return ;
dump_a_service ( pSERVICE ( snum ) , f ) ;
}
1996-05-04 11:50:46 +04:00
}
1997-09-11 06:19:04 +04:00
1996-05-04 11:50:46 +04:00
/***************************************************************************
Return the number of the service with the given name , or - 1 if it doesn ' t
exist . Note that this is a DIFFERENT ANIMAL from the internal function
getservicebyname ( ) ! This works ONLY if all services have been loaded , and
does not copy the found service .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
int lp_servicenumber ( char * pszServiceName )
{
int iService ;
for ( iService = iNumServices - 1 ; iService > = 0 ; iService - - )
if ( VALID ( iService ) & &
1997-11-27 02:43:06 +03:00
strequal ( lp_servicename ( iService ) , pszServiceName ) )
1996-05-04 11:50:46 +04:00
break ;
if ( iService < 0 )
DEBUG ( 7 , ( " lp_servicenumber: couldn't find %s \n " , pszServiceName ) ) ;
return ( iService ) ;
}
/*******************************************************************
a useful volume label function
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
char * volume_label ( int snum )
{
char * ret = lp_volume ( snum ) ;
1997-11-03 22:24:45 +03:00
if ( ! * ret ) return ( lp_servicename ( snum ) ) ;
return ( ret ) ;
1996-05-04 11:50:46 +04:00
}
1997-07-30 23:17:51 +04:00
/*******************************************************************
Set the server type we will announce as via nmbd .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1998-09-17 23:16:12 +04:00
static void set_default_server_announce_type ( void )
1997-07-30 23:17:51 +04:00
{
1999-12-13 16:27:58 +03:00
default_server_announce = ( SV_TYPE_WORKSTATION | SV_TYPE_SERVER |
SV_TYPE_SERVER_UNIX | SV_TYPE_PRINTQ_SERVER ) ;
if ( lp_announce_as ( ) = = ANNOUNCE_AS_NT_SERVER )
default_server_announce | = ( SV_TYPE_SERVER_NT | SV_TYPE_NT ) ;
if ( lp_announce_as ( ) = = ANNOUNCE_AS_NT_WORKSTATION )
default_server_announce | = SV_TYPE_NT ;
else if ( lp_announce_as ( ) = = ANNOUNCE_AS_WIN95 )
default_server_announce | = SV_TYPE_WIN95_PLUS ;
else if ( lp_announce_as ( ) = = ANNOUNCE_AS_WFW )
default_server_announce | = SV_TYPE_WFW ;
default_server_announce | = ( lp_time_server ( ) ? SV_TYPE_TIME_SOURCE : 0 ) ;
1997-07-30 23:17:51 +04:00
}
1997-09-11 06:19:04 +04:00
/*******************************************************************
remove a service
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void lp_remove_service ( int snum )
{
pSERVICE ( snum ) - > valid = False ;
}
/*******************************************************************
copy a service
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void lp_copy_service ( int snum , char * new_name )
{
char * oldname = lp_servicename ( snum ) ;
do_section ( new_name ) ;
if ( snum > = 0 ) {
snum = lp_servicenumber ( new_name ) ;
if ( snum > = 0 )
lp_do_parameter ( snum , " copy " , oldname ) ;
}
}
1997-07-30 23:17:51 +04:00
/*******************************************************************
Get the default server type we will announce as via nmbd .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
int lp_default_server_announce ( void )
{
return default_server_announce ;
}
/*******************************************************************
Split the announce version into major and minor numbers .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
int lp_major_announce_version ( void )
{
static BOOL got_major = False ;
static int major_version = DEFAULT_MAJOR_VERSION ;
char * vers ;
char * p ;
if ( got_major )
return major_version ;
got_major = True ;
if ( ( vers = lp_announce_version ( ) ) = = NULL )
return major_version ;
if ( ( p = strchr ( vers , ' . ' ) ) = = 0 )
return major_version ;
* p = ' \0 ' ;
major_version = atoi ( vers ) ;
return major_version ;
}
int lp_minor_announce_version ( void )
{
static BOOL got_minor = False ;
static int minor_version = DEFAULT_MINOR_VERSION ;
char * vers ;
char * p ;
if ( got_minor )
return minor_version ;
got_minor = True ;
if ( ( vers = lp_announce_version ( ) ) = = NULL )
return minor_version ;
if ( ( p = strchr ( vers , ' . ' ) ) = = 0 )
return minor_version ;
p + + ;
minor_version = atoi ( p ) ;
return minor_version ;
}
1997-09-11 06:19:04 +04:00
1998-03-16 23:59:47 +03:00
/***********************************************************
Set the global name resolution order ( used in smbclient ) .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void lp_set_name_resolve_order ( char * new_order )
{
Globals . szNameResolveOrder = new_order ;
}
1998-09-18 21:50:18 +04:00
/***********************************************************
1998-09-30 05:05:51 +04:00
Set the flag that says if kernel oplocks are available
( called by smbd ) .
1998-09-18 21:50:18 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1998-09-30 05:05:51 +04:00
static BOOL kernel_oplocks_available = False ;
1998-09-18 21:50:18 +04:00
void lp_set_kernel_oplocks ( BOOL val )
{
1998-09-30 05:05:51 +04:00
/*
* Only set this to True if kerenl
* oplocks are really available and were
* turned on in the smb . conf file .
*/
if ( Globals . bKernelOplocks & & val )
kernel_oplocks_available = True ;
else
kernel_oplocks_available = False ;
}
/***********************************************************
Return True if kernel oplocks are available and were turned
on in smb . conf .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lp_kernel_oplocks ( void )
{
return kernel_oplocks_available ;
1998-09-18 21:50:18 +04:00
}
1998-11-24 00:51:05 +03:00
/***********************************************************
1999-12-13 16:27:58 +03:00
Functions to return the current security masks / modes . If
set to - 1 then return the create mask / mode instead .
1998-11-24 00:51:05 +03:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1999-04-11 14:23:19 +04:00
1999-12-13 16:27:58 +03:00
int lp_security_mask ( int snum )
1998-11-24 00:51:05 +03:00
{
1999-12-13 16:27:58 +03:00
int val = _lp_security_mask ( snum ) ;
if ( val = = - 1 )
return lp_create_mask ( snum ) ;
return val ;
1999-04-11 14:23:19 +04:00
}
1999-12-13 16:27:58 +03:00
int lp_force_security_mode ( int snum )
1999-04-11 14:23:19 +04:00
{
1999-12-13 16:27:58 +03:00
int val = _lp_force_security_mode ( snum ) ;
if ( val = = - 1 )
return lp_force_create_mode ( snum ) ;
return val ;
1999-04-11 14:23:19 +04:00
}
1999-12-13 16:27:58 +03:00
int lp_dir_security_mask ( int snum )
1999-04-11 14:23:19 +04:00
{
1999-12-13 16:27:58 +03:00
int val = _lp_dir_security_mask ( snum ) ;
if ( val = = - 1 )
return lp_dir_mask ( snum ) ;
return val ;
}
1999-04-11 14:23:19 +04:00
1999-12-13 16:27:58 +03:00
int lp_force_dir_security_mode ( int snum )
{
int val = _lp_force_dir_security_mode ( snum ) ;
if ( val = = - 1 )
return lp_force_dir_mode ( snum ) ;
return val ;
1998-11-24 00:51:05 +03:00
}