465e0029b6ae7dba89512f176a50a008bd3fb7c6
[kai/samba.git] / source3 / include / local.h
1 /* local definitions for file server */
2 #ifndef _LOCAL_H
3 #define _LOCAL_H
4
5 /* This defines the section name in the configuration file that will contain */
6 /* global parameters - that is, parameters relating to the whole server, not */
7 /* just services. This name is then reserved, and may not be used as a       */
8 /* a service name. It will default to "global" if not defined here.          */
9 #define GLOBAL_NAME "global"
10 #define GLOBAL_NAME2 "globals"
11
12 /* This defines the section name in the configuration file that will
13    refer to the special "homes" service */
14 #define HOMES_NAME "homes"
15
16 /* This defines the section name in the configuration file that will
17    refer to the special "printers" service */
18 #define PRINTERS_NAME "printers"
19
20 /* This defines the name of the printcap file. It is MOST UNLIKELY that
21    this will change BUT! Specifying a file with the format of a printcap
22    file but containing only a subset of the printers actually in your real 
23    printcap file is a quick-n-dirty way to allow dynamic access to a subset
24    of available printers.
25 */
26 #define PRINTCAP_NAME "/etc/printcap"
27
28 /* set these to define the limits of the server. NOTE These are on a
29    per-client basis. Thus any one machine can't connect to more than
30    MAX_CONNECTIONS services, but any number of machines may connect at
31    one time. */
32 #define MAX_CONNECTIONS 127
33 #define MAX_OPEN_FILES 100
34
35 /* the max number of connections that the smbstatus program will show */
36 #define MAXSTATUS 1000
37
38 /* max number of directories open at once */
39 /* note that with the new directory code this no longer requires a
40    file handle per directory, but large numbers do use more memory */
41 #define MAXDIR 64
42
43 #define WORDMAX 0xFFFF
44
45
46 /* separators for lists */
47 #define LIST_SEP " \t,;:\n\r"
48
49 #ifndef LOCKDIR
50 #define LOCKDIR "/tmp/samba"
51 #endif
52
53 /* this is where browse lists are kept in the lock dir */
54 #define SERVER_LIST "browse.dat"
55
56 /* shall guest entries in printer queues get changed to user entries,
57    so they can be deleted using the windows print manager? */
58 #define LPQ_GUEST_TO_USER
59
60 /* shall filenames with illegal chars in them get mangled in long
61    filename listings? */
62 #define MANGLE_LONG_FILENAMES 
63
64 /* define this if you want to stop spoofing with .. and soft links
65    NOTE: This also slows down the server considerably */
66 #define REDUCE_PATHS
67
68 /* the size of the directory cache */
69 #define DIRCACHESIZE 20
70
71 /* what type of filesystem do we want this to show up as in a NT file
72    manager window? */
73 #define FSTYPE_STRING "Samba"
74
75 /* do you want smbd to send a 1 byte packet to nmbd to trigger it to start 
76    when smbd starts? */
77 #ifndef PRIME_NMBD
78 #define PRIME_NMBD 1
79 #endif
80
81 /* do you want session setups at user level security with a invalid
82    password to be rejected or allowed in as guest? WinNT rejects them
83    but it can be a pain as it means "net view" needs to use a password 
84
85    You have 3 choices:
86
87    GUEST_SESSSETUP = 0 means session setups with an invalid password
88    are rejected.
89
90    GUEST_SESSSETUP = 1 means session setups with an invalid password
91    are rejected, unless the username does not exist, in which case it
92    is treated as a guest login
93
94    GUEST_SESSSETUP = 2 means session setups with an invalid password
95    are treated as a guest login
96
97    Note that GUEST_SESSSETUP only has an effect in user or server
98    level security.
99    */
100 #ifndef GUEST_SESSSETUP
101 #define GUEST_SESSSETUP 0
102 #endif
103
104 /* the default pager to use for the client "more" command. Users can
105    override this with the PAGER environment variable */
106 #ifndef PAGER
107 #define PAGER "more"
108 #endif
109
110 /* the size of the uid cache used to reduce valid user checks */
111 #define UID_CACHE_SIZE 4
112
113 /* the following control timings of various actions. Don't change 
114    them unless you know what you are doing. These are all in seconds */
115 #define DEFAULT_SMBD_TIMEOUT (60*60*24*7)
116 #define SMBD_RELOAD_CHECK (10)
117 #define SHARE_MODES_CHECK (10)
118 #define SHARE_MODES_CLEAN (300)
119 #define IDLE_CLOSED_TIMEOUT (60)
120 #define DPTR_IDLE_TIMEOUT (120)
121 #define SMBD_SELECT_LOOP (10)
122 #define NMBD_SELECT_LOOP (10)
123 #define BROWSE_INTERVAL (60)
124 #define REGISTRATION_INTERVAL (10*60)
125 #define NMBD_INETD_TIMEOUT (120)
126 #define NMBD_MAX_TTL (24*60*60)
127 #define LPQ_LOCK_TIMEOUT (5)
128
129 /* the following are in milliseconds */
130 #define LOCK_RETRY_TIMEOUT (100)
131
132 /* do you want to dump core (carefully!) when an internal error is
133    encountered? Samba will be careful to make the core file only
134    accessible to root */
135 #define DUMP_CORE 1
136
137 /* what is the longest significant password available on your system? 
138  Knowing this speeds up password searches a lot */
139 #ifndef PASSWORD_LENGTH
140 #define PASSWORD_LENGTH 8
141 #endif
142
143 #define SMB_ALIGNMENT 1
144
145
146 /* shall we support browse requests via a FIFO to nmbd? */
147 #define ENABLE_FIFO 1
148
149 /* keep the password server open, this uses up a aocket, but is needed
150    by many apps */
151 #define KEEP_PASSWORD_SERVER_OPEN 1
152
153 /* how long to wait for a socket connect to happen */
154 #define LONG_CONNECT_TIMEOUT 30
155 #define SHORT_CONNECT_TIMEOUT 5
156
157
158 /* the directory to sit in when idle */
159 #define IDLE_DIR "/"
160
161 #endif