Add initshutdown pipe commands to rpcclient. Second part of fix to bug
[Samba/gebeck_regimport.git] / source / param / loadparm.c
blob55ab4ee3a08cff8ecab545dc8837fc524bd723e3
1 /*
2 Unix SMB/CIFS implementation.
3 Parameter loading functions
4 Copyright (C) Karl Auer 1993-1998
6 Largely re-written by Andrew Tridgell, September 1994
8 Copyright (C) Simo Sorce 2001
9 Copyright (C) Alexander Bokovoy 2002
10 Copyright (C) Stefan (metze) Metzmacher 2002
11 Copyright (C) Jim McDonough <jmcd@us.ibm.com> 2003
13 This program is free software; you can redistribute it and/or modify
14 it under the terms of the GNU General Public License as published by
15 the Free Software Foundation; either version 2 of the License, or
16 (at your option) any later version.
18 This program is distributed in the hope that it will be useful,
19 but WITHOUT ANY WARRANTY; without even the implied warranty of
20 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 GNU General Public License for more details.
23 You should have received a copy of the GNU General Public License
24 along with this program; if not, write to the Free Software
25 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
29 * Load parameters.
31 * This module provides suitable callback functions for the params
32 * module. It builds the internal table of service details which is
33 * then used by the rest of the server.
35 * To add a parameter:
37 * 1) add it to the global or service structure definition
38 * 2) add it to the parm_table
39 * 3) add it to the list of available functions (eg: using FN_GLOBAL_STRING())
40 * 4) If it's a global then initialise it in init_globals. If a local
41 * (ie. service) parameter then initialise it in the sDefault structure
44 * Notes:
45 * The configuration file is processed sequentially for speed. It is NOT
46 * accessed randomly as happens in 'real' Windows. For this reason, there
47 * is a fair bit of sequence-dependent code here - ie., code which assumes
48 * that certain things happen before others. In particular, the code which
49 * happens at the boundary between sections is delicately poised, so be
50 * careful!
54 #include "includes.h"
56 BOOL in_client = False; /* Not in the client by default */
57 BOOL bLoaded = False;
59 extern userdom_struct current_user_info;
60 extern pstring user_socket_options;
62 #ifndef GLOBAL_NAME
63 #define GLOBAL_NAME "global"
64 #endif
66 #ifndef PRINTERS_NAME
67 #define PRINTERS_NAME "printers"
68 #endif
70 #ifndef HOMES_NAME
71 #define HOMES_NAME "homes"
72 #endif
74 /* some helpful bits */
75 #define LP_SNUM_OK(i) (((i) >= 0) && ((i) < iNumServices) && ServicePtrs[(i)]->valid)
76 #define VALID(i) ServicePtrs[i]->valid
78 int keepalive = DEFAULT_KEEPALIVE;
79 BOOL use_getwd_cache = True;
81 extern int extra_time_offset;
83 static BOOL defaults_saved = False;
85 typedef struct _param_opt_struct param_opt_struct;
86 struct _param_opt_struct {
87 param_opt_struct *prev, *next;
88 char *key;
89 char *value;
90 char **list;
93 /*
94 * This structure describes global (ie., server-wide) parameters.
96 typedef struct
98 char *smb_ports;
99 char *dos_charset;
100 char *unix_charset;
101 char *display_charset;
102 char *szPrintcapname;
103 char *szEnumPortsCommand;
104 char *szAddPrinterCommand;
105 char *szDeletePrinterCommand;
106 char *szOs2DriverMap;
107 char *szLockDir;
108 char *szPidDir;
109 char *szRootdir;
110 char *szDefaultService;
111 char *szDfree;
112 char *szGetQuota;
113 char *szSetQuota;
114 char *szMsgCommand;
115 char *szHostsEquiv;
116 char *szServerString;
117 char *szAutoServices;
118 char *szPasswdProgram;
119 char *szPasswdChat;
120 char *szLogFile;
121 char *szConfigFile;
122 char *szSMBPasswdFile;
123 char *szPrivateDir;
124 char **szPassdbBackend;
125 char **szPreloadModules;
126 char *szPasswordServer;
127 char *szSocketOptions;
128 char *szRealm;
129 char *szAfsUsernameMap;
130 char *szUsernameMap;
131 char *szLogonScript;
132 char *szLogonPath;
133 char *szLogonDrive;
134 char *szLogonHome;
135 char **szWINSservers;
136 char **szInterfaces;
137 char *szRemoteAnnounce;
138 char *szRemoteBrowseSync;
139 char *szSocketAddress;
140 char *szNISHomeMapName;
141 char *szAnnounceVersion; /* This is initialised in init_globals */
142 char *szWorkgroup;
143 char *szNetbiosName;
144 char **szNetbiosAliases;
145 char *szNetbiosScope;
146 char *szDomainOtherSIDs;
147 char *szNameResolveOrder;
148 char *szPanicAction;
149 char *szAddUserScript;
150 char *szDelUserScript;
151 char *szAddGroupScript;
152 char *szDelGroupScript;
153 char *szAddUserToGroupScript;
154 char *szDelUserFromGroupScript;
155 char *szSetPrimaryGroupScript;
156 char *szAddMachineScript;
157 char *szShutdownScript;
158 char *szAbortShutdownScript;
159 char *szWINSHook;
160 char *szWINSPartners;
161 char *szUtmpDir;
162 char *szWtmpDir;
163 BOOL bUtmp;
164 char *szSourceEnv;
165 char *szIdmapUID;
166 char *szIdmapGID;
167 BOOL bEnableRidAlgorithm;
168 int AlgorithmicRidBase;
169 char *szTemplatePrimaryGroup;
170 char *szTemplateHomedir;
171 char *szTemplateShell;
172 char *szWinbindSeparator;
173 BOOL bWinbindEnableLocalAccounts;
174 BOOL bWinbindEnumUsers;
175 BOOL bWinbindEnumGroups;
176 BOOL bWinbindUseDefaultDomain;
177 BOOL bWinbindTrustedDomainsOnly;
178 char *szWinbindBackend;
179 char *szIdmapBackend;
180 char *szAddShareCommand;
181 char *szChangeShareCommand;
182 char *szDeleteShareCommand;
183 char *szGuestaccount;
184 char *szManglingMethod;
185 int mangle_prefix;
186 int max_log_size;
187 char *szLogLevel;
188 int max_xmit;
189 int max_mux;
190 int max_open_files;
191 int pwordlevel;
192 int unamelevel;
193 int deadtime;
194 int maxprotocol;
195 int minprotocol;
196 int security;
197 char **AuthMethods;
198 BOOL paranoid_server_security;
199 int maxdisksize;
200 int lpqcachetime;
201 int iMaxSmbdProcesses;
202 BOOL bDisableSpoolss;
203 int iTotalPrintJobs;
204 int syslog;
205 int os_level;
206 int enhanced_browsing;
207 int max_ttl;
208 int max_wins_ttl;
209 int min_wins_ttl;
210 int ReadSize;
211 int lm_announce;
212 int lm_interval;
213 int announce_as; /* This is initialised in init_globals */
214 int machine_password_timeout;
215 int change_notify_timeout;
216 int map_to_guest;
217 int min_passwd_length;
218 int oplock_break_wait_time;
219 int winbind_cache_time;
220 int iLockSpinCount;
221 int iLockSpinTime;
222 char *szLdapMachineSuffix;
223 char *szLdapUserSuffix;
224 char *szLdapIdmapSuffix;
225 char *szLdapGroupSuffix;
226 #ifdef WITH_LDAP_SAMCONFIG
227 int ldap_port;
228 char *szLdapServer;
229 #endif
230 int ldap_ssl;
231 char *szLdapSuffix;
232 char *szLdapFilter;
233 char *szLdapAdminDn;
234 char *szAclCompat;
235 int ldap_passwd_sync;
236 BOOL ldap_delete_dn;
237 BOOL bMsAddPrinterWizard;
238 BOOL bDNSproxy;
239 BOOL bWINSsupport;
240 BOOL bWINSproxy;
241 BOOL bLocalMaster;
242 BOOL bPreferredMaster;
243 BOOL bDomainMaster;
244 BOOL bDomainLogons;
245 BOOL bEncryptPasswords;
246 BOOL bUpdateEncrypt;
247 int clientSchannel;
248 int serverSchannel;
249 BOOL bNullPasswords;
250 BOOL bObeyPamRestrictions;
251 BOOL bLoadPrinters;
252 BOOL bLargeReadwrite;
253 BOOL bReadRaw;
254 BOOL bWriteRaw;
255 BOOL bReadPrediction;
256 BOOL bReadbmpx;
257 BOOL bSyslogOnly;
258 BOOL bBrowseList;
259 BOOL bNISHomeMap;
260 BOOL bTimeServer;
261 BOOL bBindInterfacesOnly;
262 BOOL bPamPasswordChange;
263 BOOL bUnixPasswdSync;
264 BOOL bPasswdChatDebug;
265 BOOL bTimestampLogs;
266 BOOL bNTSmbSupport;
267 BOOL bNTPipeSupport;
268 BOOL bNTStatusSupport;
269 BOOL bStatCache;
270 BOOL bKernelOplocks;
271 BOOL bAllowTrustedDomains;
272 BOOL bLanmanAuth;
273 BOOL bNTLMAuth;
274 BOOL bUseSpnego;
275 BOOL bClientLanManAuth;
276 BOOL bClientNTLMv2Auth;
277 BOOL bClientPlaintextAuth;
278 BOOL bClientUseSpnego;
279 BOOL bDebugHiresTimestamp;
280 BOOL bDebugPid;
281 BOOL bDebugUid;
282 BOOL bHostMSDfs;
283 BOOL bHideLocalUsers;
284 BOOL bUnicode;
285 BOOL bUseMmap;
286 BOOL bHostnameLookups;
287 BOOL bUnixExtensions;
288 BOOL bDisableNetbios;
289 BOOL bKernelChangeNotify;
290 int restrict_anonymous;
291 int name_cache_timeout;
292 int client_signing;
293 int server_signing;
294 param_opt_struct *param_opt;
296 global;
298 static global Globals;
301 * This structure describes a single service.
303 typedef struct
305 BOOL valid;
306 BOOL autoloaded;
307 char *szService;
308 char *szPath;
309 char *szUsername;
310 char **szInvalidUsers;
311 char **szValidUsers;
312 char **szAdminUsers;
313 char *szCopy;
314 char *szInclude;
315 char *szPreExec;
316 char *szPostExec;
317 char *szRootPreExec;
318 char *szRootPostExec;
319 char *szPrintcommand;
320 char *szLpqcommand;
321 char *szLprmcommand;
322 char *szLppausecommand;
323 char *szLpresumecommand;
324 char *szQueuepausecommand;
325 char *szQueueresumecommand;
326 char *szPrintername;
327 char *szDontdescend;
328 char **szHostsallow;
329 char **szHostsdeny;
330 char *szMagicScript;
331 char *szMagicOutput;
332 char *szMangledMap;
333 char *szVetoFiles;
334 char *szHideFiles;
335 char *szVetoOplockFiles;
336 char *comment;
337 char *force_user;
338 char *force_group;
339 char **readlist;
340 char **writelist;
341 char **printer_admin;
342 char *volume;
343 char *fstype;
344 char **szVfsObjects;
345 char *szMSDfsProxy;
346 int iMinPrintSpace;
347 int iMaxPrintJobs;
348 int iMaxReportedPrintJobs;
349 int iWriteCacheSize;
350 int iCreate_mask;
351 int iCreate_force_mode;
352 int iSecurity_mask;
353 int iSecurity_force_mode;
354 int iDir_mask;
355 int iDir_force_mode;
356 int iDir_Security_mask;
357 int iDir_Security_force_mode;
358 int iMaxConnections;
359 int iDefaultCase;
360 int iPrinting;
361 int iOplockContentionLimit;
362 int iCSCPolicy;
363 int iBlock_size;
364 BOOL bPreexecClose;
365 BOOL bRootpreexecClose;
366 BOOL bCaseSensitive;
367 BOOL bCasePreserve;
368 BOOL bShortCasePreserve;
369 BOOL bCaseMangle;
370 BOOL bHideDotFiles;
371 BOOL bHideSpecialFiles;
372 BOOL bHideUnReadable;
373 BOOL bHideUnWriteableFiles;
374 BOOL bBrowseable;
375 BOOL bAvailable;
376 BOOL bRead_only;
377 BOOL bNo_set_dir;
378 BOOL bGuest_only;
379 BOOL bGuest_ok;
380 BOOL bPrint_ok;
381 BOOL bMap_system;
382 BOOL bMap_hidden;
383 BOOL bMap_archive;
384 BOOL bLocking;
385 BOOL bStrictLocking;
386 BOOL bPosixLocking;
387 BOOL bShareModes;
388 BOOL bOpLocks;
389 BOOL bLevel2OpLocks;
390 BOOL bOnlyUser;
391 BOOL bMangledNames;
392 BOOL bWidelinks;
393 BOOL bSymlinks;
394 BOOL bSyncAlways;
395 BOOL bStrictAllocate;
396 BOOL bStrictSync;
397 char magic_char;
398 BOOL *copymap;
399 BOOL bDeleteReadonly;
400 BOOL bFakeOplocks;
401 BOOL bDeleteVetoFiles;
402 BOOL bDosFilemode;
403 BOOL bDosFiletimes;
404 BOOL bDosFiletimeResolution;
405 BOOL bFakeDirCreateTimes;
406 BOOL bBlockingLocks;
407 BOOL bInheritPerms;
408 BOOL bInheritACLS;
409 BOOL bMSDfsRoot;
410 BOOL bUseClientDriver;
411 BOOL bDefaultDevmode;
412 BOOL bNTAclSupport;
413 BOOL bUseSendfile;
414 BOOL bProfileAcls;
415 BOOL bMap_acl_inherit;
416 BOOL bAfs_Share;
417 param_opt_struct *param_opt;
419 char dummy[3]; /* for alignment */
421 service;
424 /* This is a default service used to prime a services structure */
425 static service sDefault = {
426 True, /* valid */
427 False, /* not autoloaded */
428 NULL, /* szService */
429 NULL, /* szPath */
430 NULL, /* szUsername */
431 NULL, /* szInvalidUsers */
432 NULL, /* szValidUsers */
433 NULL, /* szAdminUsers */
434 NULL, /* szCopy */
435 NULL, /* szInclude */
436 NULL, /* szPreExec */
437 NULL, /* szPostExec */
438 NULL, /* szRootPreExec */
439 NULL, /* szRootPostExec */
440 NULL, /* szPrintcommand */
441 NULL, /* szLpqcommand */
442 NULL, /* szLprmcommand */
443 NULL, /* szLppausecommand */
444 NULL, /* szLpresumecommand */
445 NULL, /* szQueuepausecommand */
446 NULL, /* szQueueresumecommand */
447 NULL, /* szPrintername */
448 NULL, /* szDontdescend */
449 NULL, /* szHostsallow */
450 NULL, /* szHostsdeny */
451 NULL, /* szMagicScript */
452 NULL, /* szMagicOutput */
453 NULL, /* szMangledMap */
454 NULL, /* szVetoFiles */
455 NULL, /* szHideFiles */
456 NULL, /* szVetoOplockFiles */
457 NULL, /* comment */
458 NULL, /* force user */
459 NULL, /* force group */
460 NULL, /* readlist */
461 NULL, /* writelist */
462 NULL, /* printer admin */
463 NULL, /* volume */
464 NULL, /* fstype */
465 NULL, /* vfs objects */
466 NULL, /* szMSDfsProxy */
467 0, /* iMinPrintSpace */
468 1000, /* iMaxPrintJobs */
469 0, /* iMaxReportedPrintJobs */
470 0, /* iWriteCacheSize */
471 0744, /* iCreate_mask */
472 0000, /* iCreate_force_mode */
473 0777, /* iSecurity_mask */
474 0, /* iSecurity_force_mode */
475 0755, /* iDir_mask */
476 0000, /* iDir_force_mode */
477 0777, /* iDir_Security_mask */
478 0, /* iDir_Security_force_mode */
479 0, /* iMaxConnections */
480 CASE_LOWER, /* iDefaultCase */
481 DEFAULT_PRINTING, /* iPrinting */
482 2, /* iOplockContentionLimit */
483 0, /* iCSCPolicy */
484 1024, /* iBlock_size */
485 False, /* bPreexecClose */
486 False, /* bRootpreexecClose */
487 False, /* case sensitive */
488 True, /* case preserve */
489 True, /* short case preserve */
490 False, /* case mangle */
491 True, /* bHideDotFiles */
492 False, /* bHideSpecialFiles */
493 False, /* bHideUnReadable */
494 False, /* bHideUnWriteableFiles */
495 True, /* bBrowseable */
496 True, /* bAvailable */
497 True, /* bRead_only */
498 True, /* bNo_set_dir */
499 False, /* bGuest_only */
500 False, /* bGuest_ok */
501 False, /* bPrint_ok */
502 False, /* bMap_system */
503 False, /* bMap_hidden */
504 True, /* bMap_archive */
505 True, /* bLocking */
506 True, /* bStrictLocking */
507 True, /* bPosixLocking */
508 True, /* bShareModes */
509 True, /* bOpLocks */
510 True, /* bLevel2OpLocks */
511 False, /* bOnlyUser */
512 True, /* bMangledNames */
513 True, /* bWidelinks */
514 True, /* bSymlinks */
515 False, /* bSyncAlways */
516 False, /* bStrictAllocate */
517 False, /* bStrictSync */
518 '~', /* magic char */
519 NULL, /* copymap */
520 False, /* bDeleteReadonly */
521 False, /* bFakeOplocks */
522 False, /* bDeleteVetoFiles */
523 False, /* bDosFilemode */
524 False, /* bDosFiletimes */
525 False, /* bDosFiletimeResolution */
526 False, /* bFakeDirCreateTimes */
527 True, /* bBlockingLocks */
528 False, /* bInheritPerms */
529 False, /* bInheritACLS */
530 False, /* bMSDfsRoot */
531 False, /* bUseClientDriver */
532 False, /* bDefaultDevmode */
533 True, /* bNTAclSupport */
534 False, /* bUseSendfile */
535 False, /* bProfileAcls */
536 False, /* bMap_acl_inherit */
537 False, /* bAfs_Share */
539 NULL, /* Parametric options */
541 "" /* dummy */
544 /* local variables */
545 static service **ServicePtrs = NULL;
546 static int iNumServices = 0;
547 static int iServiceIndex = 0;
548 static BOOL bInGlobalSection = True;
549 static BOOL bGlobalOnly = False;
550 static int server_role;
551 static int default_server_announce;
553 #define NUMPARAMETERS (sizeof(parm_table) / sizeof(struct parm_struct))
555 /* prototypes for the special type handlers */
556 static BOOL handle_include(const char *pszParmValue, char **ptr);
557 static BOOL handle_copy(const char *pszParmValue, char **ptr);
558 static BOOL handle_source_env(const char *pszParmValue, char **ptr);
559 static BOOL handle_netbios_name(const char *pszParmValue, char **ptr);
560 static BOOL handle_idmap_uid(const char *pszParmValue, char **ptr);
561 static BOOL handle_idmap_gid(const char *pszParmValue, char **ptr);
562 static BOOL handle_debug_list( const char *pszParmValue, char **ptr );
563 static BOOL handle_workgroup( const char *pszParmValue, char **ptr );
564 static BOOL handle_netbios_aliases( const char *pszParmValue, char **ptr );
565 static BOOL handle_netbios_scope( const char *pszParmValue, char **ptr );
566 static BOOL handle_charset( const char *pszParmValue, char **ptr );
568 static BOOL handle_ldap_suffix ( const char *pszParmValue, char **ptr );
569 static BOOL handle_ldap_sub_suffix ( const char *pszParmValue, char **ptr );
571 static BOOL handle_acl_compatibility(const char *pszParmValue, char **ptr);
573 static void set_server_role(void);
574 static void set_default_server_announce_type(void);
575 static void set_allowed_client_auth(void);
577 static const struct enum_list enum_protocol[] = {
578 {PROTOCOL_NT1, "NT1"},
579 {PROTOCOL_LANMAN2, "LANMAN2"},
580 {PROTOCOL_LANMAN1, "LANMAN1"},
581 {PROTOCOL_CORE, "CORE"},
582 {PROTOCOL_COREPLUS, "COREPLUS"},
583 {PROTOCOL_COREPLUS, "CORE+"},
584 {-1, NULL}
587 static const struct enum_list enum_security[] = {
588 {SEC_SHARE, "SHARE"},
589 {SEC_USER, "USER"},
590 {SEC_SERVER, "SERVER"},
591 {SEC_DOMAIN, "DOMAIN"},
592 #ifdef HAVE_ADS
593 {SEC_ADS, "ADS"},
594 #endif
595 {-1, NULL}
598 static const struct enum_list enum_printing[] = {
599 {PRINT_SYSV, "sysv"},
600 {PRINT_AIX, "aix"},
601 {PRINT_HPUX, "hpux"},
602 {PRINT_BSD, "bsd"},
603 {PRINT_QNX, "qnx"},
604 {PRINT_PLP, "plp"},
605 {PRINT_LPRNG, "lprng"},
606 {PRINT_CUPS, "cups"},
607 {PRINT_LPRNT, "nt"},
608 {PRINT_LPROS2, "os2"},
609 #ifdef DEVELOPER
610 {PRINT_TEST, "test"},
611 {PRINT_VLP, "vlp"},
612 #endif /* DEVELOPER */
613 {-1, NULL}
616 static const struct enum_list enum_ldap_ssl[] = {
617 #ifdef WITH_LDAP_SAMCONFIG
618 {LDAP_SSL_ON, "Yes"},
619 {LDAP_SSL_ON, "yes"},
620 {LDAP_SSL_ON, "on"},
621 {LDAP_SSL_ON, "On"},
622 #endif
623 {LDAP_SSL_OFF, "no"},
624 {LDAP_SSL_OFF, "No"},
625 {LDAP_SSL_OFF, "off"},
626 {LDAP_SSL_OFF, "Off"},
627 {LDAP_SSL_START_TLS, "start tls"},
628 {LDAP_SSL_START_TLS, "Start_tls"},
629 {-1, NULL}
632 static const struct enum_list enum_ldap_passwd_sync[] = {
633 {LDAP_PASSWD_SYNC_OFF, "no"},
634 {LDAP_PASSWD_SYNC_OFF, "No"},
635 {LDAP_PASSWD_SYNC_OFF, "off"},
636 {LDAP_PASSWD_SYNC_OFF, "Off"},
637 {LDAP_PASSWD_SYNC_ON, "Yes"},
638 {LDAP_PASSWD_SYNC_ON, "yes"},
639 {LDAP_PASSWD_SYNC_ON, "on"},
640 {LDAP_PASSWD_SYNC_ON, "On"},
641 {LDAP_PASSWD_SYNC_ONLY, "Only"},
642 {LDAP_PASSWD_SYNC_ONLY, "only"},
643 {-1, NULL}
646 /* Types of machine we can announce as. */
647 #define ANNOUNCE_AS_NT_SERVER 1
648 #define ANNOUNCE_AS_WIN95 2
649 #define ANNOUNCE_AS_WFW 3
650 #define ANNOUNCE_AS_NT_WORKSTATION 4
652 static const struct enum_list enum_announce_as[] = {
653 {ANNOUNCE_AS_NT_SERVER, "NT"},
654 {ANNOUNCE_AS_NT_SERVER, "NT Server"},
655 {ANNOUNCE_AS_NT_WORKSTATION, "NT Workstation"},
656 {ANNOUNCE_AS_WIN95, "win95"},
657 {ANNOUNCE_AS_WFW, "WfW"},
658 {-1, NULL}
661 static const struct enum_list enum_case[] = {
662 {CASE_LOWER, "lower"},
663 {CASE_UPPER, "upper"},
664 {-1, NULL}
667 static const struct enum_list enum_bool_auto[] = {
668 {False, "No"},
669 {False, "False"},
670 {False, "0"},
671 {True, "Yes"},
672 {True, "True"},
673 {True, "1"},
674 {Auto, "Auto"},
675 {-1, NULL}
678 /* Client-side offline caching policy types */
679 #define CSC_POLICY_MANUAL 0
680 #define CSC_POLICY_DOCUMENTS 1
681 #define CSC_POLICY_PROGRAMS 2
682 #define CSC_POLICY_DISABLE 3
684 static const struct enum_list enum_csc_policy[] = {
685 {CSC_POLICY_MANUAL, "manual"},
686 {CSC_POLICY_DOCUMENTS, "documents"},
687 {CSC_POLICY_PROGRAMS, "programs"},
688 {CSC_POLICY_DISABLE, "disable"},
689 {-1, NULL}
692 /* SMB signing types. */
693 static const struct enum_list enum_smb_signing_vals[] = {
694 {False, "No"},
695 {False, "False"},
696 {False, "0"},
697 {False, "Off"},
698 {False, "disabled"},
699 {True, "Yes"},
700 {True, "True"},
701 {True, "1"},
702 {True, "On"},
703 {True, "enabled"},
704 {Auto, "auto"},
705 {Required, "required"},
706 {Required, "mandatory"},
707 {Required, "force"},
708 {Required, "forced"},
709 {Required, "enforced"},
710 {-1, NULL}
715 Do you want session setups at user level security with a invalid
716 password to be rejected or allowed in as guest? WinNT rejects them
717 but it can be a pain as it means "net view" needs to use a password
719 You have 3 choices in the setting of map_to_guest:
721 "Never" means session setups with an invalid password
722 are rejected. This is the default.
724 "Bad User" means session setups with an invalid password
725 are rejected, unless the username does not exist, in which case it
726 is treated as a guest login
728 "Bad Password" means session setups with an invalid password
729 are treated as a guest login
731 Note that map_to_guest only has an effect in user or server
732 level security.
735 static const struct enum_list enum_map_to_guest[] = {
736 {NEVER_MAP_TO_GUEST, "Never"},
737 {MAP_TO_GUEST_ON_BAD_USER, "Bad User"},
738 {MAP_TO_GUEST_ON_BAD_PASSWORD, "Bad Password"},
739 {-1, NULL}
742 /* Note: We do not initialise the defaults union - it is not allowed in ANSI C
744 * The FLAG_HIDE is explicit. Paramters set this way do NOT appear in any edit
745 * screen in SWAT. This is used to exclude parameters as well as to squash all
746 * parameters that have been duplicated by pseudonyms.
748 * NOTE: To display a parameter in BASIC view set FLAG_BASIC
749 * Any parameter that does NOT have FLAG_ADVANCED will not disply at all
750 * Set FLAG_SHARE and FLAG_PRINT to specifically display parameters in
751 * respective views.
754 static struct parm_struct parm_table[] = {
755 {N_("Base Options"), P_SEP, P_SEPARATOR},
757 {"dos charset", P_STRING, P_GLOBAL, &Globals.dos_charset, handle_charset, NULL, FLAG_ADVANCED},
758 {"unix charset", P_STRING, P_GLOBAL, &Globals.unix_charset, handle_charset, NULL, FLAG_ADVANCED},
759 {"display charset", P_STRING, P_GLOBAL, &Globals.display_charset, handle_charset, NULL, FLAG_ADVANCED},
760 {"comment", P_STRING, P_LOCAL, &sDefault.comment, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED | FLAG_SHARE | FLAG_PRINT},
761 {"path", P_STRING, P_LOCAL, &sDefault.szPath, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED | FLAG_SHARE | FLAG_PRINT},
762 {"directory", P_STRING, P_LOCAL, &sDefault.szPath, NULL, NULL, FLAG_HIDE},
763 {"workgroup", P_USTRING, P_GLOBAL, &Globals.szWorkgroup, handle_workgroup, NULL, FLAG_BASIC | FLAG_ADVANCED | FLAG_WIZARD},
764 #ifdef WITH_ADS
765 {"realm", P_USTRING, P_GLOBAL, &Globals.szRealm, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED | FLAG_WIZARD},
766 #endif
767 {"afs username map", P_USTRING, P_GLOBAL, &Globals.szAfsUsernameMap, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED | FLAG_WIZARD},
768 {"netbios name", P_USTRING, P_GLOBAL, &Globals.szNetbiosName, handle_netbios_name, NULL, FLAG_BASIC | FLAG_ADVANCED | FLAG_WIZARD},
769 {"netbios aliases", P_LIST, P_GLOBAL, &Globals.szNetbiosAliases, handle_netbios_aliases, NULL, FLAG_ADVANCED},
770 {"netbios scope", P_USTRING, P_GLOBAL, &Globals.szNetbiosScope, handle_netbios_scope, NULL, FLAG_ADVANCED},
771 {"server string", P_STRING, P_GLOBAL, &Globals.szServerString, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED },
772 {"interfaces", P_LIST, P_GLOBAL, &Globals.szInterfaces, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED | FLAG_WIZARD},
773 {"bind interfaces only", P_BOOL, P_GLOBAL, &Globals.bBindInterfacesOnly, NULL, NULL, FLAG_ADVANCED | FLAG_WIZARD},
775 {N_("Security Options"), P_SEP, P_SEPARATOR},
777 {"security", P_ENUM, P_GLOBAL, &Globals.security, NULL, enum_security, FLAG_BASIC | FLAG_ADVANCED | FLAG_WIZARD},
778 {"auth methods", P_LIST, P_GLOBAL, &Globals.AuthMethods, NULL, NULL, FLAG_ADVANCED},
779 {"encrypt passwords", P_BOOL, P_GLOBAL, &Globals.bEncryptPasswords, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED | FLAG_WIZARD},
780 {"update encrypted", P_BOOL, P_GLOBAL, &Globals.bUpdateEncrypt, NULL, NULL, FLAG_ADVANCED},
781 {"client schannel", P_ENUM, P_GLOBAL, &Globals.clientSchannel, NULL, enum_bool_auto, FLAG_BASIC | FLAG_ADVANCED},
782 {"server schannel", P_ENUM, P_GLOBAL, &Globals.serverSchannel, NULL, enum_bool_auto, FLAG_BASIC | FLAG_ADVANCED},
783 {"allow trusted domains", P_BOOL, P_GLOBAL, &Globals.bAllowTrustedDomains, NULL, NULL, FLAG_ADVANCED},
784 {"hosts equiv", P_STRING, P_GLOBAL, &Globals.szHostsEquiv, NULL, NULL, FLAG_ADVANCED},
785 {"min passwd length", P_INTEGER, P_GLOBAL, &Globals.min_passwd_length, NULL, NULL, FLAG_ADVANCED},
786 {"min password length", P_INTEGER, P_GLOBAL, &Globals.min_passwd_length, NULL, NULL, FLAG_ADVANCED},
787 {"map to guest", P_ENUM, P_GLOBAL, &Globals.map_to_guest, NULL, enum_map_to_guest, FLAG_ADVANCED},
788 {"null passwords", P_BOOL, P_GLOBAL, &Globals.bNullPasswords, NULL, NULL, FLAG_ADVANCED},
789 {"obey pam restrictions", P_BOOL, P_GLOBAL, &Globals.bObeyPamRestrictions, NULL, NULL, FLAG_ADVANCED},
790 {"password server", P_STRING, P_GLOBAL, &Globals.szPasswordServer, NULL, NULL, FLAG_ADVANCED | FLAG_WIZARD},
791 {"smb passwd file", P_STRING, P_GLOBAL, &Globals.szSMBPasswdFile, NULL, NULL, FLAG_ADVANCED},
792 {"private dir", P_STRING, P_GLOBAL, &Globals.szPrivateDir, NULL, NULL, FLAG_ADVANCED},
793 {"passdb backend", P_LIST, P_GLOBAL, &Globals.szPassdbBackend, NULL, NULL, FLAG_ADVANCED | FLAG_WIZARD},
794 {"algorithmic rid base", P_INTEGER, P_GLOBAL, &Globals.AlgorithmicRidBase, NULL, NULL, FLAG_ADVANCED},
795 {"root directory", P_STRING, P_GLOBAL, &Globals.szRootdir, NULL, NULL, FLAG_ADVANCED},
796 {"root dir", P_STRING, P_GLOBAL, &Globals.szRootdir, NULL, NULL, FLAG_HIDE},
797 {"root", P_STRING, P_GLOBAL, &Globals.szRootdir, NULL, NULL, FLAG_HIDE},
798 {"guest account", P_STRING, P_GLOBAL, &Globals.szGuestaccount, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED},
800 {"pam password change", P_BOOL, P_GLOBAL, &Globals.bPamPasswordChange, NULL, NULL, FLAG_ADVANCED},
801 {"passwd program", P_STRING, P_GLOBAL, &Globals.szPasswdProgram, NULL, NULL, FLAG_ADVANCED},
802 {"passwd chat", P_STRING, P_GLOBAL, &Globals.szPasswdChat, NULL, NULL, FLAG_ADVANCED},
803 {"passwd chat debug", P_BOOL, P_GLOBAL, &Globals.bPasswdChatDebug, NULL, NULL, FLAG_ADVANCED},
804 {"username map", P_STRING, P_GLOBAL, &Globals.szUsernameMap, NULL, NULL, FLAG_ADVANCED},
805 {"password level", P_INTEGER, P_GLOBAL, &Globals.pwordlevel, NULL, NULL, FLAG_ADVANCED},
806 {"username level", P_INTEGER, P_GLOBAL, &Globals.unamelevel, NULL, NULL, FLAG_ADVANCED},
807 {"unix password sync", P_BOOL, P_GLOBAL, &Globals.bUnixPasswdSync, NULL, NULL, FLAG_ADVANCED},
808 {"restrict anonymous", P_INTEGER, P_GLOBAL, &Globals.restrict_anonymous, NULL, NULL, FLAG_ADVANCED},
809 {"lanman auth", P_BOOL, P_GLOBAL, &Globals.bLanmanAuth, NULL, NULL, FLAG_ADVANCED},
810 {"ntlm auth", P_BOOL, P_GLOBAL, &Globals.bNTLMAuth, NULL, NULL, FLAG_ADVANCED},
811 {"client NTLMv2 auth", P_BOOL, P_GLOBAL, &Globals.bClientNTLMv2Auth, NULL, NULL, FLAG_ADVANCED},
812 {"client lanman auth", P_BOOL, P_GLOBAL, &Globals.bClientLanManAuth, NULL, NULL, FLAG_ADVANCED},
813 {"client plaintext auth", P_BOOL, P_GLOBAL, &Globals.bClientPlaintextAuth, NULL, NULL, FLAG_ADVANCED},
815 {"username", P_STRING, P_LOCAL, &sDefault.szUsername, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_SHARE},
816 {"user", P_STRING, P_LOCAL, &sDefault.szUsername, NULL, NULL, FLAG_HIDE},
817 {"users", P_STRING, P_LOCAL, &sDefault.szUsername, NULL, NULL, FLAG_HIDE},
819 {"invalid users", P_LIST, P_LOCAL, &sDefault.szInvalidUsers, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_SHARE},
820 {"valid users", P_LIST, P_LOCAL, &sDefault.szValidUsers, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_SHARE},
821 {"admin users", P_LIST, P_LOCAL, &sDefault.szAdminUsers, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_SHARE},
822 {"read list", P_LIST, P_LOCAL, &sDefault.readlist, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_SHARE},
823 {"write list", P_LIST, P_LOCAL, &sDefault.writelist, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_SHARE},
824 {"printer admin", P_LIST, P_LOCAL, &sDefault.printer_admin, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_PRINT},
825 {"force user", P_STRING, P_LOCAL, &sDefault.force_user, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
826 {"force group", P_STRING, P_LOCAL, &sDefault.force_group, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
827 {"group", P_STRING, P_LOCAL, &sDefault.force_group, NULL, NULL, FLAG_ADVANCED},
829 {"read only", P_BOOL, P_LOCAL, &sDefault.bRead_only, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED | FLAG_SHARE},
830 {"write ok", P_BOOLREV, P_LOCAL, &sDefault.bRead_only, NULL, NULL, FLAG_HIDE},
831 {"writeable", P_BOOLREV, P_LOCAL, &sDefault.bRead_only, NULL, NULL, FLAG_HIDE},
832 {"writable", P_BOOLREV, P_LOCAL, &sDefault.bRead_only, NULL, NULL, FLAG_HIDE},
834 {"create mask", P_OCTAL, P_LOCAL, &sDefault.iCreate_mask, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_SHARE},
835 {"create mode", P_OCTAL, P_LOCAL, &sDefault.iCreate_mask, NULL, NULL, FLAG_HIDE},
836 {"force create mode", P_OCTAL, P_LOCAL, &sDefault.iCreate_force_mode, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_SHARE},
837 {"security mask", P_OCTAL, P_LOCAL, &sDefault.iSecurity_mask, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_SHARE},
838 {"force security mode", P_OCTAL, P_LOCAL, &sDefault.iSecurity_force_mode, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_SHARE},
839 {"directory mask", P_OCTAL, P_LOCAL, &sDefault.iDir_mask, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_SHARE},
840 {"directory mode", P_OCTAL, P_LOCAL, &sDefault.iDir_mask, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL},
841 {"force directory mode", P_OCTAL, P_LOCAL, &sDefault.iDir_force_mode, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_SHARE},
842 {"directory security mask", P_OCTAL, P_LOCAL, &sDefault.iDir_Security_mask, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_SHARE},
843 {"force directory security mode", P_OCTAL, P_LOCAL, &sDefault.iDir_Security_force_mode, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_SHARE},
844 {"inherit permissions", P_BOOL, P_LOCAL, &sDefault.bInheritPerms, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
845 {"inherit acls", P_BOOL, P_LOCAL, &sDefault.bInheritACLS, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
846 {"guest only", P_BOOL, P_LOCAL, &sDefault.bGuest_only, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
847 {"only guest", P_BOOL, P_LOCAL, &sDefault.bGuest_only, NULL, NULL, FLAG_HIDE},
849 {"guest ok", P_BOOL, P_LOCAL, &sDefault.bGuest_ok, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED | FLAG_SHARE | FLAG_PRINT},
850 {"public", P_BOOL, P_LOCAL, &sDefault.bGuest_ok, NULL, NULL, FLAG_HIDE},
852 {"only user", P_BOOL, P_LOCAL, &sDefault.bOnlyUser, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
853 {"hosts allow", P_LIST, P_LOCAL, &sDefault.szHostsallow, NULL, NULL, FLAG_GLOBAL | FLAG_BASIC | FLAG_ADVANCED | FLAG_SHARE | FLAG_PRINT},
854 {"allow hosts", P_LIST, P_LOCAL, &sDefault.szHostsallow, NULL, NULL, FLAG_HIDE},
855 {"hosts deny", P_LIST, P_LOCAL, &sDefault.szHostsdeny, NULL, NULL, FLAG_GLOBAL | FLAG_BASIC | FLAG_ADVANCED | FLAG_SHARE | FLAG_PRINT},
856 {"deny hosts", P_LIST, P_LOCAL, &sDefault.szHostsdeny, NULL, NULL, FLAG_HIDE},
857 {"preload modules", P_LIST, P_GLOBAL, &Globals.szPreloadModules, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL},
859 {N_("Logging Options"), P_SEP, P_SEPARATOR},
861 {"log level", P_STRING, P_GLOBAL, &Globals.szLogLevel, handle_debug_list, NULL, FLAG_ADVANCED},
862 {"debuglevel", P_STRING, P_GLOBAL, &Globals.szLogLevel, handle_debug_list, NULL, FLAG_HIDE},
863 {"syslog", P_INTEGER, P_GLOBAL, &Globals.syslog, NULL, NULL, FLAG_ADVANCED},
864 {"syslog only", P_BOOL, P_GLOBAL, &Globals.bSyslogOnly, NULL, NULL, FLAG_ADVANCED},
865 {"log file", P_STRING, P_GLOBAL, &Globals.szLogFile, NULL, NULL, FLAG_ADVANCED},
867 {"max log size", P_INTEGER, P_GLOBAL, &Globals.max_log_size, NULL, NULL, FLAG_ADVANCED},
868 {"timestamp logs", P_BOOL, P_GLOBAL, &Globals.bTimestampLogs, NULL, NULL, FLAG_ADVANCED},
869 {"debug timestamp", P_BOOL, P_GLOBAL, &Globals.bTimestampLogs, NULL, NULL, FLAG_ADVANCED},
870 {"debug hires timestamp", P_BOOL, P_GLOBAL, &Globals.bDebugHiresTimestamp, NULL, NULL, FLAG_ADVANCED},
871 {"debug pid", P_BOOL, P_GLOBAL, &Globals.bDebugPid, NULL, NULL, FLAG_ADVANCED},
872 {"debug uid", P_BOOL, P_GLOBAL, &Globals.bDebugUid, NULL, NULL, FLAG_ADVANCED},
874 {N_("Protocol Options"), P_SEP, P_SEPARATOR},
876 {"smb ports", P_STRING, P_GLOBAL, &Globals.smb_ports, NULL, NULL, FLAG_ADVANCED},
877 {"protocol", P_ENUM, P_GLOBAL, &Globals.maxprotocol, NULL, enum_protocol, FLAG_ADVANCED},
878 {"large readwrite", P_BOOL, P_GLOBAL, &Globals.bLargeReadwrite, NULL, NULL, FLAG_ADVANCED},
879 {"max protocol", P_ENUM, P_GLOBAL, &Globals.maxprotocol, NULL, enum_protocol, FLAG_ADVANCED},
880 {"min protocol", P_ENUM, P_GLOBAL, &Globals.minprotocol, NULL, enum_protocol, FLAG_ADVANCED},
881 {"unicode", P_BOOL, P_GLOBAL, &Globals.bUnicode, NULL, NULL, FLAG_ADVANCED},
882 {"read bmpx", P_BOOL, P_GLOBAL, &Globals.bReadbmpx, NULL, NULL, FLAG_ADVANCED},
883 {"read raw", P_BOOL, P_GLOBAL, &Globals.bReadRaw, NULL, NULL, FLAG_ADVANCED},
884 {"write raw", P_BOOL, P_GLOBAL, &Globals.bWriteRaw, NULL, NULL, FLAG_ADVANCED},
885 {"disable netbios", P_BOOL, P_GLOBAL, &Globals.bDisableNetbios, NULL, NULL, FLAG_ADVANCED},
887 {"acl compatibility", P_STRING, P_GLOBAL, &Globals.szAclCompat, handle_acl_compatibility, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
888 {"nt acl support", P_BOOL, P_LOCAL, &sDefault.bNTAclSupport, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
889 {"nt pipe support", P_BOOL, P_GLOBAL, &Globals.bNTPipeSupport, NULL, NULL, FLAG_ADVANCED},
890 {"nt status support", P_BOOL, P_GLOBAL, &Globals.bNTStatusSupport, NULL, NULL, FLAG_ADVANCED},
891 {"profile acls", P_BOOL, P_LOCAL, &sDefault.bProfileAcls, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL | FLAG_SHARE},
893 {"announce version", P_STRING, P_GLOBAL, &Globals.szAnnounceVersion, NULL, NULL, FLAG_ADVANCED},
894 {"announce as", P_ENUM, P_GLOBAL, &Globals.announce_as, NULL, enum_announce_as, FLAG_ADVANCED},
895 {"map acl inherit", P_BOOL, P_LOCAL, &sDefault.bMap_acl_inherit, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
896 {"afs share", P_BOOL, P_LOCAL, &sDefault.bAfs_Share, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
897 {"max mux", P_INTEGER, P_GLOBAL, &Globals.max_mux, NULL, NULL, FLAG_ADVANCED},
898 {"max xmit", P_INTEGER, P_GLOBAL, &Globals.max_xmit, NULL, NULL, FLAG_ADVANCED},
900 {"name resolve order", P_STRING, P_GLOBAL, &Globals.szNameResolveOrder, NULL, NULL, FLAG_ADVANCED | FLAG_WIZARD},
901 {"max ttl", P_INTEGER, P_GLOBAL, &Globals.max_ttl, NULL, NULL, FLAG_ADVANCED},
902 {"max wins ttl", P_INTEGER, P_GLOBAL, &Globals.max_wins_ttl, NULL, NULL, FLAG_ADVANCED},
903 {"min wins ttl", P_INTEGER, P_GLOBAL, &Globals.min_wins_ttl, NULL, NULL, FLAG_ADVANCED},
904 {"time server", P_BOOL, P_GLOBAL, &Globals.bTimeServer, NULL, NULL, FLAG_ADVANCED},
905 {"unix extensions", P_BOOL, P_GLOBAL, &Globals.bUnixExtensions, NULL, NULL, FLAG_ADVANCED},
906 {"use spnego", P_BOOL, P_GLOBAL, &Globals.bUseSpnego, NULL, NULL, FLAG_ADVANCED},
907 {"client signing", P_ENUM, P_GLOBAL, &Globals.client_signing, NULL, enum_smb_signing_vals, FLAG_ADVANCED},
908 {"server signing", P_ENUM, P_GLOBAL, &Globals.server_signing, NULL, enum_smb_signing_vals, FLAG_ADVANCED},
909 {"client use spnego", P_BOOL, P_GLOBAL, &Globals.bClientUseSpnego, NULL, NULL, FLAG_ADVANCED},
911 {N_("Tuning Options"), P_SEP, P_SEPARATOR},
913 {"block size", P_INTEGER, P_LOCAL, &sDefault.iBlock_size, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
914 {"change notify timeout", P_INTEGER, P_GLOBAL, &Globals.change_notify_timeout, NULL, NULL, FLAG_ADVANCED},
915 {"deadtime", P_INTEGER, P_GLOBAL, &Globals.deadtime, NULL, NULL, FLAG_ADVANCED},
916 {"getwd cache", P_BOOL, P_GLOBAL, &use_getwd_cache, NULL, NULL, FLAG_ADVANCED},
917 {"keepalive", P_INTEGER, P_GLOBAL, &keepalive, NULL, NULL, FLAG_ADVANCED},
918 {"kernel change notify", P_BOOL, P_GLOBAL, &Globals.bKernelChangeNotify, NULL, NULL, FLAG_ADVANCED},
920 {"lpq cache time", P_INTEGER, P_GLOBAL, &Globals.lpqcachetime, NULL, NULL, FLAG_ADVANCED},
921 {"max smbd processes", P_INTEGER, P_GLOBAL, &Globals.iMaxSmbdProcesses, NULL, NULL, FLAG_ADVANCED},
922 {"max connections", P_INTEGER, P_LOCAL, &sDefault.iMaxConnections, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
923 {"paranoid server security", P_BOOL, P_GLOBAL, &Globals.paranoid_server_security, NULL, NULL, FLAG_ADVANCED},
924 {"max disk size", P_INTEGER, P_GLOBAL, &Globals.maxdisksize, NULL, NULL, FLAG_ADVANCED},
925 {"max open files", P_INTEGER, P_GLOBAL, &Globals.max_open_files, NULL, NULL, FLAG_ADVANCED},
926 {"min print space", P_INTEGER, P_LOCAL, &sDefault.iMinPrintSpace, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT},
927 {"read size", P_INTEGER, P_GLOBAL, &Globals.ReadSize, NULL, NULL, FLAG_ADVANCED},
929 {"socket options", P_GSTRING, P_GLOBAL, user_socket_options, NULL, NULL, FLAG_ADVANCED},
930 {"strict allocate", P_BOOL, P_LOCAL, &sDefault.bStrictAllocate, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
931 {"strict sync", P_BOOL, P_LOCAL, &sDefault.bStrictSync, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
932 {"sync always", P_BOOL, P_LOCAL, &sDefault.bSyncAlways, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
933 {"use mmap", P_BOOL, P_GLOBAL, &Globals.bUseMmap, NULL, NULL, FLAG_ADVANCED},
934 {"use sendfile", P_BOOL, P_LOCAL, &sDefault.bUseSendfile, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
935 {"hostname lookups", P_BOOL, P_GLOBAL, &Globals.bHostnameLookups, NULL, NULL, FLAG_ADVANCED},
936 {"write cache size", P_INTEGER, P_LOCAL, &sDefault.iWriteCacheSize, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
938 {"name cache timeout", P_INTEGER, P_GLOBAL, &Globals.name_cache_timeout, NULL, NULL, FLAG_ADVANCED},
940 {N_("Printing Options"), P_SEP, P_SEPARATOR},
942 {"max reported print jobs", P_INTEGER, P_LOCAL, &sDefault.iMaxReportedPrintJobs, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT},
943 {"max print jobs", P_INTEGER, P_LOCAL, &sDefault.iMaxPrintJobs, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT},
944 {"load printers", P_BOOL, P_GLOBAL, &Globals.bLoadPrinters, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT},
945 {"printcap name", P_STRING, P_GLOBAL, &Globals.szPrintcapname, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT},
946 {"printcap", P_STRING, P_GLOBAL, &Globals.szPrintcapname, NULL, NULL, FLAG_HIDE},
947 {"printable", P_BOOL, P_LOCAL, &sDefault.bPrint_ok, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT},
948 {"print ok", P_BOOL, P_LOCAL, &sDefault.bPrint_ok, NULL, NULL, FLAG_HIDE},
949 {"printing", P_ENUM, P_LOCAL, &sDefault.iPrinting, NULL, enum_printing, FLAG_ADVANCED | FLAG_PRINT | FLAG_GLOBAL},
950 {"print command", P_STRING, P_LOCAL, &sDefault.szPrintcommand, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT | FLAG_GLOBAL},
951 {"disable spoolss", P_BOOL, P_GLOBAL, &Globals.bDisableSpoolss, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT | FLAG_GLOBAL},
952 {"lpq command", P_STRING, P_LOCAL, &sDefault.szLpqcommand, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT | FLAG_GLOBAL},
953 {"lprm command", P_STRING, P_LOCAL, &sDefault.szLprmcommand, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT | FLAG_GLOBAL},
954 {"lppause command", P_STRING, P_LOCAL, &sDefault.szLppausecommand, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT | FLAG_GLOBAL},
955 {"lpresume command", P_STRING, P_LOCAL, &sDefault.szLpresumecommand, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT | FLAG_GLOBAL},
956 {"queuepause command", P_STRING, P_LOCAL, &sDefault.szQueuepausecommand, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT | FLAG_GLOBAL},
957 {"queueresume command", P_STRING, P_LOCAL, &sDefault.szQueueresumecommand, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT | FLAG_GLOBAL},
959 {"enumports command", P_STRING, P_GLOBAL, &Globals.szEnumPortsCommand, NULL, NULL, FLAG_ADVANCED},
960 {"addprinter command", P_STRING, P_GLOBAL, &Globals.szAddPrinterCommand, NULL, NULL, FLAG_ADVANCED},
961 {"deleteprinter command", P_STRING, P_GLOBAL, &Globals.szDeletePrinterCommand, NULL, NULL, FLAG_ADVANCED},
962 {"show add printer wizard", P_BOOL, P_GLOBAL, &Globals.bMsAddPrinterWizard, NULL, NULL, FLAG_ADVANCED},
963 {"os2 driver map", P_STRING, P_GLOBAL, &Globals.szOs2DriverMap, NULL, NULL, FLAG_ADVANCED},
965 {"printer name", P_STRING, P_LOCAL, &sDefault.szPrintername, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT},
966 {"printer", P_STRING, P_LOCAL, &sDefault.szPrintername, NULL, NULL, FLAG_HIDE},
967 {"use client driver", P_BOOL, P_LOCAL, &sDefault.bUseClientDriver, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT},
968 {"default devmode", P_BOOL, P_LOCAL, &sDefault.bDefaultDevmode, NULL, NULL, FLAG_ADVANCED | FLAG_PRINT},
970 {N_("Filename Handling"), P_SEP, P_SEPARATOR},
971 {"mangling method", P_STRING, P_GLOBAL, &Globals.szManglingMethod, NULL, NULL, FLAG_ADVANCED},
972 {"mangle prefix", P_INTEGER, P_GLOBAL, &Globals.mangle_prefix, NULL, NULL, FLAG_ADVANCED},
974 {"default case", P_ENUM, P_LOCAL, &sDefault.iDefaultCase, NULL, enum_case, FLAG_ADVANCED | FLAG_SHARE},
975 {"case sensitive", P_BOOL, P_LOCAL, &sDefault.bCaseSensitive, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
976 {"casesignames", P_BOOL, P_LOCAL, &sDefault.bCaseSensitive, NULL, NULL, FLAG_HIDE},
977 {"preserve case", P_BOOL, P_LOCAL, &sDefault.bCasePreserve, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
978 {"short preserve case", P_BOOL, P_LOCAL, &sDefault.bShortCasePreserve, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
979 {"mangle case", P_BOOL, P_LOCAL, &sDefault.bCaseMangle, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
980 {"mangling char", P_CHAR, P_LOCAL, &sDefault.magic_char, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
981 {"hide dot files", P_BOOL, P_LOCAL, &sDefault.bHideDotFiles, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
982 {"hide special files", P_BOOL, P_LOCAL, &sDefault.bHideSpecialFiles, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
983 {"hide unreadable", P_BOOL, P_LOCAL, &sDefault.bHideUnReadable, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
984 {"hide unwriteable files", P_BOOL, P_LOCAL, &sDefault.bHideUnWriteableFiles, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
985 {"delete veto files", P_BOOL, P_LOCAL, &sDefault.bDeleteVetoFiles, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
986 {"veto files", P_STRING, P_LOCAL, &sDefault.szVetoFiles, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL },
987 {"hide files", P_STRING, P_LOCAL, &sDefault.szHideFiles, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL },
988 {"veto oplock files", P_STRING, P_LOCAL, &sDefault.szVetoOplockFiles, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL },
989 {"map system", P_BOOL, P_LOCAL, &sDefault.bMap_system, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
990 {"map hidden", P_BOOL, P_LOCAL, &sDefault.bMap_hidden, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
991 {"map archive", P_BOOL, P_LOCAL, &sDefault.bMap_archive, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
992 {"mangled names", P_BOOL, P_LOCAL, &sDefault.bMangledNames, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
993 {"mangled map", P_STRING, P_LOCAL, &sDefault.szMangledMap, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL | FLAG_DEPRECATED },
994 {"stat cache", P_BOOL, P_GLOBAL, &Globals.bStatCache, NULL, NULL, FLAG_ADVANCED},
996 {N_("Domain Options"), P_SEP, P_SEPARATOR},
998 {"machine password timeout", P_INTEGER, P_GLOBAL, &Globals.machine_password_timeout, NULL, NULL, FLAG_ADVANCED | FLAG_WIZARD},
1000 {N_("Logon Options"), P_SEP, P_SEPARATOR},
1002 {"add user script", P_STRING, P_GLOBAL, &Globals.szAddUserScript, NULL, NULL, FLAG_ADVANCED},
1003 {"delete user script", P_STRING, P_GLOBAL, &Globals.szDelUserScript, NULL, NULL, FLAG_ADVANCED},
1004 {"add group script", P_STRING, P_GLOBAL, &Globals.szAddGroupScript, NULL, NULL, FLAG_ADVANCED},
1005 {"delete group script", P_STRING, P_GLOBAL, &Globals.szDelGroupScript, NULL, NULL, FLAG_ADVANCED},
1006 {"add user to group script", P_STRING, P_GLOBAL, &Globals.szAddUserToGroupScript, NULL, NULL, FLAG_ADVANCED},
1007 {"delete user from group script", P_STRING, P_GLOBAL, &Globals.szDelUserFromGroupScript, NULL, NULL, FLAG_ADVANCED},
1008 {"set primary group script", P_STRING, P_GLOBAL, &Globals.szSetPrimaryGroupScript, NULL, NULL, FLAG_ADVANCED},
1009 {"add machine script", P_STRING, P_GLOBAL, &Globals.szAddMachineScript, NULL, NULL, FLAG_ADVANCED},
1010 {"shutdown script", P_STRING, P_GLOBAL, &Globals.szShutdownScript, NULL, NULL, FLAG_ADVANCED},
1011 {"abort shutdown script", P_STRING, P_GLOBAL, &Globals.szAbortShutdownScript, NULL, NULL, FLAG_ADVANCED},
1013 {"logon script", P_STRING, P_GLOBAL, &Globals.szLogonScript, NULL, NULL, FLAG_ADVANCED},
1014 {"logon path", P_STRING, P_GLOBAL, &Globals.szLogonPath, NULL, NULL, FLAG_ADVANCED},
1015 {"logon drive", P_STRING, P_GLOBAL, &Globals.szLogonDrive, NULL, NULL, FLAG_ADVANCED},
1016 {"logon home", P_STRING, P_GLOBAL, &Globals.szLogonHome, NULL, NULL, FLAG_ADVANCED},
1017 {"domain logons", P_BOOL, P_GLOBAL, &Globals.bDomainLogons, NULL, NULL, FLAG_ADVANCED},
1019 {N_("Browse Options"), P_SEP, P_SEPARATOR},
1021 {"os level", P_INTEGER, P_GLOBAL, &Globals.os_level, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED},
1022 {"lm announce", P_ENUM, P_GLOBAL, &Globals.lm_announce, NULL, enum_bool_auto, FLAG_ADVANCED},
1023 {"lm interval", P_INTEGER, P_GLOBAL, &Globals.lm_interval, NULL, NULL, FLAG_ADVANCED},
1024 {"preferred master", P_ENUM, P_GLOBAL, &Globals.bPreferredMaster, NULL, enum_bool_auto, FLAG_BASIC | FLAG_ADVANCED},
1025 {"prefered master", P_ENUM, P_GLOBAL, &Globals.bPreferredMaster, NULL, enum_bool_auto, FLAG_HIDE},
1026 {"local master", P_BOOL, P_GLOBAL, &Globals.bLocalMaster, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED},
1027 {"domain master", P_ENUM, P_GLOBAL, &Globals.bDomainMaster, NULL, enum_bool_auto, FLAG_BASIC | FLAG_ADVANCED},
1028 {"browse list", P_BOOL, P_GLOBAL, &Globals.bBrowseList, NULL, NULL, FLAG_ADVANCED},
1029 {"browseable", P_BOOL, P_LOCAL, &sDefault.bBrowseable, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED | FLAG_SHARE | FLAG_PRINT},
1030 {"browsable", P_BOOL, P_LOCAL, &sDefault.bBrowseable, NULL, NULL, FLAG_HIDE},
1031 {"enhanced browsing", P_BOOL, P_GLOBAL, &Globals.enhanced_browsing, NULL, NULL, FLAG_ADVANCED},
1033 {N_("WINS Options"), P_SEP, P_SEPARATOR},
1035 {"dns proxy", P_BOOL, P_GLOBAL, &Globals.bDNSproxy, NULL, NULL, FLAG_ADVANCED},
1036 {"wins proxy", P_BOOL, P_GLOBAL, &Globals.bWINSproxy, NULL, NULL, FLAG_ADVANCED},
1038 {"wins server", P_LIST, P_GLOBAL, &Globals.szWINSservers, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED | FLAG_WIZARD},
1039 {"wins support", P_BOOL, P_GLOBAL, &Globals.bWINSsupport, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED | FLAG_WIZARD},
1040 {"wins hook", P_STRING, P_GLOBAL, &Globals.szWINSHook, NULL, NULL, FLAG_ADVANCED},
1041 {"wins partners", P_STRING, P_GLOBAL, &Globals.szWINSPartners, NULL, NULL, FLAG_ADVANCED | FLAG_WIZARD},
1043 {N_("Locking Options"), P_SEP, P_SEPARATOR},
1045 {"blocking locks", P_BOOL, P_LOCAL, &sDefault.bBlockingLocks, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1046 {"csc policy", P_ENUM, P_LOCAL, &sDefault.iCSCPolicy, NULL, enum_csc_policy, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1047 {"fake oplocks", P_BOOL, P_LOCAL, &sDefault.bFakeOplocks, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
1048 {"kernel oplocks", P_BOOL, P_GLOBAL, &Globals.bKernelOplocks, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL},
1049 {"locking", P_BOOL, P_LOCAL, &sDefault.bLocking, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1050 {"lock spin count", P_INTEGER, P_GLOBAL, &Globals.iLockSpinCount, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL},
1051 {"lock spin time", P_INTEGER, P_GLOBAL, &Globals.iLockSpinTime, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL},
1053 {"oplocks", P_BOOL, P_LOCAL, &sDefault.bOpLocks, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1054 {"level2 oplocks", P_BOOL, P_LOCAL, &sDefault.bLevel2OpLocks, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1055 {"oplock break wait time", P_INTEGER, P_GLOBAL, &Globals.oplock_break_wait_time, NULL, NULL, FLAG_ADVANCED | FLAG_GLOBAL},
1056 {"oplock contention limit", P_INTEGER, P_LOCAL, &sDefault.iOplockContentionLimit, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1057 {"posix locking", P_BOOL, P_LOCAL, &sDefault.bPosixLocking, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1058 {"strict locking", P_BOOL, P_LOCAL, &sDefault.bStrictLocking, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1059 {"share modes", P_BOOL, P_LOCAL, &sDefault.bShareModes, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1061 {N_("Ldap Options"), P_SEP, P_SEPARATOR},
1063 #ifdef WITH_LDAP_SAMCONFIG
1064 {"ldap server", P_STRING, P_GLOBAL, &Globals.szLdapServer, NULL, NULL, FLAG_ADVANCED},
1065 {"ldap port", P_INTEGER, P_GLOBAL, &Globals.ldap_port, NULL, NULL, FLAG_ADVANCED},
1066 #endif
1067 {"ldap suffix", P_STRING, P_GLOBAL, &Globals.szLdapSuffix, handle_ldap_suffix, NULL, FLAG_ADVANCED},
1068 {"ldap machine suffix", P_STRING, P_GLOBAL, &Globals.szLdapMachineSuffix, handle_ldap_sub_suffix, NULL, FLAG_ADVANCED},
1069 {"ldap user suffix", P_STRING, P_GLOBAL, &Globals.szLdapUserSuffix, handle_ldap_sub_suffix, NULL, FLAG_ADVANCED},
1070 {"ldap group suffix", P_STRING, P_GLOBAL, &Globals.szLdapGroupSuffix, handle_ldap_sub_suffix, NULL, FLAG_ADVANCED},
1071 {"ldap idmap suffix", P_STRING, P_GLOBAL, &Globals.szLdapIdmapSuffix, handle_ldap_sub_suffix, NULL, FLAG_ADVANCED},
1072 {"ldap filter", P_STRING, P_GLOBAL, &Globals.szLdapFilter, NULL, NULL, FLAG_ADVANCED},
1073 {"ldap admin dn", P_STRING, P_GLOBAL, &Globals.szLdapAdminDn, NULL, NULL, FLAG_ADVANCED},
1074 {"ldap ssl", P_ENUM, P_GLOBAL, &Globals.ldap_ssl, NULL, enum_ldap_ssl, FLAG_ADVANCED},
1075 {"ldap passwd sync", P_ENUM, P_GLOBAL, &Globals.ldap_passwd_sync, NULL, enum_ldap_passwd_sync, FLAG_ADVANCED},
1076 {"ldap delete dn", P_BOOL, P_GLOBAL, &Globals.ldap_delete_dn, NULL, NULL, FLAG_ADVANCED},
1078 {N_("Miscellaneous Options"), P_SEP, P_SEPARATOR},
1079 {"add share command", P_STRING, P_GLOBAL, &Globals.szAddShareCommand, NULL, NULL, FLAG_ADVANCED},
1080 {"change share command", P_STRING, P_GLOBAL, &Globals.szChangeShareCommand, NULL, NULL, FLAG_ADVANCED},
1081 {"delete share command", P_STRING, P_GLOBAL, &Globals.szDeleteShareCommand, NULL, NULL, FLAG_ADVANCED},
1083 {"config file", P_STRING, P_GLOBAL, &Globals.szConfigFile, NULL, NULL, FLAG_HIDE},
1084 {"preload", P_STRING, P_GLOBAL, &Globals.szAutoServices, NULL, NULL, FLAG_ADVANCED},
1085 {"auto services", P_STRING, P_GLOBAL, &Globals.szAutoServices, NULL, NULL, FLAG_ADVANCED},
1086 {"lock directory", P_STRING, P_GLOBAL, &Globals.szLockDir, NULL, NULL, FLAG_ADVANCED},
1087 {"lock dir", P_STRING, P_GLOBAL, &Globals.szLockDir, NULL, NULL, FLAG_HIDE},
1088 {"pid directory", P_STRING, P_GLOBAL, &Globals.szPidDir, NULL, NULL, FLAG_ADVANCED},
1089 #ifdef WITH_UTMP
1090 {"utmp directory", P_STRING, P_GLOBAL, &Globals.szUtmpDir, NULL, NULL, FLAG_ADVANCED},
1091 {"wtmp directory", P_STRING, P_GLOBAL, &Globals.szWtmpDir, NULL, NULL, FLAG_ADVANCED},
1092 {"utmp", P_BOOL, P_GLOBAL, &Globals.bUtmp, NULL, NULL, FLAG_ADVANCED},
1093 #endif
1095 {"default service", P_STRING, P_GLOBAL, &Globals.szDefaultService, NULL, NULL, FLAG_ADVANCED},
1096 {"default", P_STRING, P_GLOBAL, &Globals.szDefaultService, NULL, NULL, FLAG_ADVANCED},
1097 {"message command", P_STRING, P_GLOBAL, &Globals.szMsgCommand, NULL, NULL, FLAG_ADVANCED},
1098 {"dfree command", P_STRING, P_GLOBAL, &Globals.szDfree, NULL, NULL, FLAG_ADVANCED},
1099 {"get quota command", P_STRING, P_GLOBAL, &Globals.szGetQuota, NULL, NULL, FLAG_ADVANCED},
1100 {"set quota command", P_STRING, P_GLOBAL, &Globals.szSetQuota, NULL, NULL, FLAG_ADVANCED},
1101 {"remote announce", P_STRING, P_GLOBAL, &Globals.szRemoteAnnounce, NULL, NULL, FLAG_ADVANCED},
1102 {"remote browse sync", P_STRING, P_GLOBAL, &Globals.szRemoteBrowseSync, NULL, NULL, FLAG_ADVANCED},
1103 {"socket address", P_STRING, P_GLOBAL, &Globals.szSocketAddress, NULL, NULL, FLAG_ADVANCED},
1104 {"homedir map", P_STRING, P_GLOBAL, &Globals.szNISHomeMapName, NULL, NULL, FLAG_ADVANCED},
1105 {"time offset", P_INTEGER, P_GLOBAL, &extra_time_offset, NULL, NULL, FLAG_ADVANCED},
1106 {"NIS homedir", P_BOOL, P_GLOBAL, &Globals.bNISHomeMap, NULL, NULL, FLAG_ADVANCED},
1107 {"-valid", P_BOOL, P_LOCAL, &sDefault.valid, NULL, NULL, FLAG_HIDE},
1109 {"copy", P_STRING, P_LOCAL, &sDefault.szCopy, handle_copy, NULL, FLAG_HIDE},
1110 {"include", P_STRING, P_LOCAL, &sDefault.szInclude, handle_include, NULL, FLAG_HIDE},
1111 {"exec", P_STRING, P_LOCAL, &sDefault.szPreExec, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_PRINT},
1112 {"preexec", P_STRING, P_LOCAL, &sDefault.szPreExec, NULL, NULL, FLAG_ADVANCED},
1114 {"preexec close", P_BOOL, P_LOCAL, &sDefault.bPreexecClose, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
1115 {"postexec", P_STRING, P_LOCAL, &sDefault.szPostExec, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_PRINT},
1116 {"root preexec", P_STRING, P_LOCAL, &sDefault.szRootPreExec, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_PRINT},
1117 {"root preexec close", P_BOOL, P_LOCAL, &sDefault.bRootpreexecClose, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
1118 {"root postexec", P_STRING, P_LOCAL, &sDefault.szRootPostExec, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_PRINT},
1119 {"available", P_BOOL, P_LOCAL, &sDefault.bAvailable, NULL, NULL, FLAG_BASIC | FLAG_ADVANCED | FLAG_SHARE | FLAG_PRINT},
1120 {"volume", P_STRING, P_LOCAL, &sDefault.volume, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE },
1121 {"fstype", P_STRING, P_LOCAL, &sDefault.fstype, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
1122 {"set directory", P_BOOLREV, P_LOCAL, &sDefault.bNo_set_dir, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
1123 {"source environment", P_STRING, P_GLOBAL, &Globals.szSourceEnv, handle_source_env, NULL, FLAG_ADVANCED},
1124 {"wide links", P_BOOL, P_LOCAL, &sDefault.bWidelinks, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1125 {"follow symlinks", P_BOOL, P_LOCAL, &sDefault.bSymlinks, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1126 {"dont descend", P_STRING, P_LOCAL, &sDefault.szDontdescend, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
1127 {"magic script", P_STRING, P_LOCAL, &sDefault.szMagicScript, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
1128 {"magic output", P_STRING, P_LOCAL, &sDefault.szMagicOutput, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
1129 {"delete readonly", P_BOOL, P_LOCAL, &sDefault.bDeleteReadonly, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1130 {"dos filemode", P_BOOL, P_LOCAL, &sDefault.bDosFilemode, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1131 {"dos filetimes", P_BOOL, P_LOCAL, &sDefault.bDosFiletimes, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1132 {"dos filetime resolution", P_BOOL, P_LOCAL, &sDefault.bDosFiletimeResolution, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1134 {"fake directory create times", P_BOOL, P_LOCAL, &sDefault.bFakeDirCreateTimes, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE | FLAG_GLOBAL},
1135 {"panic action", P_STRING, P_GLOBAL, &Globals.szPanicAction, NULL, NULL, FLAG_ADVANCED},
1136 {"hide local users", P_BOOL, P_GLOBAL, &Globals.bHideLocalUsers, NULL, NULL, FLAG_ADVANCED},
1138 {N_("VFS module options"), P_SEP, P_SEPARATOR},
1140 {"vfs objects", P_LIST, P_LOCAL, &sDefault.szVfsObjects, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
1141 {"vfs object", P_LIST, P_LOCAL, &sDefault.szVfsObjects, NULL, NULL, FLAG_HIDE},
1144 {"msdfs root", P_BOOL, P_LOCAL, &sDefault.bMSDfsRoot, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
1145 {"msdfs proxy", P_STRING, P_LOCAL, &sDefault.szMSDfsProxy, NULL, NULL, FLAG_ADVANCED | FLAG_SHARE},
1146 {"host msdfs", P_BOOL, P_GLOBAL, &Globals.bHostMSDfs, NULL, NULL, FLAG_ADVANCED},
1148 {N_("Winbind options"), P_SEP, P_SEPARATOR},
1150 {"enable rid algorithm", P_BOOL, P_GLOBAL, &Globals.bEnableRidAlgorithm, NULL, NULL, FLAG_DEPRECATED},
1151 {"idmap backend", P_STRING, P_GLOBAL, &Globals.szIdmapBackend, NULL, NULL, FLAG_ADVANCED},
1152 {"idmap uid", P_STRING, P_GLOBAL, &Globals.szIdmapUID, handle_idmap_uid, NULL, FLAG_ADVANCED},
1153 {"winbind uid", P_STRING, P_GLOBAL, &Globals.szIdmapUID, handle_idmap_uid, NULL, FLAG_ADVANCED},
1154 {"idmap gid", P_STRING, P_GLOBAL, &Globals.szIdmapGID, handle_idmap_gid, NULL, FLAG_ADVANCED},
1155 {"winbind gid", P_STRING, P_GLOBAL, &Globals.szIdmapGID, handle_idmap_gid, NULL, FLAG_ADVANCED},
1156 {"template primary group", P_STRING, P_GLOBAL, &Globals.szTemplatePrimaryGroup, NULL, NULL, FLAG_ADVANCED},
1157 {"template homedir", P_STRING, P_GLOBAL, &Globals.szTemplateHomedir, NULL, NULL, FLAG_ADVANCED},
1158 {"template shell", P_STRING, P_GLOBAL, &Globals.szTemplateShell, NULL, NULL, FLAG_ADVANCED},
1159 {"winbind separator", P_STRING, P_GLOBAL, &Globals.szWinbindSeparator, NULL, NULL, FLAG_ADVANCED},
1160 {"winbind cache time", P_INTEGER, P_GLOBAL, &Globals.winbind_cache_time, NULL, NULL, FLAG_ADVANCED},
1161 {"winbind enable local accounts", P_BOOL, P_GLOBAL, &Globals.bWinbindEnableLocalAccounts, NULL, NULL, FLAG_ADVANCED},
1162 {"winbind enum users", P_BOOL, P_GLOBAL, &Globals.bWinbindEnumUsers, NULL, NULL, FLAG_ADVANCED},
1163 {"winbind enum groups", P_BOOL, P_GLOBAL, &Globals.bWinbindEnumGroups, NULL, NULL, FLAG_ADVANCED},
1164 {"winbind use default domain", P_BOOL, P_GLOBAL, &Globals.bWinbindUseDefaultDomain, NULL, NULL, FLAG_ADVANCED},
1165 {"winbind trusted domains only", P_BOOL, P_GLOBAL, &Globals.bWinbindTrustedDomainsOnly, NULL, NULL, FLAG_ADVANCED},
1167 {NULL, P_BOOL, P_NONE, NULL, NULL, NULL, 0}
1170 /***************************************************************************
1171 Initialise the sDefault parameter structure for the printer values.
1172 ***************************************************************************/
1174 static void init_printer_values(void)
1176 /* choose defaults depending on the type of printing */
1177 switch (sDefault.iPrinting) {
1178 case PRINT_BSD:
1179 case PRINT_AIX:
1180 case PRINT_LPRNT:
1181 case PRINT_LPROS2:
1182 string_set(&sDefault.szLpqcommand, "lpq -P'%p'");
1183 string_set(&sDefault.szLprmcommand, "lprm -P'%p' %j");
1184 string_set(&sDefault.szPrintcommand,
1185 "lpr -r -P'%p' %s");
1186 break;
1188 case PRINT_LPRNG:
1189 case PRINT_PLP:
1190 string_set(&sDefault.szLpqcommand, "lpq -P'%p'");
1191 string_set(&sDefault.szLprmcommand, "lprm -P'%p' %j");
1192 string_set(&sDefault.szPrintcommand,
1193 "lpr -r -P'%p' %s");
1194 string_set(&sDefault.szQueuepausecommand,
1195 "lpc stop '%p'");
1196 string_set(&sDefault.szQueueresumecommand,
1197 "lpc start '%p'");
1198 string_set(&sDefault.szLppausecommand,
1199 "lpc hold '%p' %j");
1200 string_set(&sDefault.szLpresumecommand,
1201 "lpc release '%p' %j");
1202 break;
1204 case PRINT_CUPS:
1205 #ifdef HAVE_CUPS
1206 string_set(&sDefault.szLpqcommand, "");
1207 string_set(&sDefault.szLprmcommand, "");
1208 string_set(&sDefault.szPrintcommand, "");
1209 string_set(&sDefault.szLppausecommand, "");
1210 string_set(&sDefault.szLpresumecommand, "");
1211 string_set(&sDefault.szQueuepausecommand, "");
1212 string_set(&sDefault.szQueueresumecommand, "");
1214 string_set(&Globals.szPrintcapname, "cups");
1215 #else
1216 string_set(&sDefault.szLpqcommand,
1217 "/usr/bin/lpstat -o '%p'");
1218 string_set(&sDefault.szLprmcommand,
1219 "/usr/bin/cancel '%p-%j'");
1220 string_set(&sDefault.szPrintcommand,
1221 "/usr/bin/lp -d '%p' %s; rm %s");
1222 string_set(&sDefault.szLppausecommand,
1223 "lp -i '%p-%j' -H hold");
1224 string_set(&sDefault.szLpresumecommand,
1225 "lp -i '%p-%j' -H resume");
1226 string_set(&sDefault.szQueuepausecommand,
1227 "/usr/bin/disable '%p'");
1228 string_set(&sDefault.szQueueresumecommand,
1229 "/usr/bin/enable '%p'");
1230 string_set(&Globals.szPrintcapname, "lpstat");
1231 #endif /* HAVE_CUPS */
1232 break;
1234 case PRINT_SYSV:
1235 case PRINT_HPUX:
1236 string_set(&sDefault.szLpqcommand, "lpstat -o%p");
1237 string_set(&sDefault.szLprmcommand, "cancel %p-%j");
1238 string_set(&sDefault.szPrintcommand,
1239 "lp -c -d%p %s; rm %s");
1240 string_set(&sDefault.szQueuepausecommand,
1241 "disable %p");
1242 string_set(&sDefault.szQueueresumecommand,
1243 "enable %p");
1244 #ifndef HPUX
1245 string_set(&sDefault.szLppausecommand,
1246 "lp -i %p-%j -H hold");
1247 string_set(&sDefault.szLpresumecommand,
1248 "lp -i %p-%j -H resume");
1249 #endif /* HPUX */
1250 break;
1252 case PRINT_QNX:
1253 string_set(&sDefault.szLpqcommand, "lpq -P%p");
1254 string_set(&sDefault.szLprmcommand, "lprm -P%p %j");
1255 string_set(&sDefault.szPrintcommand, "lp -r -P%p %s");
1256 break;
1258 #ifdef DEVELOPER
1259 case PRINT_TEST:
1260 case PRINT_VLP:
1261 string_set(&sDefault.szPrintcommand, "vlp print %p %s");
1262 string_set(&sDefault.szLpqcommand, "vlp lpq %p");
1263 string_set(&sDefault.szLprmcommand, "vlp lprm %p %j");
1264 string_set(&sDefault.szLppausecommand, "vlp lppause %p %j");
1265 string_set(&sDefault.szLpresumecommand, "vlp lpresum %p %j");
1266 string_set(&sDefault.szQueuepausecommand, "vlp queuepause %p");
1267 string_set(&sDefault.szQueueresumecommand, "vlp queueresume %p");
1268 break;
1269 #endif /* DEVELOPER */
1274 /***************************************************************************
1275 Initialise the global parameter structure.
1276 ***************************************************************************/
1278 static void init_globals(void)
1280 static BOOL done_init = False;
1281 pstring s;
1283 if (!done_init) {
1284 int i;
1285 memset((void *)&Globals, '\0', sizeof(Globals));
1287 for (i = 0; parm_table[i].label; i++)
1288 if ((parm_table[i].type == P_STRING ||
1289 parm_table[i].type == P_USTRING) &&
1290 parm_table[i].ptr)
1291 string_set(parm_table[i].ptr, "");
1293 string_set(&sDefault.fstype, FSTYPE_STRING);
1295 init_printer_values();
1297 done_init = True;
1301 DEBUG(3, ("Initialising global parameters\n"));
1303 string_set(&Globals.szSMBPasswdFile, dyn_SMB_PASSWD_FILE);
1304 string_set(&Globals.szPrivateDir, dyn_PRIVATE_DIR);
1306 /* use the new 'hash2' method by default, with a prefix of 1 */
1307 string_set(&Globals.szManglingMethod, "hash2");
1308 Globals.mangle_prefix = 1;
1310 string_set(&Globals.szGuestaccount, GUEST_ACCOUNT);
1312 /* using UTF8 by default allows us to support all chars */
1313 string_set(&Globals.unix_charset, DEFAULT_UNIX_CHARSET);
1315 #if defined(HAVE_NL_LANGINFO) && defined(CODESET)
1316 /* If the system supports nl_langinfo(), try to grab the value
1317 from the user's locale */
1318 string_set(&Globals.display_charset, "LOCALE");
1319 #else
1320 string_set(&Globals.display_charset, DEFAULT_DISPLAY_CHARSET);
1321 #endif
1323 /* Use codepage 850 as a default for the dos character set */
1324 string_set(&Globals.dos_charset, DEFAULT_DOS_CHARSET);
1327 * Allow the default PASSWD_CHAT to be overridden in local.h.
1329 string_set(&Globals.szPasswdChat, DEFAULT_PASSWD_CHAT);
1331 set_global_myname(myhostname());
1332 string_set(&Globals.szNetbiosName,global_myname());
1334 set_global_myworkgroup(WORKGROUP);
1335 string_set(&Globals.szWorkgroup, lp_workgroup());
1337 string_set(&Globals.szPasswdProgram, "");
1338 string_set(&Globals.szPrintcapname, PRINTCAP_NAME);
1339 string_set(&Globals.szPidDir, dyn_PIDDIR);
1340 string_set(&Globals.szLockDir, dyn_LOCKDIR);
1341 string_set(&Globals.szSocketAddress, "0.0.0.0");
1342 pstrcpy(s, "Samba ");
1343 pstrcat(s, SAMBA_VERSION_STRING);
1344 string_set(&Globals.szServerString, s);
1345 slprintf(s, sizeof(s) - 1, "%d.%d", DEFAULT_MAJOR_VERSION,
1346 DEFAULT_MINOR_VERSION);
1347 string_set(&Globals.szAnnounceVersion, s);
1349 pstrcpy(user_socket_options, DEFAULT_SOCKET_OPTIONS);
1351 string_set(&Globals.szLogonDrive, "");
1352 /* %N is the NIS auto.home server if -DAUTOHOME is used, else same as %L */
1353 string_set(&Globals.szLogonHome, "\\\\%N\\%U");
1354 string_set(&Globals.szLogonPath, "\\\\%N\\%U\\profile");
1356 string_set(&Globals.szNameResolveOrder, "lmhosts wins host bcast");
1357 string_set(&Globals.szPasswordServer, "*");
1359 Globals.AlgorithmicRidBase = BASE_RID;
1361 Globals.bLoadPrinters = True;
1362 /* Was 65535 (0xFFFF). 0x4101 matches W2K and causes major speed improvements... */
1363 /* Discovered by 2 days of pain by Don McCall @ HP :-). */
1364 Globals.max_xmit = 0x4104;
1365 Globals.max_mux = 50; /* This is *needed* for profile support. */
1366 Globals.lpqcachetime = 10;
1367 Globals.bDisableSpoolss = False;
1368 Globals.iMaxSmbdProcesses = 0;/* no limit specified */
1369 Globals.iTotalPrintJobs = 0; /* no limit specified */
1370 Globals.pwordlevel = 0;
1371 Globals.unamelevel = 0;
1372 Globals.deadtime = 0;
1373 Globals.bLargeReadwrite = True;
1374 Globals.max_log_size = 5000;
1375 Globals.max_open_files = MAX_OPEN_FILES;
1376 Globals.maxprotocol = PROTOCOL_NT1;
1377 Globals.minprotocol = PROTOCOL_CORE;
1378 Globals.security = SEC_USER;
1379 Globals.paranoid_server_security = True;
1380 Globals.bEncryptPasswords = True;
1381 Globals.bUpdateEncrypt = False;
1382 Globals.clientSchannel = Auto;
1383 Globals.serverSchannel = Auto;
1384 Globals.bReadRaw = True;
1385 Globals.bWriteRaw = True;
1386 Globals.bReadPrediction = False;
1387 Globals.bReadbmpx = False;
1388 Globals.bNullPasswords = False;
1389 Globals.bObeyPamRestrictions = False;
1390 Globals.syslog = 1;
1391 Globals.bSyslogOnly = False;
1392 Globals.bTimestampLogs = True;
1393 string_set(&Globals.szLogLevel, "0");
1394 Globals.bDebugHiresTimestamp = False;
1395 Globals.bDebugPid = False;
1396 Globals.bDebugUid = False;
1397 Globals.max_ttl = 60 * 60 * 24 * 3; /* 3 days default. */
1398 Globals.max_wins_ttl = 60 * 60 * 24 * 6; /* 6 days default. */
1399 Globals.min_wins_ttl = 60 * 60 * 6; /* 6 hours default. */
1400 Globals.machine_password_timeout = 60 * 60 * 24 * 7; /* 7 days default. */
1401 Globals.change_notify_timeout = 60; /* 1 minute default. */
1402 Globals.bKernelChangeNotify = True; /* On if we have it. */
1403 Globals.ReadSize = 16 * 1024;
1404 Globals.lm_announce = 2; /* = Auto: send only if LM clients found */
1405 Globals.lm_interval = 60;
1406 Globals.announce_as = ANNOUNCE_AS_NT_SERVER;
1407 #if (defined(HAVE_NETGROUP) && defined(WITH_AUTOMOUNT))
1408 Globals.bNISHomeMap = False;
1409 #ifdef WITH_NISPLUS_HOME
1410 string_set(&Globals.szNISHomeMapName, "auto_home.org_dir");
1411 #else
1412 string_set(&Globals.szNISHomeMapName, "auto.home");
1413 #endif
1414 #endif
1415 Globals.bTimeServer = False;
1416 Globals.bBindInterfacesOnly = False;
1417 Globals.bUnixPasswdSync = False;
1418 Globals.bPamPasswordChange = False;
1419 Globals.bPasswdChatDebug = False;
1420 Globals.bUnicode = True; /* Do unicode on the wire by default */
1421 Globals.bNTPipeSupport = True; /* Do NT pipes by default. */
1422 Globals.bNTStatusSupport = True; /* Use NT status by default. */
1423 Globals.bStatCache = True; /* use stat cache by default */
1424 Globals.restrict_anonymous = 0;
1425 Globals.bClientLanManAuth = True; /* Do use the LanMan hash if it is available */
1426 Globals.bClientPlaintextAuth = True; /* Do use a plaintext password if is requested by the server */
1427 Globals.bLanmanAuth = True; /* Do use the LanMan hash if it is available */
1428 Globals.bNTLMAuth = True; /* Do use NTLMv1 if it is available (otherwise NTLMv2) */
1429 Globals.bClientNTLMv2Auth = False; /* Client should not use NTLMv2, as we can't tell that the server supports it. */
1430 /* Note, that we will use NTLM2 session security (which is different), if it is available */
1432 Globals.map_to_guest = 0; /* By Default, "Never" */
1433 Globals.min_passwd_length = MINPASSWDLENGTH; /* By Default, 5. */
1434 Globals.oplock_break_wait_time = 0; /* By Default, 0 msecs. */
1435 Globals.enhanced_browsing = True;
1436 Globals.iLockSpinCount = 3; /* Try 3 times. */
1437 Globals.iLockSpinTime = 10; /* usec. */
1438 #ifdef MMAP_BLACKLIST
1439 Globals.bUseMmap = False;
1440 #else
1441 Globals.bUseMmap = True;
1442 #endif
1443 Globals.bUnixExtensions = True;
1445 /* hostname lookups can be very expensive and are broken on
1446 a large number of sites (tridge) */
1447 Globals.bHostnameLookups = False;
1449 #ifdef WITH_LDAP_SAMCONFIG
1450 string_set(&Globals.szLdapServer, "localhost");
1451 Globals.ldap_port = 636;
1452 Globals.szPassdbBackend = str_list_make("ldapsam_compat", NULL);
1453 #else
1454 Globals.szPassdbBackend = str_list_make("smbpasswd", NULL);
1455 #endif /* WITH_LDAP_SAMCONFIG */
1457 string_set(&Globals.szLdapSuffix, "");
1458 string_set(&Globals.szLdapFilter, "(uid=%u)");
1459 string_set(&Globals.szLdapMachineSuffix, "");
1460 string_set(&Globals.szLdapUserSuffix, "");
1461 string_set(&Globals.szLdapGroupSuffix, "");
1462 string_set(&Globals.szLdapIdmapSuffix, "");
1464 string_set(&Globals.szLdapAdminDn, "");
1465 Globals.ldap_ssl = LDAP_SSL_ON;
1466 Globals.ldap_passwd_sync = LDAP_PASSWD_SYNC_OFF;
1467 Globals.ldap_delete_dn = False;
1469 /* these parameters are set to defaults that are more appropriate
1470 for the increasing samba install base:
1472 as a member of the workgroup, that will possibly become a
1473 _local_ master browser (lm = True). this is opposed to a forced
1474 local master browser startup (pm = True).
1476 doesn't provide WINS server service by default (wsupp = False),
1477 and doesn't provide domain master browser services by default, either.
1481 Globals.bMsAddPrinterWizard = True;
1482 Globals.bPreferredMaster = Auto; /* depending on bDomainMaster */
1483 Globals.os_level = 20;
1484 Globals.bLocalMaster = True;
1485 Globals.bDomainMaster = Auto; /* depending on bDomainLogons */
1486 Globals.bDomainLogons = False;
1487 Globals.bBrowseList = True;
1488 Globals.bWINSsupport = False;
1489 Globals.bWINSproxy = False;
1491 Globals.bDNSproxy = True;
1493 /* this just means to use them if they exist */
1494 Globals.bKernelOplocks = True;
1496 Globals.bAllowTrustedDomains = True;
1498 string_set(&Globals.szTemplateShell, "/bin/false");
1499 string_set(&Globals.szTemplateHomedir, "/home/%D/%U");
1500 string_set(&Globals.szTemplatePrimaryGroup, "nobody");
1501 string_set(&Globals.szWinbindSeparator, "\\");
1502 string_set(&Globals.szAclCompat, "");
1504 Globals.winbind_cache_time = 300; /* 5 minutes */
1505 Globals.bWinbindEnableLocalAccounts = True;
1506 Globals.bWinbindEnumUsers = True;
1507 Globals.bWinbindEnumGroups = True;
1508 Globals.bWinbindUseDefaultDomain = False;
1509 Globals.bWinbindTrustedDomainsOnly = False;
1511 Globals.bEnableRidAlgorithm = True;
1513 Globals.name_cache_timeout = 660; /* In seconds */
1515 Globals.bUseSpnego = True;
1516 Globals.bClientUseSpnego = True;
1518 Globals.client_signing = Auto;
1519 Globals.server_signing = False;
1521 string_set(&Globals.smb_ports, SMB_PORTS);
1524 static TALLOC_CTX *lp_talloc;
1526 /******************************************************************* a
1527 Free up temporary memory - called from the main loop.
1528 ********************************************************************/
1530 void lp_talloc_free(void)
1532 if (!lp_talloc)
1533 return;
1534 talloc_destroy(lp_talloc);
1535 lp_talloc = NULL;
1538 /*******************************************************************
1539 Convenience routine to grab string parameters into temporary memory
1540 and run standard_sub_basic on them. The buffers can be written to by
1541 callers without affecting the source string.
1542 ********************************************************************/
1544 static char *lp_string(const char *s)
1546 char *ret, *tmpstr;
1548 /* The follow debug is useful for tracking down memory problems
1549 especially if you have an inner loop that is calling a lp_*()
1550 function that returns a string. Perhaps this debug should be
1551 present all the time? */
1553 #if 0
1554 DEBUG(10, ("lp_string(%s)\n", s));
1555 #endif
1557 if (!lp_talloc)
1558 lp_talloc = talloc_init("lp_talloc");
1560 tmpstr = alloc_sub_basic(current_user_info.smb_name, s);
1561 if (trim_char(tmpstr, '\"', '\"')) {
1562 if (strchr(tmpstr,'\"') != NULL) {
1563 SAFE_FREE(tmpstr);
1564 tmpstr = alloc_sub_basic(current_user_info.smb_name,s);
1567 ret = talloc_strdup(lp_talloc, tmpstr);
1568 SAFE_FREE(tmpstr);
1570 return (ret);
1574 In this section all the functions that are used to access the
1575 parameters from the rest of the program are defined
1578 #define FN_GLOBAL_STRING(fn_name,ptr) \
1579 char *fn_name(void) {return(lp_string(*(char **)(ptr) ? *(char **)(ptr) : ""));}
1580 #define FN_GLOBAL_CONST_STRING(fn_name,ptr) \
1581 const char *fn_name(void) {return(*(const char **)(ptr) ? *(const char **)(ptr) : "");}
1582 #define FN_GLOBAL_LIST(fn_name,ptr) \
1583 const char **fn_name(void) {return(*(const char ***)(ptr));}
1584 #define FN_GLOBAL_BOOL(fn_name,ptr) \
1585 BOOL fn_name(void) {return(*(BOOL *)(ptr));}
1586 #define FN_GLOBAL_CHAR(fn_name,ptr) \
1587 char fn_name(void) {return(*(char *)(ptr));}
1588 #define FN_GLOBAL_INTEGER(fn_name,ptr) \
1589 int fn_name(void) {return(*(int *)(ptr));}
1591 #define FN_LOCAL_STRING(fn_name,val) \
1592 char *fn_name(int i) {return(lp_string((LP_SNUM_OK(i) && ServicePtrs[(i)]->val) ? ServicePtrs[(i)]->val : sDefault.val));}
1593 #define FN_LOCAL_CONST_STRING(fn_name,val) \
1594 const char *fn_name(int i) {return (const char *)((LP_SNUM_OK(i) && ServicePtrs[(i)]->val) ? ServicePtrs[(i)]->val : sDefault.val);}
1595 #define FN_LOCAL_LIST(fn_name,val) \
1596 const char **fn_name(int i) {return(const char **)(LP_SNUM_OK(i)? ServicePtrs[(i)]->val : sDefault.val);}
1597 #define FN_LOCAL_BOOL(fn_name,val) \
1598 BOOL fn_name(int i) {return(LP_SNUM_OK(i)? ServicePtrs[(i)]->val : sDefault.val);}
1599 #define FN_LOCAL_CHAR(fn_name,val) \
1600 char fn_name(int i) {return(LP_SNUM_OK(i)? ServicePtrs[(i)]->val : sDefault.val);}
1601 #define FN_LOCAL_INTEGER(fn_name,val) \
1602 int fn_name(int i) {return(LP_SNUM_OK(i)? ServicePtrs[(i)]->val : sDefault.val);}
1604 FN_GLOBAL_STRING(lp_smb_ports, &Globals.smb_ports)
1605 FN_GLOBAL_STRING(lp_dos_charset, &Globals.dos_charset)
1606 FN_GLOBAL_STRING(lp_unix_charset, &Globals.unix_charset)
1607 FN_GLOBAL_STRING(lp_display_charset, &Globals.display_charset)
1608 FN_GLOBAL_STRING(lp_logfile, &Globals.szLogFile)
1609 FN_GLOBAL_STRING(lp_configfile, &Globals.szConfigFile)
1610 FN_GLOBAL_STRING(lp_smb_passwd_file, &Globals.szSMBPasswdFile)
1611 FN_GLOBAL_STRING(lp_private_dir, &Globals.szPrivateDir)
1612 FN_GLOBAL_STRING(lp_serverstring, &Globals.szServerString)
1613 FN_GLOBAL_STRING(lp_printcapname, &Globals.szPrintcapname)
1614 FN_GLOBAL_STRING(lp_enumports_cmd, &Globals.szEnumPortsCommand)
1615 FN_GLOBAL_STRING(lp_addprinter_cmd, &Globals.szAddPrinterCommand)
1616 FN_GLOBAL_STRING(lp_deleteprinter_cmd, &Globals.szDeletePrinterCommand)
1617 FN_GLOBAL_STRING(lp_os2_driver_map, &Globals.szOs2DriverMap)
1618 FN_GLOBAL_STRING(lp_lockdir, &Globals.szLockDir)
1619 FN_GLOBAL_STRING(lp_piddir, &Globals.szPidDir)
1620 FN_GLOBAL_STRING(lp_mangling_method, &Globals.szManglingMethod)
1621 FN_GLOBAL_INTEGER(lp_mangle_prefix, &Globals.mangle_prefix)
1622 FN_GLOBAL_STRING(lp_utmpdir, &Globals.szUtmpDir)
1623 FN_GLOBAL_STRING(lp_wtmpdir, &Globals.szWtmpDir)
1624 FN_GLOBAL_BOOL(lp_utmp, &Globals.bUtmp)
1625 FN_GLOBAL_STRING(lp_rootdir, &Globals.szRootdir)
1626 FN_GLOBAL_STRING(lp_source_environment, &Globals.szSourceEnv)
1627 FN_GLOBAL_STRING(lp_defaultservice, &Globals.szDefaultService)
1628 FN_GLOBAL_STRING(lp_msg_command, &Globals.szMsgCommand)
1629 FN_GLOBAL_STRING(lp_dfree_command, &Globals.szDfree)
1630 FN_GLOBAL_STRING(lp_get_quota_command, &Globals.szGetQuota)
1631 FN_GLOBAL_STRING(lp_set_quota_command, &Globals.szSetQuota)
1632 FN_GLOBAL_STRING(lp_hosts_equiv, &Globals.szHostsEquiv)
1633 FN_GLOBAL_STRING(lp_auto_services, &Globals.szAutoServices)
1634 FN_GLOBAL_STRING(lp_passwd_program, &Globals.szPasswdProgram)
1635 FN_GLOBAL_STRING(lp_passwd_chat, &Globals.szPasswdChat)
1636 FN_GLOBAL_STRING(lp_passwordserver, &Globals.szPasswordServer)
1637 FN_GLOBAL_STRING(lp_name_resolve_order, &Globals.szNameResolveOrder)
1638 FN_GLOBAL_STRING(lp_realm, &Globals.szRealm)
1639 FN_GLOBAL_STRING(lp_afs_username_map, &Globals.szAfsUsernameMap)
1640 FN_GLOBAL_STRING(lp_username_map, &Globals.szUsernameMap)
1641 FN_GLOBAL_CONST_STRING(lp_logon_script, &Globals.szLogonScript)
1642 FN_GLOBAL_CONST_STRING(lp_logon_path, &Globals.szLogonPath)
1643 FN_GLOBAL_CONST_STRING(lp_logon_drive, &Globals.szLogonDrive)
1644 FN_GLOBAL_CONST_STRING(lp_logon_home, &Globals.szLogonHome)
1645 FN_GLOBAL_STRING(lp_remote_announce, &Globals.szRemoteAnnounce)
1646 FN_GLOBAL_STRING(lp_remote_browse_sync, &Globals.szRemoteBrowseSync)
1647 FN_GLOBAL_LIST(lp_wins_server_list, &Globals.szWINSservers)
1648 FN_GLOBAL_LIST(lp_interfaces, &Globals.szInterfaces)
1649 FN_GLOBAL_STRING(lp_socket_address, &Globals.szSocketAddress)
1650 FN_GLOBAL_STRING(lp_nis_home_map_name, &Globals.szNISHomeMapName)
1651 static FN_GLOBAL_STRING(lp_announce_version, &Globals.szAnnounceVersion)
1652 FN_GLOBAL_LIST(lp_netbios_aliases, &Globals.szNetbiosAliases)
1653 FN_GLOBAL_LIST(lp_passdb_backend, &Globals.szPassdbBackend)
1654 FN_GLOBAL_LIST(lp_preload_modules, &Globals.szPreloadModules)
1655 FN_GLOBAL_STRING(lp_panic_action, &Globals.szPanicAction)
1656 FN_GLOBAL_STRING(lp_adduser_script, &Globals.szAddUserScript)
1657 FN_GLOBAL_STRING(lp_deluser_script, &Globals.szDelUserScript)
1659 FN_GLOBAL_CONST_STRING(lp_guestaccount, &Globals.szGuestaccount)
1660 FN_GLOBAL_STRING(lp_addgroup_script, &Globals.szAddGroupScript)
1661 FN_GLOBAL_STRING(lp_delgroup_script, &Globals.szDelGroupScript)
1662 FN_GLOBAL_STRING(lp_addusertogroup_script, &Globals.szAddUserToGroupScript)
1663 FN_GLOBAL_STRING(lp_deluserfromgroup_script, &Globals.szDelUserFromGroupScript)
1664 FN_GLOBAL_STRING(lp_setprimarygroup_script, &Globals.szSetPrimaryGroupScript)
1666 FN_GLOBAL_STRING(lp_addmachine_script, &Globals.szAddMachineScript)
1668 FN_GLOBAL_STRING(lp_shutdown_script, &Globals.szShutdownScript)
1669 FN_GLOBAL_STRING(lp_abort_shutdown_script, &Globals.szAbortShutdownScript)
1671 FN_GLOBAL_STRING(lp_wins_hook, &Globals.szWINSHook)
1672 FN_GLOBAL_STRING(lp_wins_partners, &Globals.szWINSPartners)
1673 FN_GLOBAL_STRING(lp_template_primary_group, &Globals.szTemplatePrimaryGroup)
1674 FN_GLOBAL_STRING(lp_template_homedir, &Globals.szTemplateHomedir)
1675 FN_GLOBAL_STRING(lp_template_shell, &Globals.szTemplateShell)
1676 FN_GLOBAL_CONST_STRING(lp_winbind_separator, &Globals.szWinbindSeparator)
1677 FN_GLOBAL_STRING(lp_acl_compatibility, &Globals.szAclCompat)
1678 FN_GLOBAL_BOOL(lp_winbind_enable_local_accounts, &Globals.bWinbindEnableLocalAccounts)
1679 FN_GLOBAL_BOOL(lp_winbind_enum_users, &Globals.bWinbindEnumUsers)
1680 FN_GLOBAL_BOOL(lp_winbind_enum_groups, &Globals.bWinbindEnumGroups)
1681 FN_GLOBAL_BOOL(lp_winbind_use_default_domain, &Globals.bWinbindUseDefaultDomain)
1682 FN_GLOBAL_BOOL(lp_winbind_trusted_domains_only, &Globals.bWinbindTrustedDomainsOnly)
1684 FN_GLOBAL_STRING(lp_idmap_backend, &Globals.szIdmapBackend)
1685 FN_GLOBAL_BOOL(lp_enable_rid_algorithm, &Globals.bEnableRidAlgorithm)
1687 #ifdef WITH_LDAP_SAMCONFIG
1688 FN_GLOBAL_STRING(lp_ldap_server, &Globals.szLdapServer)
1689 FN_GLOBAL_INTEGER(lp_ldap_port, &Globals.ldap_port)
1690 #endif
1691 FN_GLOBAL_STRING(lp_ldap_suffix, &Globals.szLdapSuffix)
1692 FN_GLOBAL_STRING(lp_ldap_machine_suffix, &Globals.szLdapMachineSuffix)
1693 FN_GLOBAL_STRING(lp_ldap_user_suffix, &Globals.szLdapUserSuffix)
1694 FN_GLOBAL_STRING(lp_ldap_idmap_suffix, &Globals.szLdapIdmapSuffix)
1695 FN_GLOBAL_STRING(lp_ldap_group_suffix, &Globals.szLdapGroupSuffix)
1696 FN_GLOBAL_STRING(lp_ldap_filter, &Globals.szLdapFilter)
1697 FN_GLOBAL_STRING(lp_ldap_admin_dn, &Globals.szLdapAdminDn)
1698 FN_GLOBAL_INTEGER(lp_ldap_ssl, &Globals.ldap_ssl)
1699 FN_GLOBAL_INTEGER(lp_ldap_passwd_sync, &Globals.ldap_passwd_sync)
1700 FN_GLOBAL_BOOL(lp_ldap_delete_dn, &Globals.ldap_delete_dn)
1701 FN_GLOBAL_STRING(lp_add_share_cmd, &Globals.szAddShareCommand)
1702 FN_GLOBAL_STRING(lp_change_share_cmd, &Globals.szChangeShareCommand)
1703 FN_GLOBAL_STRING(lp_delete_share_cmd, &Globals.szDeleteShareCommand)
1705 FN_GLOBAL_BOOL(lp_disable_netbios, &Globals.bDisableNetbios)
1706 FN_GLOBAL_BOOL(lp_ms_add_printer_wizard, &Globals.bMsAddPrinterWizard)
1707 FN_GLOBAL_BOOL(lp_dns_proxy, &Globals.bDNSproxy)
1708 FN_GLOBAL_BOOL(lp_wins_support, &Globals.bWINSsupport)
1709 FN_GLOBAL_BOOL(lp_we_are_a_wins_server, &Globals.bWINSsupport)
1710 FN_GLOBAL_BOOL(lp_wins_proxy, &Globals.bWINSproxy)
1711 FN_GLOBAL_BOOL(lp_local_master, &Globals.bLocalMaster)
1712 FN_GLOBAL_BOOL(lp_domain_logons, &Globals.bDomainLogons)
1713 FN_GLOBAL_BOOL(lp_load_printers, &Globals.bLoadPrinters)
1714 FN_GLOBAL_BOOL(lp_readprediction, &Globals.bReadPrediction)
1715 FN_GLOBAL_BOOL(lp_readbmpx, &Globals.bReadbmpx)
1716 FN_GLOBAL_BOOL(lp_readraw, &Globals.bReadRaw)
1717 FN_GLOBAL_BOOL(lp_large_readwrite, &Globals.bLargeReadwrite)
1718 FN_GLOBAL_BOOL(lp_writeraw, &Globals.bWriteRaw)
1719 FN_GLOBAL_BOOL(lp_null_passwords, &Globals.bNullPasswords)
1720 FN_GLOBAL_BOOL(lp_obey_pam_restrictions, &Globals.bObeyPamRestrictions)
1721 FN_GLOBAL_BOOL(lp_encrypted_passwords, &Globals.bEncryptPasswords)
1722 FN_GLOBAL_BOOL(lp_update_encrypted, &Globals.bUpdateEncrypt)
1723 FN_GLOBAL_INTEGER(lp_client_schannel, &Globals.clientSchannel)
1724 FN_GLOBAL_INTEGER(lp_server_schannel, &Globals.serverSchannel)
1725 FN_GLOBAL_BOOL(lp_syslog_only, &Globals.bSyslogOnly)
1726 FN_GLOBAL_BOOL(lp_timestamp_logs, &Globals.bTimestampLogs)
1727 FN_GLOBAL_BOOL(lp_debug_hires_timestamp, &Globals.bDebugHiresTimestamp)
1728 FN_GLOBAL_BOOL(lp_debug_pid, &Globals.bDebugPid)
1729 FN_GLOBAL_BOOL(lp_debug_uid, &Globals.bDebugUid)
1730 FN_GLOBAL_BOOL(lp_browse_list, &Globals.bBrowseList)
1731 FN_GLOBAL_BOOL(lp_nis_home_map, &Globals.bNISHomeMap)
1732 static FN_GLOBAL_BOOL(lp_time_server, &Globals.bTimeServer)
1733 FN_GLOBAL_BOOL(lp_bind_interfaces_only, &Globals.bBindInterfacesOnly)
1734 FN_GLOBAL_BOOL(lp_pam_password_change, &Globals.bPamPasswordChange)
1735 FN_GLOBAL_BOOL(lp_unix_password_sync, &Globals.bUnixPasswdSync)
1736 FN_GLOBAL_BOOL(lp_passwd_chat_debug, &Globals.bPasswdChatDebug)
1737 FN_GLOBAL_BOOL(lp_unicode, &Globals.bUnicode)
1738 FN_GLOBAL_BOOL(lp_nt_pipe_support, &Globals.bNTPipeSupport)
1739 FN_GLOBAL_BOOL(lp_nt_status_support, &Globals.bNTStatusSupport)
1740 FN_GLOBAL_BOOL(lp_stat_cache, &Globals.bStatCache)
1741 FN_GLOBAL_BOOL(lp_allow_trusted_domains, &Globals.bAllowTrustedDomains)
1742 FN_GLOBAL_INTEGER(lp_restrict_anonymous, &Globals.restrict_anonymous)
1743 FN_GLOBAL_BOOL(lp_lanman_auth, &Globals.bLanmanAuth)
1744 FN_GLOBAL_BOOL(lp_ntlm_auth, &Globals.bNTLMAuth)
1745 FN_GLOBAL_BOOL(lp_client_plaintext_auth, &Globals.bClientPlaintextAuth)
1746 FN_GLOBAL_BOOL(lp_client_lanman_auth, &Globals.bClientLanManAuth)
1747 FN_GLOBAL_BOOL(lp_client_ntlmv2_auth, &Globals.bClientNTLMv2Auth)
1748 FN_GLOBAL_BOOL(lp_host_msdfs, &Globals.bHostMSDfs)
1749 FN_GLOBAL_BOOL(lp_kernel_oplocks, &Globals.bKernelOplocks)
1750 FN_GLOBAL_BOOL(lp_enhanced_browsing, &Globals.enhanced_browsing)
1751 FN_GLOBAL_BOOL(lp_use_mmap, &Globals.bUseMmap)
1752 FN_GLOBAL_BOOL(lp_unix_extensions, &Globals.bUnixExtensions)
1753 FN_GLOBAL_BOOL(lp_use_spnego, &Globals.bUseSpnego)
1754 FN_GLOBAL_BOOL(lp_client_use_spnego, &Globals.bClientUseSpnego)
1755 FN_GLOBAL_BOOL(lp_hostname_lookups, &Globals.bHostnameLookups)
1756 FN_GLOBAL_BOOL(lp_kernel_change_notify, &Globals.bKernelChangeNotify)
1757 FN_GLOBAL_INTEGER(lp_os_level, &Globals.os_level)
1758 FN_GLOBAL_INTEGER(lp_max_ttl, &Globals.max_ttl)
1759 FN_GLOBAL_INTEGER(lp_max_wins_ttl, &Globals.max_wins_ttl)
1760 FN_GLOBAL_INTEGER(lp_min_wins_ttl, &Globals.min_wins_ttl)
1761 FN_GLOBAL_INTEGER(lp_max_log_size, &Globals.max_log_size)
1762 FN_GLOBAL_INTEGER(lp_max_open_files, &Globals.max_open_files)
1763 FN_GLOBAL_INTEGER(lp_maxxmit, &Globals.max_xmit)
1764 FN_GLOBAL_INTEGER(lp_maxmux, &Globals.max_mux)
1765 FN_GLOBAL_INTEGER(lp_passwordlevel, &Globals.pwordlevel)
1766 FN_GLOBAL_INTEGER(lp_usernamelevel, &Globals.unamelevel)
1767 FN_GLOBAL_INTEGER(lp_readsize, &Globals.ReadSize)
1768 FN_GLOBAL_INTEGER(lp_deadtime, &Globals.deadtime)
1769 FN_GLOBAL_INTEGER(lp_maxprotocol, &Globals.maxprotocol)
1770 FN_GLOBAL_INTEGER(lp_minprotocol, &Globals.minprotocol)
1771 FN_GLOBAL_INTEGER(lp_security, &Globals.security)
1772 FN_GLOBAL_LIST(lp_auth_methods, &Globals.AuthMethods)
1773 FN_GLOBAL_BOOL(lp_paranoid_server_security, &Globals.paranoid_server_security)
1774 FN_GLOBAL_INTEGER(lp_maxdisksize, &Globals.maxdisksize)
1775 FN_GLOBAL_INTEGER(lp_lpqcachetime, &Globals.lpqcachetime)
1776 FN_GLOBAL_INTEGER(lp_max_smbd_processes, &Globals.iMaxSmbdProcesses)
1777 FN_GLOBAL_INTEGER(lp_disable_spoolss, &Globals.bDisableSpoolss)
1778 FN_GLOBAL_INTEGER(lp_syslog, &Globals.syslog)
1779 static FN_GLOBAL_INTEGER(lp_announce_as, &Globals.announce_as)
1780 FN_GLOBAL_INTEGER(lp_lm_announce, &Globals.lm_announce)
1781 FN_GLOBAL_INTEGER(lp_lm_interval, &Globals.lm_interval)
1782 FN_GLOBAL_INTEGER(lp_machine_password_timeout, &Globals.machine_password_timeout)
1783 FN_GLOBAL_INTEGER(lp_change_notify_timeout, &Globals.change_notify_timeout)
1784 FN_GLOBAL_INTEGER(lp_map_to_guest, &Globals.map_to_guest)
1785 FN_GLOBAL_INTEGER(lp_min_passwd_length, &Globals.min_passwd_length)
1786 FN_GLOBAL_INTEGER(lp_oplock_break_wait_time, &Globals.oplock_break_wait_time)
1787 FN_GLOBAL_INTEGER(lp_lock_spin_count, &Globals.iLockSpinCount)
1788 FN_GLOBAL_INTEGER(lp_lock_sleep_time, &Globals.iLockSpinTime)
1789 FN_LOCAL_STRING(lp_preexec, szPreExec)
1790 FN_LOCAL_STRING(lp_postexec, szPostExec)
1791 FN_LOCAL_STRING(lp_rootpreexec, szRootPreExec)
1792 FN_LOCAL_STRING(lp_rootpostexec, szRootPostExec)
1793 FN_LOCAL_STRING(lp_servicename, szService)
1794 FN_LOCAL_CONST_STRING(lp_const_servicename, szService)
1795 FN_LOCAL_STRING(lp_pathname, szPath)
1796 FN_LOCAL_STRING(lp_dontdescend, szDontdescend)
1797 FN_LOCAL_STRING(lp_username, szUsername)
1798 FN_LOCAL_LIST(lp_invalid_users, szInvalidUsers)
1799 FN_LOCAL_LIST(lp_valid_users, szValidUsers)
1800 FN_LOCAL_LIST(lp_admin_users, szAdminUsers)
1801 FN_LOCAL_STRING(lp_printcommand, szPrintcommand)
1802 FN_LOCAL_STRING(lp_lpqcommand, szLpqcommand)
1803 FN_LOCAL_STRING(lp_lprmcommand, szLprmcommand)
1804 FN_LOCAL_STRING(lp_lppausecommand, szLppausecommand)
1805 FN_LOCAL_STRING(lp_lpresumecommand, szLpresumecommand)
1806 FN_LOCAL_STRING(lp_queuepausecommand, szQueuepausecommand)
1807 FN_LOCAL_STRING(lp_queueresumecommand, szQueueresumecommand)
1808 static FN_LOCAL_STRING(_lp_printername, szPrintername)
1809 FN_LOCAL_LIST(lp_hostsallow, szHostsallow)
1810 FN_LOCAL_LIST(lp_hostsdeny, szHostsdeny)
1811 FN_LOCAL_STRING(lp_magicscript, szMagicScript)
1812 FN_LOCAL_STRING(lp_magicoutput, szMagicOutput)
1813 FN_LOCAL_STRING(lp_comment, comment)
1814 FN_LOCAL_STRING(lp_force_user, force_user)
1815 FN_LOCAL_STRING(lp_force_group, force_group)
1816 FN_LOCAL_LIST(lp_readlist, readlist)
1817 FN_LOCAL_LIST(lp_writelist, writelist)
1818 FN_LOCAL_LIST(lp_printer_admin, printer_admin)
1819 FN_LOCAL_STRING(lp_fstype, fstype)
1820 FN_LOCAL_LIST(lp_vfs_objects, szVfsObjects)
1821 FN_LOCAL_STRING(lp_msdfs_proxy, szMSDfsProxy)
1822 static FN_LOCAL_STRING(lp_volume, volume)
1823 FN_LOCAL_STRING(lp_mangled_map, szMangledMap)
1824 FN_LOCAL_STRING(lp_veto_files, szVetoFiles)
1825 FN_LOCAL_STRING(lp_hide_files, szHideFiles)
1826 FN_LOCAL_STRING(lp_veto_oplocks, szVetoOplockFiles)
1827 FN_LOCAL_BOOL(lp_msdfs_root, bMSDfsRoot)
1828 FN_LOCAL_BOOL(lp_autoloaded, autoloaded)
1829 FN_LOCAL_BOOL(lp_preexec_close, bPreexecClose)
1830 FN_LOCAL_BOOL(lp_rootpreexec_close, bRootpreexecClose)
1831 FN_LOCAL_BOOL(lp_casesensitive, bCaseSensitive)
1832 FN_LOCAL_BOOL(lp_preservecase, bCasePreserve)
1833 FN_LOCAL_BOOL(lp_shortpreservecase, bShortCasePreserve)
1834 FN_LOCAL_BOOL(lp_casemangle, bCaseMangle)
1835 FN_LOCAL_BOOL(lp_hide_dot_files, bHideDotFiles)
1836 FN_LOCAL_BOOL(lp_hide_special_files, bHideSpecialFiles)
1837 FN_LOCAL_BOOL(lp_hideunreadable, bHideUnReadable)
1838 FN_LOCAL_BOOL(lp_hideunwriteable_files, bHideUnWriteableFiles)
1839 FN_LOCAL_BOOL(lp_browseable, bBrowseable)
1840 FN_LOCAL_BOOL(lp_readonly, bRead_only)
1841 FN_LOCAL_BOOL(lp_no_set_dir, bNo_set_dir)
1842 FN_LOCAL_BOOL(lp_guest_ok, bGuest_ok)
1843 FN_LOCAL_BOOL(lp_guest_only, bGuest_only)
1844 FN_LOCAL_BOOL(lp_print_ok, bPrint_ok)
1845 FN_LOCAL_BOOL(lp_map_hidden, bMap_hidden)
1846 FN_LOCAL_BOOL(lp_map_archive, bMap_archive)
1847 FN_LOCAL_BOOL(lp_locking, bLocking)
1848 FN_LOCAL_BOOL(lp_strict_locking, bStrictLocking)
1849 FN_LOCAL_BOOL(lp_posix_locking, bPosixLocking)
1850 FN_LOCAL_BOOL(lp_share_modes, bShareModes)
1851 FN_LOCAL_BOOL(lp_oplocks, bOpLocks)
1852 FN_LOCAL_BOOL(lp_level2_oplocks, bLevel2OpLocks)
1853 FN_LOCAL_BOOL(lp_onlyuser, bOnlyUser)
1854 FN_LOCAL_BOOL(lp_manglednames, bMangledNames)
1855 FN_LOCAL_BOOL(lp_widelinks, bWidelinks)
1856 FN_LOCAL_BOOL(lp_symlinks, bSymlinks)
1857 FN_LOCAL_BOOL(lp_syncalways, bSyncAlways)
1858 FN_LOCAL_BOOL(lp_strict_allocate, bStrictAllocate)
1859 FN_LOCAL_BOOL(lp_strict_sync, bStrictSync)
1860 FN_LOCAL_BOOL(lp_map_system, bMap_system)
1861 FN_LOCAL_BOOL(lp_delete_readonly, bDeleteReadonly)
1862 FN_LOCAL_BOOL(lp_fake_oplocks, bFakeOplocks)
1863 FN_LOCAL_BOOL(lp_recursive_veto_delete, bDeleteVetoFiles)
1864 FN_LOCAL_BOOL(lp_dos_filemode, bDosFilemode)
1865 FN_LOCAL_BOOL(lp_dos_filetimes, bDosFiletimes)
1866 FN_LOCAL_BOOL(lp_dos_filetime_resolution, bDosFiletimeResolution)
1867 FN_LOCAL_BOOL(lp_fake_dir_create_times, bFakeDirCreateTimes)
1868 FN_LOCAL_BOOL(lp_blocking_locks, bBlockingLocks)
1869 FN_LOCAL_BOOL(lp_inherit_perms, bInheritPerms)
1870 FN_LOCAL_BOOL(lp_inherit_acls, bInheritACLS)
1871 FN_LOCAL_BOOL(lp_use_client_driver, bUseClientDriver)
1872 FN_LOCAL_BOOL(lp_default_devmode, bDefaultDevmode)
1873 FN_LOCAL_BOOL(lp_nt_acl_support, bNTAclSupport)
1874 FN_LOCAL_BOOL(_lp_use_sendfile, bUseSendfile)
1875 FN_LOCAL_BOOL(lp_profile_acls, bProfileAcls)
1876 FN_LOCAL_BOOL(lp_map_acl_inherit, bMap_acl_inherit)
1877 FN_LOCAL_BOOL(lp_afs_share, bAfs_Share)
1878 FN_LOCAL_INTEGER(lp_create_mask, iCreate_mask)
1879 FN_LOCAL_INTEGER(lp_force_create_mode, iCreate_force_mode)
1880 FN_LOCAL_INTEGER(lp_security_mask, iSecurity_mask)
1881 FN_LOCAL_INTEGER(lp_force_security_mode, iSecurity_force_mode)
1882 FN_LOCAL_INTEGER(lp_dir_mask, iDir_mask)
1883 FN_LOCAL_INTEGER(lp_force_dir_mode, iDir_force_mode)
1884 FN_LOCAL_INTEGER(lp_dir_security_mask, iDir_Security_mask)
1885 FN_LOCAL_INTEGER(lp_force_dir_security_mode, iDir_Security_force_mode)
1886 FN_LOCAL_INTEGER(lp_max_connections, iMaxConnections)
1887 FN_LOCAL_INTEGER(lp_defaultcase, iDefaultCase)
1888 FN_LOCAL_INTEGER(lp_minprintspace, iMinPrintSpace)
1889 FN_LOCAL_INTEGER(lp_printing, iPrinting)
1890 FN_LOCAL_INTEGER(lp_max_reported_jobs, iMaxReportedPrintJobs)
1891 FN_LOCAL_INTEGER(lp_oplock_contention_limit, iOplockContentionLimit)
1892 FN_LOCAL_INTEGER(lp_csc_policy, iCSCPolicy)
1893 FN_LOCAL_INTEGER(lp_write_cache_size, iWriteCacheSize)
1894 FN_LOCAL_INTEGER(lp_block_size, iBlock_size)
1895 FN_LOCAL_CHAR(lp_magicchar, magic_char)
1896 FN_GLOBAL_INTEGER(lp_winbind_cache_time, &Globals.winbind_cache_time)
1897 FN_GLOBAL_BOOL(lp_hide_local_users, &Globals.bHideLocalUsers)
1898 FN_GLOBAL_INTEGER(lp_algorithmic_rid_base, &Globals.AlgorithmicRidBase)
1899 FN_GLOBAL_INTEGER(lp_name_cache_timeout, &Globals.name_cache_timeout)
1900 FN_GLOBAL_INTEGER(lp_client_signing, &Globals.client_signing)
1901 FN_GLOBAL_INTEGER(lp_server_signing, &Globals.server_signing)
1903 /* local prototypes */
1905 static int map_parameter(const char *pszParmName);
1906 static BOOL set_boolean(BOOL *pb, const char *pszParmValue);
1907 static int getservicebyname(const char *pszServiceName,
1908 service * pserviceDest);
1909 static void copy_service(service * pserviceDest,
1910 service * pserviceSource, BOOL *pcopymapDest);
1911 static BOOL service_ok(int iService);
1912 static BOOL do_parameter(const char *pszParmName, const char *pszParmValue);
1913 static BOOL do_section(const char *pszSectionName);
1914 static void init_copymap(service * pservice);
1916 /* This is a helper function for parametrical options support. */
1917 /* It returns a pointer to parametrical option value if it exists or NULL otherwise */
1918 /* Actual parametrical functions are quite simple */
1919 static param_opt_struct *get_parametrics(int snum, const char *type, const char *option)
1921 BOOL global_section = False;
1922 char* param_key;
1923 param_opt_struct *data;
1925 if (snum >= iNumServices) return NULL;
1927 if (snum < 0) {
1928 data = Globals.param_opt;
1929 global_section = True;
1930 } else {
1931 data = ServicePtrs[snum]->param_opt;
1934 asprintf(&param_key, "%s:%s", type, option);
1935 if (!param_key) {
1936 DEBUG(0,("asprintf failed!\n"));
1937 return NULL;
1940 while (data) {
1941 if (strcmp(data->key, param_key) == 0) {
1942 string_free(&param_key);
1943 return data;
1945 data = data->next;
1948 if (!global_section) {
1949 /* Try to fetch the same option but from globals */
1950 /* but only if we are not already working with Globals */
1951 data = Globals.param_opt;
1952 while (data) {
1953 if (strcmp(data->key, param_key) == 0) {
1954 string_free(&param_key);
1955 return data;
1957 data = data->next;
1961 string_free(&param_key);
1963 return NULL;
1967 /*******************************************************************
1968 convenience routine to return int parameters.
1969 ********************************************************************/
1970 static int lp_int(const char *s)
1973 if (!s) {
1974 DEBUG(0,("lp_int(%s): is called with NULL!\n",s));
1975 return (-1);
1978 return atoi(s);
1981 /*******************************************************************
1982 convenience routine to return unsigned long parameters.
1983 ********************************************************************/
1984 static int lp_ulong(const char *s)
1987 if (!s) {
1988 DEBUG(0,("lp_int(%s): is called with NULL!\n",s));
1989 return (-1);
1992 return strtoul(s, NULL, 10);
1995 /*******************************************************************
1996 convenience routine to return boolean parameters.
1997 ********************************************************************/
1998 static BOOL lp_bool(const char *s)
2000 BOOL ret = False;
2002 if (!s) {
2003 DEBUG(0,("lp_bool(%s): is called with NULL!\n",s));
2004 return False;
2007 if (!set_boolean(&ret,s)) {
2008 DEBUG(0,("lp_bool(%s): value is not boolean!\n",s));
2009 return False;
2012 return ret;
2015 /*******************************************************************
2016 convenience routine to return enum parameters.
2017 ********************************************************************/
2018 static int lp_enum(const char *s,const struct enum_list *_enum)
2020 int i;
2022 if (!s || !_enum) {
2023 DEBUG(0,("lp_enum(%s,enum): is called with NULL!\n",s));
2024 return (-1);
2027 for (i=0; _enum[i].name; i++) {
2028 if (strequal(_enum[i].name,s))
2029 return _enum[i].value;
2032 DEBUG(0,("lp_enum(%s,enum): value is not in enum_list!\n",s));
2033 return (-1);
2037 /* DO NOT USE lp_parm_string ANYMORE!!!!
2038 * use lp_parm_const_string or lp_parm_talloc_string
2040 * lp_parm_string is only used to let old modules find this symbol
2042 #undef lp_parm_string
2043 char *lp_parm_string(const char *servicename, const char *type, const char *option)
2045 return lp_parm_talloc_string(lp_servicenumber(servicename), type, option, NULL);
2048 /* Return parametric option from a given service. Type is a part of option before ':' */
2049 /* Parametric option has following syntax: 'Type: option = value' */
2050 /* the returned value is talloced in lp_talloc */
2051 char *lp_parm_talloc_string(int snum, const char *type, const char *option, const char *def)
2053 param_opt_struct *data = get_parametrics(snum, type, option);
2055 if (data == NULL||data->value==NULL) {
2056 if (def) {
2057 return lp_string(def);
2058 } else {
2059 return NULL;
2063 return lp_string(data->value);
2066 /* Return parametric option from a given service. Type is a part of option before ':' */
2067 /* Parametric option has following syntax: 'Type: option = value' */
2068 const char *lp_parm_const_string(int snum, const char *type, const char *option, const char *def)
2070 param_opt_struct *data = get_parametrics(snum, type, option);
2072 if (data == NULL||data->value==NULL)
2073 return def;
2075 return data->value;
2078 /* Return parametric option from a given service. Type is a part of option before ':' */
2079 /* Parametric option has following syntax: 'Type: option = value' */
2081 const char **lp_parm_string_list(int snum, const char *type, const char *option, const char **def)
2083 param_opt_struct *data = get_parametrics(snum, type, option);
2085 if (data == NULL||data->value==NULL)
2086 return (const char **)def;
2088 if (data->list==NULL) {
2089 data->list = str_list_make(data->value, NULL);
2092 return (const char **)data->list;
2095 /* Return parametric option from a given service. Type is a part of option before ':' */
2096 /* Parametric option has following syntax: 'Type: option = value' */
2098 int lp_parm_int(int snum, const char *type, const char *option, int def)
2100 param_opt_struct *data = get_parametrics(snum, type, option);
2102 if (data && data->value && *data->value)
2103 return lp_int(data->value);
2105 return def;
2108 /* Return parametric option from a given service. Type is a part of option before ':' */
2109 /* Parametric option has following syntax: 'Type: option = value' */
2111 unsigned long lp_parm_ulong(int snum, const char *type, const char *option, unsigned long def)
2113 param_opt_struct *data = get_parametrics(snum, type, option);
2115 if (data && data->value && *data->value)
2116 return lp_ulong(data->value);
2118 return def;
2121 /* Return parametric option from a given service. Type is a part of option before ':' */
2122 /* Parametric option has following syntax: 'Type: option = value' */
2124 BOOL lp_parm_bool(int snum, const char *type, const char *option, BOOL def)
2126 param_opt_struct *data = get_parametrics(snum, type, option);
2128 if (data && data->value && *data->value)
2129 return lp_bool(data->value);
2131 return def;
2134 /* Return parametric option from a given service. Type is a part of option before ':' */
2135 /* Parametric option has following syntax: 'Type: option = value' */
2137 int lp_parm_enum(int snum, const char *type, const char *option,
2138 const struct enum_list *_enum, int def)
2140 param_opt_struct *data = get_parametrics(snum, type, option);
2142 if (data && data->value && *data->value && _enum)
2143 return lp_enum(data->value, _enum);
2145 return def;
2149 /***************************************************************************
2150 Initialise a service to the defaults.
2151 ***************************************************************************/
2153 static void init_service(service * pservice)
2155 memset((char *)pservice, '\0', sizeof(service));
2156 copy_service(pservice, &sDefault, NULL);
2159 /***************************************************************************
2160 Free the dynamically allocated parts of a service struct.
2161 ***************************************************************************/
2163 static void free_service(service *pservice)
2165 int i;
2166 param_opt_struct *data, *pdata;
2167 if (!pservice)
2168 return;
2170 if (pservice->szService)
2171 DEBUG(5, ("free_service: Freeing service %s\n",
2172 pservice->szService));
2174 string_free(&pservice->szService);
2175 SAFE_FREE(pservice->copymap);
2177 for (i = 0; parm_table[i].label; i++) {
2178 if ((parm_table[i].type == P_STRING ||
2179 parm_table[i].type == P_USTRING) &&
2180 parm_table[i].class == P_LOCAL)
2181 string_free((char **)
2182 (((char *)pservice) +
2183 PTR_DIFF(parm_table[i].ptr, &sDefault)));
2184 else if (parm_table[i].type == P_LIST &&
2185 parm_table[i].class == P_LOCAL)
2186 str_list_free((char ***)
2187 (((char *)pservice) +
2188 PTR_DIFF(parm_table[i].ptr, &sDefault)));
2191 data = pservice->param_opt;
2192 if (data)
2193 DEBUG(5,("Freeing parametrics:\n"));
2194 while (data) {
2195 DEBUG(5,("[%s = %s]\n", data->key, data->value));
2196 string_free(&data->key);
2197 string_free(&data->value);
2198 str_list_free(&data->list);
2199 pdata = data->next;
2200 SAFE_FREE(data);
2201 data = pdata;
2204 ZERO_STRUCTP(pservice);
2207 /***************************************************************************
2208 Add a new service to the services array initialising it with the given
2209 service.
2210 ***************************************************************************/
2212 static int add_a_service(const service *pservice, const char *name)
2214 int i;
2215 service tservice;
2216 int num_to_alloc = iNumServices + 1;
2217 param_opt_struct *data, *pdata;
2219 tservice = *pservice;
2221 /* it might already exist */
2222 if (name) {
2223 i = getservicebyname(name, NULL);
2224 if (i >= 0) {
2225 /* Clean all parametric options for service */
2226 /* They will be added during parsing again */
2227 data = ServicePtrs[i]->param_opt;
2228 while (data) {
2229 string_free(&data->key);
2230 string_free(&data->value);
2231 str_list_free(&data->list);
2232 pdata = data->next;
2233 SAFE_FREE(data);
2234 data = pdata;
2236 ServicePtrs[i]->param_opt = NULL;
2237 return (i);
2241 /* find an invalid one */
2242 for (i = 0; i < iNumServices; i++)
2243 if (!ServicePtrs[i]->valid)
2244 break;
2246 /* if not, then create one */
2247 if (i == iNumServices) {
2248 service **tsp;
2250 tsp = (service **) Realloc(ServicePtrs,
2251 sizeof(service *) *
2252 num_to_alloc);
2254 if (!tsp) {
2255 DEBUG(0,("add_a_service: failed to enlarge ServicePtrs!\n"));
2256 return (-1);
2258 else {
2259 ServicePtrs = tsp;
2260 ServicePtrs[iNumServices] =
2261 (service *) malloc(sizeof(service));
2263 if (!ServicePtrs[iNumServices]) {
2264 DEBUG(0,("add_a_service: out of memory!\n"));
2265 return (-1);
2268 iNumServices++;
2269 } else
2270 free_service(ServicePtrs[i]);
2272 ServicePtrs[i]->valid = True;
2274 init_service(ServicePtrs[i]);
2275 copy_service(ServicePtrs[i], &tservice, NULL);
2276 if (name)
2277 string_set(&ServicePtrs[i]->szService, name);
2278 return (i);
2281 /***************************************************************************
2282 Add a new home service, with the specified home directory, defaults coming
2283 from service ifrom.
2284 ***************************************************************************/
2286 BOOL lp_add_home(const char *pszHomename, int iDefaultService,
2287 const char *user, const char *pszHomedir)
2289 int i;
2290 pstring newHomedir;
2292 i = add_a_service(ServicePtrs[iDefaultService], pszHomename);
2294 if (i < 0)
2295 return (False);
2297 if (!(*(ServicePtrs[iDefaultService]->szPath))
2298 || strequal(ServicePtrs[iDefaultService]->szPath, lp_pathname(GLOBAL_SECTION_SNUM))) {
2299 pstrcpy(newHomedir, pszHomedir);
2300 string_set(&ServicePtrs[i]->szPath, newHomedir);
2303 if (!(*(ServicePtrs[i]->comment))) {
2304 pstring comment;
2305 slprintf(comment, sizeof(comment) - 1,
2306 "Home directory of %s", user);
2307 string_set(&ServicePtrs[i]->comment, comment);
2310 /* set the browseable flag from the gloabl default */
2312 ServicePtrs[i]->bBrowseable = sDefault.bBrowseable;
2314 DEBUG(3, ("adding home's share [%s] for user '%s' at '%s'\n", pszHomename,
2315 user, newHomedir));
2317 return (True);
2320 /***************************************************************************
2321 Add a new service, based on an old one.
2322 ***************************************************************************/
2324 int lp_add_service(const char *pszService, int iDefaultService)
2326 return (add_a_service(ServicePtrs[iDefaultService], pszService));
2329 /***************************************************************************
2330 Add the IPC service.
2331 ***************************************************************************/
2333 static BOOL lp_add_ipc(const char *ipc_name, BOOL guest_ok)
2335 pstring comment;
2336 int i = add_a_service(&sDefault, ipc_name);
2338 if (i < 0)
2339 return (False);
2341 slprintf(comment, sizeof(comment) - 1,
2342 "IPC Service (%s)", Globals.szServerString);
2344 string_set(&ServicePtrs[i]->szPath, tmpdir());
2345 string_set(&ServicePtrs[i]->szUsername, "");
2346 string_set(&ServicePtrs[i]->comment, comment);
2347 string_set(&ServicePtrs[i]->fstype, "IPC");
2348 ServicePtrs[i]->iMaxConnections = 0;
2349 ServicePtrs[i]->bAvailable = True;
2350 ServicePtrs[i]->bRead_only = True;
2351 ServicePtrs[i]->bGuest_only = False;
2352 ServicePtrs[i]->bGuest_ok = guest_ok;
2353 ServicePtrs[i]->bPrint_ok = False;
2354 ServicePtrs[i]->bBrowseable = sDefault.bBrowseable;
2356 DEBUG(3, ("adding IPC service\n"));
2358 return (True);
2361 /***************************************************************************
2362 Add a new printer service, with defaults coming from service iFrom.
2363 ***************************************************************************/
2365 BOOL lp_add_printer(const char *pszPrintername, int iDefaultService)
2367 const char *comment = "From Printcap";
2368 int i = add_a_service(ServicePtrs[iDefaultService], pszPrintername);
2370 if (i < 0)
2371 return (False);
2373 /* note that we do NOT default the availability flag to True - */
2374 /* we take it from the default service passed. This allows all */
2375 /* dynamic printers to be disabled by disabling the [printers] */
2376 /* entry (if/when the 'available' keyword is implemented!). */
2378 /* the printer name is set to the service name. */
2379 string_set(&ServicePtrs[i]->szPrintername, pszPrintername);
2380 string_set(&ServicePtrs[i]->comment, comment);
2382 /* set the browseable flag from the gloabl default */
2383 ServicePtrs[i]->bBrowseable = sDefault.bBrowseable;
2385 /* Printers cannot be read_only. */
2386 ServicePtrs[i]->bRead_only = False;
2387 /* No share modes on printer services. */
2388 ServicePtrs[i]->bShareModes = False;
2389 /* No oplocks on printer services. */
2390 ServicePtrs[i]->bOpLocks = False;
2391 /* Printer services must be printable. */
2392 ServicePtrs[i]->bPrint_ok = True;
2394 DEBUG(3, ("adding printer service %s\n", pszPrintername));
2396 update_server_announce_as_printserver();
2398 return (True);
2401 /***************************************************************************
2402 Map a parameter's string representation to something we can use.
2403 Returns False if the parameter string is not recognised, else TRUE.
2404 ***************************************************************************/
2406 static int map_parameter(const char *pszParmName)
2408 int iIndex;
2410 if (*pszParmName == '-')
2411 return (-1);
2413 for (iIndex = 0; parm_table[iIndex].label; iIndex++)
2414 if (strwicmp(parm_table[iIndex].label, pszParmName) == 0)
2415 return (iIndex);
2417 /* Warn only if it isn't parametric option */
2418 if (strchr(pszParmName, ':') == NULL)
2419 DEBUG(0, ("Unknown parameter encountered: \"%s\"\n", pszParmName));
2420 /* We do return 'fail' for parametric options as well because they are
2421 stored in different storage
2423 return (-1);
2426 /***************************************************************************
2427 Set a boolean variable from the text value stored in the passed string.
2428 Returns True in success, False if the passed string does not correctly
2429 represent a boolean.
2430 ***************************************************************************/
2432 static BOOL set_boolean(BOOL *pb, const char *pszParmValue)
2434 BOOL bRetval;
2436 bRetval = True;
2437 if (strwicmp(pszParmValue, "yes") == 0 ||
2438 strwicmp(pszParmValue, "true") == 0 ||
2439 strwicmp(pszParmValue, "1") == 0)
2440 *pb = True;
2441 else if (strwicmp(pszParmValue, "no") == 0 ||
2442 strwicmp(pszParmValue, "False") == 0 ||
2443 strwicmp(pszParmValue, "0") == 0)
2444 *pb = False;
2445 else {
2446 DEBUG(0,
2447 ("ERROR: Badly formed boolean in configuration file: \"%s\".\n",
2448 pszParmValue));
2449 bRetval = False;
2451 return (bRetval);
2454 /***************************************************************************
2455 Find a service by name. Otherwise works like get_service.
2456 ***************************************************************************/
2458 static int getservicebyname(const char *pszServiceName, service * pserviceDest)
2460 int iService;
2462 for (iService = iNumServices - 1; iService >= 0; iService--)
2463 if (VALID(iService) &&
2464 strwicmp(ServicePtrs[iService]->szService, pszServiceName) == 0) {
2465 if (pserviceDest != NULL)
2466 copy_service(pserviceDest, ServicePtrs[iService], NULL);
2467 break;
2470 return (iService);
2473 /***************************************************************************
2474 Copy a service structure to another.
2475 If pcopymapDest is NULL then copy all fields
2476 ***************************************************************************/
2478 static void copy_service(service * pserviceDest, service * pserviceSource, BOOL *pcopymapDest)
2480 int i;
2481 BOOL bcopyall = (pcopymapDest == NULL);
2482 param_opt_struct *data, *pdata, *paramo;
2483 BOOL not_added;
2485 for (i = 0; parm_table[i].label; i++)
2486 if (parm_table[i].ptr && parm_table[i].class == P_LOCAL &&
2487 (bcopyall || pcopymapDest[i])) {
2488 void *def_ptr = parm_table[i].ptr;
2489 void *src_ptr =
2490 ((char *)pserviceSource) + PTR_DIFF(def_ptr,
2491 &sDefault);
2492 void *dest_ptr =
2493 ((char *)pserviceDest) + PTR_DIFF(def_ptr,
2494 &sDefault);
2496 switch (parm_table[i].type) {
2497 case P_BOOL:
2498 case P_BOOLREV:
2499 *(BOOL *)dest_ptr = *(BOOL *)src_ptr;
2500 break;
2502 case P_INTEGER:
2503 case P_ENUM:
2504 case P_OCTAL:
2505 *(int *)dest_ptr = *(int *)src_ptr;
2506 break;
2508 case P_CHAR:
2509 *(char *)dest_ptr = *(char *)src_ptr;
2510 break;
2512 case P_STRING:
2513 string_set(dest_ptr,
2514 *(char **)src_ptr);
2515 break;
2517 case P_USTRING:
2518 string_set(dest_ptr,
2519 *(char **)src_ptr);
2520 strupper_m(*(char **)dest_ptr);
2521 break;
2522 case P_LIST:
2523 str_list_copy((char ***)dest_ptr, *(const char ***)src_ptr);
2524 break;
2525 default:
2526 break;
2530 if (bcopyall) {
2531 init_copymap(pserviceDest);
2532 if (pserviceSource->copymap)
2533 memcpy((void *)pserviceDest->copymap,
2534 (void *)pserviceSource->copymap,
2535 sizeof(BOOL) * NUMPARAMETERS);
2538 data = pserviceSource->param_opt;
2539 while (data) {
2540 not_added = True;
2541 pdata = pserviceDest->param_opt;
2542 /* Traverse destination */
2543 while (pdata) {
2544 /* If we already have same option, override it */
2545 if (strcmp(pdata->key, data->key) == 0) {
2546 string_free(&pdata->value);
2547 str_list_free(&data->list);
2548 pdata->value = strdup(data->value);
2549 not_added = False;
2550 break;
2552 pdata = pdata->next;
2554 if (not_added) {
2555 paramo = smb_xmalloc(sizeof(param_opt_struct));
2556 paramo->key = strdup(data->key);
2557 paramo->value = strdup(data->value);
2558 paramo->list = NULL;
2559 DLIST_ADD(pserviceDest->param_opt, paramo);
2561 data = data->next;
2565 /***************************************************************************
2566 Check a service for consistency. Return False if the service is in any way
2567 incomplete or faulty, else True.
2568 ***************************************************************************/
2570 static BOOL service_ok(int iService)
2572 BOOL bRetval;
2574 bRetval = True;
2575 if (ServicePtrs[iService]->szService[0] == '\0') {
2576 DEBUG(0, ("The following message indicates an internal error:\n"));
2577 DEBUG(0, ("No service name in service entry.\n"));
2578 bRetval = False;
2581 /* The [printers] entry MUST be printable. I'm all for flexibility, but */
2582 /* I can't see why you'd want a non-printable printer service... */
2583 if (strwicmp(ServicePtrs[iService]->szService, PRINTERS_NAME) == 0) {
2584 if (!ServicePtrs[iService]->bPrint_ok) {
2585 DEBUG(0, ("WARNING: [%s] service MUST be printable!\n",
2586 ServicePtrs[iService]->szService));
2587 ServicePtrs[iService]->bPrint_ok = True;
2589 /* [printers] service must also be non-browsable. */
2590 if (ServicePtrs[iService]->bBrowseable)
2591 ServicePtrs[iService]->bBrowseable = False;
2594 if (ServicePtrs[iService]->szPath[0] == '\0' &&
2595 strwicmp(ServicePtrs[iService]->szService, HOMES_NAME) != 0) {
2596 DEBUG(0, ("No path in service %s - using %s\n",
2597 ServicePtrs[iService]->szService, tmpdir()));
2598 string_set(&ServicePtrs[iService]->szPath, tmpdir());
2601 /* If a service is flagged unavailable, log the fact at level 0. */
2602 if (!ServicePtrs[iService]->bAvailable)
2603 DEBUG(1, ("NOTE: Service %s is flagged unavailable.\n",
2604 ServicePtrs[iService]->szService));
2606 return (bRetval);
2609 static struct file_lists {
2610 struct file_lists *next;
2611 char *name;
2612 char *subfname;
2613 time_t modtime;
2614 } *file_lists = NULL;
2616 /*******************************************************************
2617 Keep a linked list of all config files so we know when one has changed
2618 it's date and needs to be reloaded.
2619 ********************************************************************/
2621 static void add_to_file_list(const char *fname, const char *subfname)
2623 struct file_lists *f = file_lists;
2625 while (f) {
2626 if (f->name && !strcmp(f->name, fname))
2627 break;
2628 f = f->next;
2631 if (!f) {
2632 f = (struct file_lists *)malloc(sizeof(file_lists[0]));
2633 if (!f)
2634 return;
2635 f->next = file_lists;
2636 f->name = strdup(fname);
2637 if (!f->name) {
2638 SAFE_FREE(f);
2639 return;
2641 f->subfname = strdup(subfname);
2642 if (!f->subfname) {
2643 SAFE_FREE(f);
2644 return;
2646 file_lists = f;
2647 f->modtime = file_modtime(subfname);
2648 } else {
2649 time_t t = file_modtime(subfname);
2650 if (t)
2651 f->modtime = t;
2655 /*******************************************************************
2656 Check if a config file has changed date.
2657 ********************************************************************/
2659 BOOL lp_file_list_changed(void)
2661 struct file_lists *f = file_lists;
2662 DEBUG(6, ("lp_file_list_changed()\n"));
2664 while (f) {
2665 pstring n2;
2666 time_t mod_time;
2668 pstrcpy(n2, f->name);
2669 standard_sub_basic(current_user_info.smb_name, n2,sizeof(n2));
2671 DEBUGADD(6, ("file %s -> %s last mod_time: %s\n",
2672 f->name, n2, ctime(&f->modtime)));
2674 mod_time = file_modtime(n2);
2676 if (mod_time && ((f->modtime != mod_time) || (f->subfname == NULL) || (strcmp(n2, f->subfname) != 0))) {
2677 DEBUGADD(6,
2678 ("file %s modified: %s\n", n2,
2679 ctime(&mod_time)));
2680 f->modtime = mod_time;
2681 SAFE_FREE(f->subfname);
2682 f->subfname = strdup(n2);
2683 return (True);
2685 f = f->next;
2687 return (False);
2690 /***************************************************************************
2691 Run standard_sub_basic on netbios name... needed because global_myname
2692 is not accessed through any lp_ macro.
2693 Note: We must *NOT* use string_set() here as ptr points to global_myname.
2694 ***************************************************************************/
2696 static BOOL handle_netbios_name(const char *pszParmValue, char **ptr)
2698 BOOL ret;
2699 pstring netbios_name;
2701 pstrcpy(netbios_name, pszParmValue);
2703 standard_sub_basic(current_user_info.smb_name, netbios_name,sizeof(netbios_name));
2705 ret = set_global_myname(netbios_name);
2706 string_set(&Globals.szNetbiosName,global_myname());
2708 DEBUG(4, ("handle_netbios_name: set global_myname to: %s\n",
2709 global_myname()));
2711 return ret;
2714 static BOOL handle_charset(const char *pszParmValue, char **ptr)
2716 if (strcmp(*ptr, pszParmValue) != 0) {
2717 string_set(ptr, pszParmValue);
2718 init_iconv();
2720 return True;
2723 static BOOL handle_workgroup(const char *pszParmValue, char **ptr)
2725 BOOL ret;
2727 ret = set_global_myworkgroup(pszParmValue);
2728 string_set(&Globals.szWorkgroup,lp_workgroup());
2730 return ret;
2733 static BOOL handle_netbios_scope(const char *pszParmValue, char **ptr)
2735 BOOL ret;
2737 ret = set_global_scope(pszParmValue);
2738 string_set(&Globals.szNetbiosScope,global_scope());
2740 return ret;
2743 static BOOL handle_netbios_aliases(const char *pszParmValue, char **ptr)
2745 Globals.szNetbiosAliases = str_list_make(pszParmValue, NULL);
2746 return set_netbios_aliases((const char **)Globals.szNetbiosAliases);
2749 /***************************************************************************
2750 Do the work of sourcing in environment variable/value pairs.
2751 ***************************************************************************/
2753 static BOOL source_env(char **lines)
2755 char *varval;
2756 size_t len;
2757 int i;
2758 char *p;
2760 for (i = 0; lines[i]; i++) {
2761 char *line = lines[i];
2763 if ((len = strlen(line)) == 0)
2764 continue;
2766 if (line[len - 1] == '\n')
2767 line[--len] = '\0';
2769 if ((varval = malloc(len + 1)) == NULL) {
2770 DEBUG(0, ("source_env: Not enough memory!\n"));
2771 return (False);
2774 DEBUG(4, ("source_env: Adding to environment: %s\n", line));
2775 strncpy(varval, line, len);
2776 varval[len] = '\0';
2778 p = strchr_m(line, (int)'=');
2779 if (p == NULL) {
2780 DEBUG(4, ("source_env: missing '=': %s\n", line));
2781 continue;
2784 if (putenv(varval)) {
2785 DEBUG(0, ("source_env: Failed to put environment variable %s\n",
2786 varval));
2787 continue;
2790 *p = '\0';
2791 p++;
2792 DEBUG(4, ("source_env: getting var %s = %s\n", line, getenv(line)));
2795 DEBUG(4, ("source_env: returning successfully\n"));
2796 return (True);
2799 /***************************************************************************
2800 Handle the source environment operation.
2801 ***************************************************************************/
2803 static BOOL handle_source_env(const char *pszParmValue, char **ptr)
2805 pstring fname;
2806 char *p = fname;
2807 BOOL result;
2808 char **lines;
2810 pstrcpy(fname, pszParmValue);
2812 standard_sub_basic(current_user_info.smb_name, fname,sizeof(fname));
2814 string_set(ptr, pszParmValue);
2816 DEBUG(4, ("handle_source_env: checking env type\n"));
2819 * Filename starting with '|' means popen and read from stdin.
2822 if (*p == '|')
2823 lines = file_lines_pload(p + 1, NULL);
2824 else
2825 lines = file_lines_load(fname, NULL);
2827 if (!lines) {
2828 DEBUG(0, ("handle_source_env: Failed to open file %s, Error was %s\n",
2829 fname, strerror(errno)));
2830 return (False);
2833 result = source_env(lines);
2834 file_lines_free(lines);
2836 return (result);
2839 /***************************************************************************
2840 Handle the include operation.
2841 ***************************************************************************/
2843 static BOOL handle_include(const char *pszParmValue, char **ptr)
2845 pstring fname;
2846 pstrcpy(fname, pszParmValue);
2848 standard_sub_basic(current_user_info.smb_name, fname,sizeof(fname));
2850 add_to_file_list(pszParmValue, fname);
2852 string_set(ptr, fname);
2854 if (file_exist(fname, NULL))
2855 return (pm_process(fname, do_section, do_parameter));
2857 DEBUG(2, ("Can't find include file %s\n", fname));
2859 return (False);
2862 /***************************************************************************
2863 Handle the interpretation of the copy parameter.
2864 ***************************************************************************/
2866 static BOOL handle_copy(const char *pszParmValue, char **ptr)
2868 BOOL bRetval;
2869 int iTemp;
2870 service serviceTemp;
2872 string_set(ptr, pszParmValue);
2874 init_service(&serviceTemp);
2876 bRetval = False;
2878 DEBUG(3, ("Copying service from service %s\n", pszParmValue));
2880 if ((iTemp = getservicebyname(pszParmValue, &serviceTemp)) >= 0) {
2881 if (iTemp == iServiceIndex) {
2882 DEBUG(0, ("Can't copy service %s - unable to copy self!\n", pszParmValue));
2883 } else {
2884 copy_service(ServicePtrs[iServiceIndex],
2885 &serviceTemp,
2886 ServicePtrs[iServiceIndex]->copymap);
2887 bRetval = True;
2889 } else {
2890 DEBUG(0, ("Unable to copy service - source not found: %s\n", pszParmValue));
2891 bRetval = False;
2894 free_service(&serviceTemp);
2895 return (bRetval);
2898 /***************************************************************************
2899 Handle idmap/non unix account uid and gid allocation parameters. The format of these
2900 parameters is:
2902 [global]
2904 idmap uid = 1000-1999
2905 idmap gid = 700-899
2907 We only do simple parsing checks here. The strings are parsed into useful
2908 structures in the idmap daemon code.
2910 ***************************************************************************/
2912 /* Some lp_ routines to return idmap [ug]id information */
2914 static uid_t idmap_uid_low, idmap_uid_high;
2915 static gid_t idmap_gid_low, idmap_gid_high;
2917 BOOL lp_idmap_uid(uid_t *low, uid_t *high)
2919 if (idmap_uid_low == 0 || idmap_uid_high == 0)
2920 return False;
2922 if (low)
2923 *low = idmap_uid_low;
2925 if (high)
2926 *high = idmap_uid_high;
2928 return True;
2931 BOOL lp_idmap_gid(gid_t *low, gid_t *high)
2933 if (idmap_gid_low == 0 || idmap_gid_high == 0)
2934 return False;
2936 if (low)
2937 *low = idmap_gid_low;
2939 if (high)
2940 *high = idmap_gid_high;
2942 return True;
2945 /* Do some simple checks on "idmap [ug]id" parameter values */
2947 static BOOL handle_idmap_uid(const char *pszParmValue, char **ptr)
2949 uint32 low, high;
2951 if (sscanf(pszParmValue, "%u-%u", &low, &high) != 2 || high < low)
2952 return False;
2954 /* Parse OK */
2956 string_set(ptr, pszParmValue);
2958 idmap_uid_low = low;
2959 idmap_uid_high = high;
2961 return True;
2964 static BOOL handle_idmap_gid(const char *pszParmValue, char **ptr)
2966 uint32 low, high;
2968 if (sscanf(pszParmValue, "%u-%u", &low, &high) != 2 || high < low)
2969 return False;
2971 /* Parse OK */
2973 string_set(ptr, pszParmValue);
2975 idmap_gid_low = low;
2976 idmap_gid_high = high;
2978 return True;
2981 /***************************************************************************
2982 Handle the DEBUG level list.
2983 ***************************************************************************/
2985 static BOOL handle_debug_list( const char *pszParmValueIn, char **ptr )
2987 pstring pszParmValue;
2989 pstrcpy(pszParmValue, pszParmValueIn);
2990 string_set(ptr, pszParmValueIn);
2991 return debug_parse_levels( pszParmValue );
2994 /***************************************************************************
2995 Handle setting ldap suffix and determines whether ldap machine suffix needs
2996 to be set as well.
2998 Set all of the sub suffix strings to be the 'ldap suffix' by default
2999 ***************************************************************************/
3001 static BOOL handle_ldap_suffix( const char *pszParmValue, char **ptr )
3003 pstring suffix;
3005 pstrcpy(suffix, pszParmValue);
3007 /* set defaults for the the sub-suffixes */
3009 if (! *Globals.szLdapMachineSuffix )
3010 string_set(&Globals.szLdapMachineSuffix, suffix);
3011 if (! *Globals.szLdapUserSuffix )
3012 string_set(&Globals.szLdapUserSuffix, suffix);
3013 if (! *Globals.szLdapGroupSuffix )
3014 string_set(&Globals.szLdapGroupSuffix, suffix);
3015 if (! *Globals.szLdapIdmapSuffix )
3016 string_set(&Globals.szLdapIdmapSuffix, suffix);
3018 string_set(ptr, suffix);
3019 return True;
3022 /***************************************************************************
3023 Handle the ldap sub suffix option.
3024 Always append the 'ldap suffix' if it is set
3025 ***************************************************************************/
3027 static BOOL handle_ldap_sub_suffix( const char *pszParmValue, char **ptr)
3029 pstring suffix;
3031 pstrcpy(suffix, pszParmValue);
3033 if (! *Globals.szLdapSuffix ) {
3034 string_set( ptr, suffix );
3035 return True;
3037 else {
3038 if ( *pszParmValue )
3039 pstrcat(suffix, ",");
3040 pstrcat(suffix, Globals.szLdapSuffix);
3043 string_set( ptr, suffix );
3044 return True;
3047 /***************************************************************************
3048 ***************************************************************************/
3050 static BOOL handle_acl_compatibility(const char *pszParmValue, char **ptr)
3052 if (strequal(pszParmValue, "auto"))
3053 string_set(ptr, "");
3054 else if (strequal(pszParmValue, "winnt"))
3055 string_set(ptr, "winnt");
3056 else if (strequal(pszParmValue, "win2k"))
3057 string_set(ptr, "win2k");
3058 else
3059 return False;
3061 return True;
3064 /***************************************************************************
3065 Initialise a copymap.
3066 ***************************************************************************/
3068 static void init_copymap(service * pservice)
3070 int i;
3071 SAFE_FREE(pservice->copymap);
3072 pservice->copymap = (BOOL *)malloc(sizeof(BOOL) * NUMPARAMETERS);
3073 if (!pservice->copymap)
3074 DEBUG(0,
3075 ("Couldn't allocate copymap!! (size %d)\n",
3076 (int)NUMPARAMETERS));
3077 else
3078 for (i = 0; i < NUMPARAMETERS; i++)
3079 pservice->copymap[i] = True;
3082 /***************************************************************************
3083 Return the local pointer to a parameter given the service number and the
3084 pointer into the default structure.
3085 ***************************************************************************/
3087 void *lp_local_ptr(int snum, void *ptr)
3089 return (void *)(((char *)ServicePtrs[snum]) + PTR_DIFF(ptr, &sDefault));
3092 /***************************************************************************
3093 Process a parameter for a particular service number. If snum < 0
3094 then assume we are in the globals.
3095 ***************************************************************************/
3097 BOOL lp_do_parameter(int snum, const char *pszParmName, const char *pszParmValue)
3099 int parmnum, i, slen;
3100 void *parm_ptr = NULL; /* where we are going to store the result */
3101 void *def_ptr = NULL;
3102 pstring param_key;
3103 char *sep;
3104 param_opt_struct *paramo, *data;
3105 BOOL not_added;
3107 parmnum = map_parameter(pszParmName);
3109 if (parmnum < 0) {
3110 if ((sep=strchr(pszParmName, ':')) != NULL) {
3111 *sep = '\0';
3112 ZERO_STRUCT(param_key);
3113 pstr_sprintf(param_key, "%s:", pszParmName);
3114 slen = strlen(param_key);
3115 pstrcat(param_key, sep+1);
3116 trim_char(param_key+slen, ' ', ' ');
3117 not_added = True;
3118 data = (snum < 0) ? Globals.param_opt :
3119 ServicePtrs[snum]->param_opt;
3120 /* Traverse destination */
3121 while (data) {
3122 /* If we already have same option, override it */
3123 if (strcmp(data->key, param_key) == 0) {
3124 string_free(&data->value);
3125 str_list_free(&data->list);
3126 data->value = strdup(pszParmValue);
3127 not_added = False;
3128 break;
3130 data = data->next;
3132 if (not_added) {
3133 paramo = smb_xmalloc(sizeof(param_opt_struct));
3134 paramo->key = strdup(param_key);
3135 paramo->value = strdup(pszParmValue);
3136 paramo->list = NULL;
3137 if (snum < 0) {
3138 DLIST_ADD(Globals.param_opt, paramo);
3139 } else {
3140 DLIST_ADD(ServicePtrs[snum]->param_opt, paramo);
3144 *sep = ':';
3145 return (True);
3147 DEBUG(0, ("Ignoring unknown parameter \"%s\"\n", pszParmName));
3148 return (True);
3151 if (parm_table[parmnum].flags & FLAG_DEPRECATED) {
3152 DEBUG(1, ("WARNING: The \"%s\" option is deprecated\n",
3153 pszParmName));
3156 def_ptr = parm_table[parmnum].ptr;
3158 /* we might point at a service, the default service or a global */
3159 if (snum < 0) {
3160 parm_ptr = def_ptr;
3161 } else {
3162 if (parm_table[parmnum].class == P_GLOBAL) {
3163 DEBUG(0,
3164 ("Global parameter %s found in service section!\n",
3165 pszParmName));
3166 return (True);
3168 parm_ptr =
3169 ((char *)ServicePtrs[snum]) + PTR_DIFF(def_ptr,
3170 &sDefault);
3173 if (snum >= 0) {
3174 if (!ServicePtrs[snum]->copymap)
3175 init_copymap(ServicePtrs[snum]);
3177 /* this handles the aliases - set the copymap for other entries with
3178 the same data pointer */
3179 for (i = 0; parm_table[i].label; i++)
3180 if (parm_table[i].ptr == parm_table[parmnum].ptr)
3181 ServicePtrs[snum]->copymap[i] = False;
3184 /* if it is a special case then go ahead */
3185 if (parm_table[parmnum].special) {
3186 parm_table[parmnum].special(pszParmValue, (char **)parm_ptr);
3187 return (True);
3190 /* now switch on the type of variable it is */
3191 switch (parm_table[parmnum].type)
3193 case P_BOOL:
3194 set_boolean(parm_ptr, pszParmValue);
3195 break;
3197 case P_BOOLREV:
3198 set_boolean(parm_ptr, pszParmValue);
3199 *(BOOL *)parm_ptr = !*(BOOL *)parm_ptr;
3200 break;
3202 case P_INTEGER:
3203 *(int *)parm_ptr = atoi(pszParmValue);
3204 break;
3206 case P_CHAR:
3207 *(char *)parm_ptr = *pszParmValue;
3208 break;
3210 case P_OCTAL:
3211 sscanf(pszParmValue, "%o", (int *)parm_ptr);
3212 break;
3214 case P_LIST:
3215 str_list_free(parm_ptr);
3216 *(char ***)parm_ptr = str_list_make(pszParmValue, NULL);
3217 break;
3219 case P_STRING:
3220 string_set(parm_ptr, pszParmValue);
3221 break;
3223 case P_USTRING:
3224 string_set(parm_ptr, pszParmValue);
3225 strupper_m(*(char **)parm_ptr);
3226 break;
3228 case P_GSTRING:
3229 pstrcpy((char *)parm_ptr, pszParmValue);
3230 break;
3232 case P_UGSTRING:
3233 pstrcpy((char *)parm_ptr, pszParmValue);
3234 strupper_m((char *)parm_ptr);
3235 break;
3237 case P_ENUM:
3238 for (i = 0; parm_table[parmnum].enum_list[i].name; i++) {
3239 if (strequal
3240 (pszParmValue,
3241 parm_table[parmnum].enum_list[i].name)) {
3242 *(int *)parm_ptr =
3243 parm_table[parmnum].
3244 enum_list[i].value;
3245 break;
3248 break;
3249 case P_SEP:
3250 break;
3253 return (True);
3256 /***************************************************************************
3257 Process a parameter.
3258 ***************************************************************************/
3260 static BOOL do_parameter(const char *pszParmName, const char *pszParmValue)
3262 if (!bInGlobalSection && bGlobalOnly)
3263 return (True);
3265 DEBUGADD(4, ("doing parameter %s = %s\n", pszParmName, pszParmValue));
3267 return (lp_do_parameter(bInGlobalSection ? -2 : iServiceIndex,
3268 pszParmName, pszParmValue));
3271 /***************************************************************************
3272 Print a parameter of the specified type.
3273 ***************************************************************************/
3275 static void print_parameter(struct parm_struct *p, void *ptr, FILE * f)
3277 int i;
3278 switch (p->type)
3280 case P_ENUM:
3281 for (i = 0; p->enum_list[i].name; i++) {
3282 if (*(int *)ptr == p->enum_list[i].value) {
3283 fprintf(f, "%s",
3284 p->enum_list[i].name);
3285 break;
3288 break;
3290 case P_BOOL:
3291 fprintf(f, "%s", BOOLSTR(*(BOOL *)ptr));
3292 break;
3294 case P_BOOLREV:
3295 fprintf(f, "%s", BOOLSTR(!*(BOOL *)ptr));
3296 break;
3298 case P_INTEGER:
3299 fprintf(f, "%d", *(int *)ptr);
3300 break;
3302 case P_CHAR:
3303 fprintf(f, "%c", *(char *)ptr);
3304 break;
3306 case P_OCTAL:
3307 fprintf(f, "%s", octal_string(*(int *)ptr));
3308 break;
3310 case P_LIST:
3311 if ((char ***)ptr && *(char ***)ptr) {
3312 char **list = *(char ***)ptr;
3314 for (; *list; list++)
3315 fprintf(f, "%s%s", *list,
3316 ((*(list+1))?", ":""));
3318 break;
3320 case P_GSTRING:
3321 case P_UGSTRING:
3322 if ((char *)ptr) {
3323 fprintf(f, "%s", (char *)ptr);
3325 break;
3327 case P_STRING:
3328 case P_USTRING:
3329 if (*(char **)ptr) {
3330 fprintf(f, "%s", *(char **)ptr);
3332 break;
3333 case P_SEP:
3334 break;
3338 /***************************************************************************
3339 Check if two parameters are equal.
3340 ***************************************************************************/
3342 static BOOL equal_parameter(parm_type type, void *ptr1, void *ptr2)
3344 switch (type) {
3345 case P_BOOL:
3346 case P_BOOLREV:
3347 return (*((BOOL *)ptr1) == *((BOOL *)ptr2));
3349 case P_INTEGER:
3350 case P_ENUM:
3351 case P_OCTAL:
3352 return (*((int *)ptr1) == *((int *)ptr2));
3354 case P_CHAR:
3355 return (*((char *)ptr1) == *((char *)ptr2));
3357 case P_LIST:
3358 return str_list_compare(*(char ***)ptr1, *(char ***)ptr2);
3360 case P_GSTRING:
3361 case P_UGSTRING:
3363 char *p1 = (char *)ptr1, *p2 = (char *)ptr2;
3364 if (p1 && !*p1)
3365 p1 = NULL;
3366 if (p2 && !*p2)
3367 p2 = NULL;
3368 return (p1 == p2 || strequal(p1, p2));
3370 case P_STRING:
3371 case P_USTRING:
3373 char *p1 = *(char **)ptr1, *p2 = *(char **)ptr2;
3374 if (p1 && !*p1)
3375 p1 = NULL;
3376 if (p2 && !*p2)
3377 p2 = NULL;
3378 return (p1 == p2 || strequal(p1, p2));
3380 case P_SEP:
3381 break;
3383 return (False);
3386 /***************************************************************************
3387 Initialize any local varients in the sDefault table.
3388 ***************************************************************************/
3390 void init_locals(void)
3392 /* None as yet. */
3395 /***************************************************************************
3396 Process a new section (service). At this stage all sections are services.
3397 Later we'll have special sections that permit server parameters to be set.
3398 Returns True on success, False on failure.
3399 ***************************************************************************/
3401 static BOOL do_section(const char *pszSectionName)
3403 BOOL bRetval;
3404 BOOL isglobal = ((strwicmp(pszSectionName, GLOBAL_NAME) == 0) ||
3405 (strwicmp(pszSectionName, GLOBAL_NAME2) == 0));
3406 bRetval = False;
3408 /* if we were in a global section then do the local inits */
3409 if (bInGlobalSection && !isglobal)
3410 init_locals();
3412 /* if we've just struck a global section, note the fact. */
3413 bInGlobalSection = isglobal;
3415 /* check for multiple global sections */
3416 if (bInGlobalSection) {
3417 DEBUG(3, ("Processing section \"[%s]\"\n", pszSectionName));
3418 return (True);
3421 if (!bInGlobalSection && bGlobalOnly)
3422 return (True);
3424 /* if we have a current service, tidy it up before moving on */
3425 bRetval = True;
3427 if (iServiceIndex >= 0)
3428 bRetval = service_ok(iServiceIndex);
3430 /* if all is still well, move to the next record in the services array */
3431 if (bRetval) {
3432 /* We put this here to avoid an odd message order if messages are */
3433 /* issued by the post-processing of a previous section. */
3434 DEBUG(2, ("Processing section \"[%s]\"\n", pszSectionName));
3436 if ((iServiceIndex = add_a_service(&sDefault, pszSectionName))
3437 < 0) {
3438 DEBUG(0, ("Failed to add a new service\n"));
3439 return (False);
3443 return (bRetval);
3447 /***************************************************************************
3448 Determine if a partcular base parameter is currentl set to the default value.
3449 ***************************************************************************/
3451 static BOOL is_default(int i)
3453 if (!defaults_saved)
3454 return False;
3455 switch (parm_table[i].type) {
3456 case P_LIST:
3457 return str_list_compare (parm_table[i].def.lvalue,
3458 *(char ***)parm_table[i].ptr);
3459 case P_STRING:
3460 case P_USTRING:
3461 return strequal(parm_table[i].def.svalue,
3462 *(char **)parm_table[i].ptr);
3463 case P_GSTRING:
3464 case P_UGSTRING:
3465 return strequal(parm_table[i].def.svalue,
3466 (char *)parm_table[i].ptr);
3467 case P_BOOL:
3468 case P_BOOLREV:
3469 return parm_table[i].def.bvalue ==
3470 *(BOOL *)parm_table[i].ptr;
3471 case P_CHAR:
3472 return parm_table[i].def.cvalue ==
3473 *(char *)parm_table[i].ptr;
3474 case P_INTEGER:
3475 case P_OCTAL:
3476 case P_ENUM:
3477 return parm_table[i].def.ivalue ==
3478 *(int *)parm_table[i].ptr;
3479 case P_SEP:
3480 break;
3482 return False;
3485 /***************************************************************************
3486 Display the contents of the global structure.
3487 ***************************************************************************/
3489 static void dump_globals(FILE *f)
3491 int i;
3492 param_opt_struct *data;
3494 fprintf(f, "# Global parameters\n[global]\n");
3496 for (i = 0; parm_table[i].label; i++)
3497 if (parm_table[i].class == P_GLOBAL &&
3498 parm_table[i].ptr &&
3499 (i == 0 || (parm_table[i].ptr != parm_table[i - 1].ptr))) {
3500 if (defaults_saved && is_default(i))
3501 continue;
3502 fprintf(f, "\t%s = ", parm_table[i].label);
3503 print_parameter(&parm_table[i], parm_table[i].ptr, f);
3504 fprintf(f, "\n");
3506 if (Globals.param_opt != NULL) {
3507 data = Globals.param_opt;
3508 while(data) {
3509 fprintf(f, "\t%s = %s\n", data->key, data->value);
3510 data = data->next;
3516 /***************************************************************************
3517 Return True if a local parameter is currently set to the global default.
3518 ***************************************************************************/
3520 BOOL lp_is_default(int snum, struct parm_struct *parm)
3522 int pdiff = PTR_DIFF(parm->ptr, &sDefault);
3524 return equal_parameter(parm->type,
3525 ((char *)ServicePtrs[snum]) + pdiff,
3526 ((char *)&sDefault) + pdiff);
3529 /***************************************************************************
3530 Display the contents of a single services record.
3531 ***************************************************************************/
3533 static void dump_a_service(service * pService, FILE * f)
3535 int i;
3536 param_opt_struct *data;
3538 if (pService != &sDefault)
3539 fprintf(f, "\n[%s]\n", pService->szService);
3541 for (i = 0; parm_table[i].label; i++)
3542 if (parm_table[i].class == P_LOCAL &&
3543 parm_table[i].ptr &&
3544 (*parm_table[i].label != '-') &&
3545 (i == 0 || (parm_table[i].ptr != parm_table[i - 1].ptr))) {
3546 int pdiff = PTR_DIFF(parm_table[i].ptr, &sDefault);
3548 if (pService == &sDefault) {
3549 if (defaults_saved && is_default(i))
3550 continue;
3551 } else {
3552 if (equal_parameter(parm_table[i].type,
3553 ((char *)pService) +
3554 pdiff,
3555 ((char *)&sDefault) +
3556 pdiff))
3557 continue;
3560 fprintf(f, "\t%s = ", parm_table[i].label);
3561 print_parameter(&parm_table[i],
3562 ((char *)pService) + pdiff, f);
3563 fprintf(f, "\n");
3565 if (pService->param_opt != NULL) {
3566 data = pService->param_opt;
3567 while(data) {
3568 fprintf(f, "\t%s = %s\n", data->key, data->value);
3569 data = data->next;
3575 /***************************************************************************
3576 Return info about the next service in a service. snum==GLOBAL_SECTION_SNUM gives the globals.
3577 Return NULL when out of parameters.
3578 ***************************************************************************/
3580 struct parm_struct *lp_next_parameter(int snum, int *i, int allparameters)
3582 if (snum < 0) {
3583 /* do the globals */
3584 for (; parm_table[*i].label; (*i)++) {
3585 if (parm_table[*i].class == P_SEPARATOR)
3586 return &parm_table[(*i)++];
3588 if (!parm_table[*i].ptr
3589 || (*parm_table[*i].label == '-'))
3590 continue;
3592 if ((*i) > 0
3593 && (parm_table[*i].ptr ==
3594 parm_table[(*i) - 1].ptr))
3595 continue;
3597 return &parm_table[(*i)++];
3599 } else {
3600 service *pService = ServicePtrs[snum];
3602 for (; parm_table[*i].label; (*i)++) {
3603 if (parm_table[*i].class == P_SEPARATOR)
3604 return &parm_table[(*i)++];
3606 if (parm_table[*i].class == P_LOCAL &&
3607 parm_table[*i].ptr &&
3608 (*parm_table[*i].label != '-') &&
3609 ((*i) == 0 ||
3610 (parm_table[*i].ptr !=
3611 parm_table[(*i) - 1].ptr)))
3613 int pdiff =
3614 PTR_DIFF(parm_table[*i].ptr,
3615 &sDefault);
3617 if (allparameters ||
3618 !equal_parameter(parm_table[*i].type,
3619 ((char *)pService) +
3620 pdiff,
3621 ((char *)&sDefault) +
3622 pdiff))
3624 return &parm_table[(*i)++];
3630 return NULL;
3634 #if 0
3635 /***************************************************************************
3636 Display the contents of a single copy structure.
3637 ***************************************************************************/
3638 static void dump_copy_map(BOOL *pcopymap)
3640 int i;
3641 if (!pcopymap)
3642 return;
3644 printf("\n\tNon-Copied parameters:\n");
3646 for (i = 0; parm_table[i].label; i++)
3647 if (parm_table[i].class == P_LOCAL &&
3648 parm_table[i].ptr && !pcopymap[i] &&
3649 (i == 0 || (parm_table[i].ptr != parm_table[i - 1].ptr)))
3651 printf("\t\t%s\n", parm_table[i].label);
3654 #endif
3656 /***************************************************************************
3657 Return TRUE if the passed service number is within range.
3658 ***************************************************************************/
3660 BOOL lp_snum_ok(int iService)
3662 return (LP_SNUM_OK(iService) && ServicePtrs[iService]->bAvailable);
3665 /***************************************************************************
3666 Auto-load some home services.
3667 ***************************************************************************/
3669 static void lp_add_auto_services(char *str)
3671 char *s;
3672 char *p;
3673 int homes;
3675 if (!str)
3676 return;
3678 s = strdup(str);
3679 if (!s)
3680 return;
3682 homes = lp_servicenumber(HOMES_NAME);
3684 for (p = strtok(s, LIST_SEP); p; p = strtok(NULL, LIST_SEP)) {
3685 char *home = get_user_home_dir(p);
3687 if (lp_servicenumber(p) >= 0)
3688 continue;
3690 if (home && homes >= 0)
3691 lp_add_home(p, homes, p, home);
3693 SAFE_FREE(s);
3696 /***************************************************************************
3697 Auto-load one printer.
3698 ***************************************************************************/
3700 void lp_add_one_printer(char *name, char *comment)
3702 int printers = lp_servicenumber(PRINTERS_NAME);
3703 int i;
3705 if (lp_servicenumber(name) < 0) {
3706 lp_add_printer(name, printers);
3707 if ((i = lp_servicenumber(name)) >= 0) {
3708 string_set(&ServicePtrs[i]->comment, comment);
3709 ServicePtrs[i]->autoloaded = True;
3714 /***************************************************************************
3715 Announce ourselves as a print server.
3716 ***************************************************************************/
3718 void update_server_announce_as_printserver(void)
3720 default_server_announce |= SV_TYPE_PRINTQ_SERVER;
3723 /***************************************************************************
3724 Have we loaded a services file yet?
3725 ***************************************************************************/
3727 BOOL lp_loaded(void)
3729 return (bLoaded);
3732 /***************************************************************************
3733 Unload unused services.
3734 ***************************************************************************/
3736 void lp_killunused(BOOL (*snumused) (int))
3738 int i;
3739 for (i = 0; i < iNumServices; i++) {
3740 if (!VALID(i))
3741 continue;
3743 if (!snumused || !snumused(i)) {
3744 ServicePtrs[i]->valid = False;
3745 free_service(ServicePtrs[i]);
3750 /***************************************************************************
3751 Unload a service.
3752 ***************************************************************************/
3754 void lp_killservice(int iServiceIn)
3756 if (VALID(iServiceIn)) {
3757 ServicePtrs[iServiceIn]->valid = False;
3758 free_service(ServicePtrs[iServiceIn]);
3762 /***************************************************************************
3763 Save the curent values of all global and sDefault parameters into the
3764 defaults union. This allows swat and testparm to show only the
3765 changed (ie. non-default) parameters.
3766 ***************************************************************************/
3768 static void lp_save_defaults(void)
3770 int i;
3771 for (i = 0; parm_table[i].label; i++) {
3772 if (i > 0 && parm_table[i].ptr == parm_table[i - 1].ptr)
3773 continue;
3774 switch (parm_table[i].type) {
3775 case P_LIST:
3776 str_list_copy(&(parm_table[i].def.lvalue),
3777 *(const char ***)parm_table[i].ptr);
3778 break;
3779 case P_STRING:
3780 case P_USTRING:
3781 if (parm_table[i].ptr) {
3782 parm_table[i].def.svalue = strdup(*(char **)parm_table[i].ptr);
3783 } else {
3784 parm_table[i].def.svalue = NULL;
3786 break;
3787 case P_GSTRING:
3788 case P_UGSTRING:
3789 if (parm_table[i].ptr) {
3790 parm_table[i].def.svalue = strdup((char *)parm_table[i].ptr);
3791 } else {
3792 parm_table[i].def.svalue = NULL;
3794 break;
3795 case P_BOOL:
3796 case P_BOOLREV:
3797 parm_table[i].def.bvalue =
3798 *(BOOL *)parm_table[i].ptr;
3799 break;
3800 case P_CHAR:
3801 parm_table[i].def.cvalue =
3802 *(char *)parm_table[i].ptr;
3803 break;
3804 case P_INTEGER:
3805 case P_OCTAL:
3806 case P_ENUM:
3807 parm_table[i].def.ivalue =
3808 *(int *)parm_table[i].ptr;
3809 break;
3810 case P_SEP:
3811 break;
3814 defaults_saved = True;
3817 /*******************************************************************
3818 Set the server type we will announce as via nmbd.
3819 ********************************************************************/
3821 static void set_server_role(void)
3823 server_role = ROLE_STANDALONE;
3825 switch (lp_security()) {
3826 case SEC_SHARE:
3827 if (lp_domain_logons())
3828 DEBUG(0, ("Server's Role (logon server) conflicts with share-level security\n"));
3829 break;
3830 case SEC_SERVER:
3831 if (lp_domain_logons())
3832 DEBUG(0, ("Server's Role (logon server) conflicts with server-level security\n"));
3833 server_role = ROLE_DOMAIN_MEMBER;
3834 break;
3835 case SEC_DOMAIN:
3836 if (lp_domain_logons()) {
3837 DEBUG(1, ("Server's Role (logon server) NOT ADVISED with domain-level security\n"));
3838 server_role = ROLE_DOMAIN_BDC;
3839 break;
3841 server_role = ROLE_DOMAIN_MEMBER;
3842 break;
3843 case SEC_ADS:
3844 if (lp_domain_logons()) {
3845 server_role = ROLE_DOMAIN_PDC;
3846 break;
3848 server_role = ROLE_DOMAIN_MEMBER;
3849 break;
3850 case SEC_USER:
3851 if (lp_domain_logons()) {
3853 if (Globals.bDomainMaster) /* auto or yes */
3854 server_role = ROLE_DOMAIN_PDC;
3855 else
3856 server_role = ROLE_DOMAIN_BDC;
3858 break;
3859 default:
3860 DEBUG(0, ("Server's Role undefined due to unknown security mode\n"));
3861 break;
3864 DEBUG(10, ("set_server_role: role = "));
3866 switch(server_role) {
3867 case ROLE_STANDALONE:
3868 DEBUGADD(10, ("ROLE_STANDALONE\n"));
3869 break;
3870 case ROLE_DOMAIN_MEMBER:
3871 DEBUGADD(10, ("ROLE_DOMAIN_MEMBER\n"));
3872 break;
3873 case ROLE_DOMAIN_BDC:
3874 DEBUGADD(10, ("ROLE_DOMAIN_BDC\n"));
3875 break;
3876 case ROLE_DOMAIN_PDC:
3877 DEBUGADD(10, ("ROLE_DOMAIN_PDC\n"));
3878 break;
3882 /***********************************************************
3883 If we should send plaintext/LANMAN passwords in the clinet
3884 ************************************************************/
3885 static void set_allowed_client_auth(void)
3887 if (Globals.bClientNTLMv2Auth) {
3888 Globals.bClientLanManAuth = False;
3890 if (!Globals.bClientLanManAuth) {
3891 Globals.bClientPlaintextAuth = False;
3895 /***************************************************************************
3896 Load the services array from the services file. Return True on success,
3897 False on failure.
3898 ***************************************************************************/
3900 BOOL lp_load(const char *pszFname, BOOL global_only, BOOL save_defaults,
3901 BOOL add_ipc)
3903 pstring n2;
3904 BOOL bRetval;
3905 param_opt_struct *data, *pdata;
3907 pstrcpy(n2, pszFname);
3908 standard_sub_basic(current_user_info.smb_name, n2,sizeof(n2));
3910 add_to_file_list(pszFname, n2);
3912 bRetval = False;
3914 DEBUG(3, ("lp_load: refreshing parameters\n"));
3916 bInGlobalSection = True;
3917 bGlobalOnly = global_only;
3919 init_globals();
3920 debug_init();
3922 if (save_defaults)
3924 init_locals();
3925 lp_save_defaults();
3928 if (Globals.param_opt != NULL) {
3929 data = Globals.param_opt;
3930 while (data) {
3931 string_free(&data->key);
3932 string_free(&data->value);
3933 str_list_free(&data->list);
3934 pdata = data->next;
3935 SAFE_FREE(data);
3936 data = pdata;
3938 Globals.param_opt = NULL;
3941 /* We get sections first, so have to start 'behind' to make up */
3942 iServiceIndex = -1;
3943 bRetval = pm_process(n2, do_section, do_parameter);
3945 /* finish up the last section */
3946 DEBUG(4, ("pm_process() returned %s\n", BOOLSTR(bRetval)));
3947 if (bRetval)
3948 if (iServiceIndex >= 0)
3949 bRetval = service_ok(iServiceIndex);
3951 lp_add_auto_services(lp_auto_services());
3953 if (add_ipc) {
3954 /* When 'restrict anonymous = 2' guest connections to ipc$
3955 are denied */
3956 lp_add_ipc("IPC$", (lp_restrict_anonymous() < 2));
3957 lp_add_ipc("ADMIN$", False);
3960 set_server_role();
3961 set_default_server_announce_type();
3962 set_allowed_client_auth();
3964 bLoaded = True;
3966 /* Now we check bWINSsupport and set szWINSserver to 127.0.0.1 */
3967 /* if bWINSsupport is true and we are in the client */
3968 if (in_client && Globals.bWINSsupport) {
3969 lp_do_parameter(GLOBAL_SECTION_SNUM, "wins server", "127.0.0.1");
3972 init_iconv();
3974 return (bRetval);
3977 /***************************************************************************
3978 Reset the max number of services.
3979 ***************************************************************************/
3981 void lp_resetnumservices(void)
3983 iNumServices = 0;
3986 /***************************************************************************
3987 Return the max number of services.
3988 ***************************************************************************/
3990 int lp_numservices(void)
3992 return (iNumServices);
3995 /***************************************************************************
3996 Display the contents of the services array in human-readable form.
3997 ***************************************************************************/
3999 void lp_dump(FILE *f, BOOL show_defaults, int maxtoprint)
4001 int iService;
4003 if (show_defaults)
4004 defaults_saved = False;
4006 dump_globals(f);
4008 dump_a_service(&sDefault, f);
4010 for (iService = 0; iService < maxtoprint; iService++)
4011 lp_dump_one(f, show_defaults, iService);
4014 /***************************************************************************
4015 Display the contents of one service in human-readable form.
4016 ***************************************************************************/
4018 void lp_dump_one(FILE * f, BOOL show_defaults, int snum)
4020 if (VALID(snum)) {
4021 if (ServicePtrs[snum]->szService[0] == '\0')
4022 return;
4023 dump_a_service(ServicePtrs[snum], f);
4027 /***************************************************************************
4028 Return the number of the service with the given name, or -1 if it doesn't
4029 exist. Note that this is a DIFFERENT ANIMAL from the internal function
4030 getservicebyname()! This works ONLY if all services have been loaded, and
4031 does not copy the found service.
4032 ***************************************************************************/
4034 int lp_servicenumber(const char *pszServiceName)
4036 int iService;
4037 fstring serviceName;
4039 if (!pszServiceName)
4040 return GLOBAL_SECTION_SNUM;
4042 for (iService = iNumServices - 1; iService >= 0; iService--) {
4043 if (VALID(iService) && ServicePtrs[iService]->szService) {
4045 * The substitution here is used to support %U is
4046 * service names
4048 fstrcpy(serviceName, ServicePtrs[iService]->szService);
4049 standard_sub_basic(current_user_info.smb_name, serviceName,sizeof(serviceName));
4050 if (strequal(serviceName, pszServiceName))
4051 break;
4055 if (iService < 0) {
4056 DEBUG(7,("lp_servicenumber: couldn't find %s\n", pszServiceName));
4057 return GLOBAL_SECTION_SNUM;
4060 return (iService);
4063 /*******************************************************************
4064 A useful volume label function.
4065 ********************************************************************/
4067 char *volume_label(int snum)
4069 char *ret = lp_volume(snum);
4070 if (!*ret)
4071 return lp_servicename(snum);
4072 return (ret);
4076 /*******************************************************************
4077 Set the server type we will announce as via nmbd.
4078 ********************************************************************/
4080 static void set_default_server_announce_type(void)
4082 default_server_announce = 0;
4083 default_server_announce |= SV_TYPE_WORKSTATION;
4084 default_server_announce |= SV_TYPE_SERVER;
4085 default_server_announce |= SV_TYPE_SERVER_UNIX;
4087 switch (lp_announce_as()) {
4088 case ANNOUNCE_AS_NT_SERVER:
4089 default_server_announce |= SV_TYPE_SERVER_NT;
4090 /* fall through... */
4091 case ANNOUNCE_AS_NT_WORKSTATION:
4092 default_server_announce |= SV_TYPE_NT;
4093 break;
4094 case ANNOUNCE_AS_WIN95:
4095 default_server_announce |= SV_TYPE_WIN95_PLUS;
4096 break;
4097 case ANNOUNCE_AS_WFW:
4098 default_server_announce |= SV_TYPE_WFW;
4099 break;
4100 default:
4101 break;
4104 switch (lp_server_role()) {
4105 case ROLE_DOMAIN_MEMBER:
4106 default_server_announce |= SV_TYPE_DOMAIN_MEMBER;
4107 break;
4108 case ROLE_DOMAIN_PDC:
4109 default_server_announce |= SV_TYPE_DOMAIN_CTRL;
4110 break;
4111 case ROLE_DOMAIN_BDC:
4112 default_server_announce |= SV_TYPE_DOMAIN_BAKCTRL;
4113 break;
4114 case ROLE_STANDALONE:
4115 default:
4116 break;
4118 if (lp_time_server())
4119 default_server_announce |= SV_TYPE_TIME_SOURCE;
4121 if (lp_host_msdfs())
4122 default_server_announce |= SV_TYPE_DFS_SERVER;
4125 /***********************************************************
4126 returns role of Samba server
4127 ************************************************************/
4129 int lp_server_role(void)
4131 return server_role;
4134 /***********************************************************
4135 If we are PDC then prefer us as DMB
4136 ************************************************************/
4138 BOOL lp_domain_master(void)
4140 if (Globals.bDomainMaster == Auto)
4141 return (lp_server_role() == ROLE_DOMAIN_PDC);
4143 return Globals.bDomainMaster;
4146 /***********************************************************
4147 If we are DMB then prefer us as LMB
4148 ************************************************************/
4150 BOOL lp_preferred_master(void)
4152 if (Globals.bPreferredMaster == Auto)
4153 return (lp_local_master() && lp_domain_master());
4155 return Globals.bPreferredMaster;
4158 /*******************************************************************
4159 Remove a service.
4160 ********************************************************************/
4162 void lp_remove_service(int snum)
4164 ServicePtrs[snum]->valid = False;
4167 /*******************************************************************
4168 Copy a service.
4169 ********************************************************************/
4171 void lp_copy_service(int snum, const char *new_name)
4173 do_section(new_name);
4174 if (snum >= 0) {
4175 snum = lp_servicenumber(new_name);
4176 if (snum >= 0)
4177 lp_do_parameter(snum, "copy", lp_servicename(snum));
4182 /*******************************************************************
4183 Get the default server type we will announce as via nmbd.
4184 ********************************************************************/
4186 int lp_default_server_announce(void)
4188 return default_server_announce;
4191 /*******************************************************************
4192 Split the announce version into major and minor numbers.
4193 ********************************************************************/
4195 int lp_major_announce_version(void)
4197 static BOOL got_major = False;
4198 static int major_version = DEFAULT_MAJOR_VERSION;
4199 char *vers;
4200 char *p;
4202 if (got_major)
4203 return major_version;
4205 got_major = True;
4206 if ((vers = lp_announce_version()) == NULL)
4207 return major_version;
4209 if ((p = strchr_m(vers, '.')) == 0)
4210 return major_version;
4212 *p = '\0';
4213 major_version = atoi(vers);
4214 return major_version;
4217 int lp_minor_announce_version(void)
4219 static BOOL got_minor = False;
4220 static int minor_version = DEFAULT_MINOR_VERSION;
4221 char *vers;
4222 char *p;
4224 if (got_minor)
4225 return minor_version;
4227 got_minor = True;
4228 if ((vers = lp_announce_version()) == NULL)
4229 return minor_version;
4231 if ((p = strchr_m(vers, '.')) == 0)
4232 return minor_version;
4234 p++;
4235 minor_version = atoi(p);
4236 return minor_version;
4239 /***********************************************************
4240 Set the global name resolution order (used in smbclient).
4241 ************************************************************/
4243 void lp_set_name_resolve_order(char *new_order)
4245 Globals.szNameResolveOrder = new_order;
4248 const char *lp_printername(int snum)
4250 const char *ret = _lp_printername(snum);
4251 if (ret == NULL || (ret != NULL && *ret == '\0'))
4252 ret = lp_const_servicename(snum);
4254 return ret;
4258 /****************************************************************
4259 Compatibility fn. for 2.2.2 code.....
4260 *****************************************************************/
4262 void get_private_directory(pstring privdir)
4264 pstrcpy (privdir, lp_private_dir());
4267 /***********************************************************
4268 Allow daemons such as winbindd to fix their logfile name.
4269 ************************************************************/
4271 void lp_set_logfile(const char *name)
4273 extern pstring debugf;
4274 string_set(&Globals.szLogFile, name);
4275 pstrcpy(debugf, name);
4278 /*******************************************************************
4279 Return the NetBIOS called name, or my IP - but never global_myname().
4280 ********************************************************************/
4282 const char *get_called_name(void)
4284 extern fstring local_machine;
4285 static fstring called_name;
4287 if (!*local_machine) {
4288 fstrcpy(called_name, get_my_primary_ip());
4289 DEBUG(8,("get_called_name: assuming that client used IP address [%s] as called name.\n",
4290 called_name));
4291 return called_name;
4294 return local_machine;
4297 /*******************************************************************
4298 Return the max print jobs per queue.
4299 ********************************************************************/
4301 int lp_maxprintjobs(int snum)
4303 int maxjobs = LP_SNUM_OK(snum) ? ServicePtrs[snum]->iMaxPrintJobs : sDefault.iMaxPrintJobs;
4304 if (maxjobs <= 0 || maxjobs >= PRINT_MAX_JOBID)
4305 maxjobs = PRINT_MAX_JOBID - 1;
4307 return maxjobs;
4310 /*******************************************************************
4311 Ensure we don't use sendfile if server smb signing is active.
4312 ********************************************************************/
4314 BOOL lp_use_sendfile(int snum)
4316 return (_lp_use_sendfile(snum) && !srv_is_signing_active());