s3-rpc_server: run minimal_includes.pl.
[samba.git] / source3 / include / local.h
1 /* Copyright (C) 1995-1998 Samba-Team */
2 /* Copyright (C) 1998 John H Terpstra <jht@aquasoft.com.au> */
3
4 /* local definitions for file server */
5 #ifndef _LOCAL_H
6 #define _LOCAL_H
7
8 /* The default workgroup - usually overridden in smb.conf */
9 #ifndef WORKGROUP
10 #define WORKGROUP "WORKGROUP"
11 #endif
12
13 /* This defines the section name in the configuration file that will contain */
14 /* global parameters - that is, parameters relating to the whole server, not */
15 /* just services. This name is then reserved, and may not be used as a       */
16 /* a service name. It will default to "global" if not defined here.          */
17 #define GLOBAL_NAME "global"
18 #define GLOBAL_NAME2 "globals"
19
20 /* This defines the section name in the configuration file that will
21    refer to the special "homes" service */
22 #define HOMES_NAME "homes"
23
24 /* This defines the section name in the configuration file that will
25    refer to the special "printers" service */
26 #define PRINTERS_NAME "printers"
27
28 /* Yves Gaige <yvesg@hptnodur.grenoble.hp.com> requested this set this       */
29 /* to a maximum of 8 if old smb clients break because of long printer names. */
30 #define MAXPRINTERLEN 15
31
32 /* max number of directories open at once */
33 /* note that with the new directory code this no longer requires a
34    file handle per directory, but large numbers do use more memory */
35 #define MAX_OPEN_DIRECTORIES 256
36
37 /* max number of directory handles */
38 /* As this now uses the bitmap code this can be
39    quite large. */
40 #define MAX_DIRECTORY_HANDLES 2048
41
42 /* maximum number of file caches per smbd */
43 #define MAX_WRITE_CACHES 10
44
45 /*
46  * Fudgefactor required for open tdb's, etc.
47  */
48
49 #ifndef MAX_OPEN_FUDGEFACTOR
50 #define MAX_OPEN_FUDGEFACTOR 20
51 #endif
52
53 /*
54  * Minimum number of open files needed for Windows7 to
55  * work correctly. A little conservative but better that
56  * than run out of fd's.
57  */
58
59 #ifndef MIN_OPEN_FILES_WINDOWS
60 #define MIN_OPEN_FILES_WINDOWS 16384
61 #endif
62
63 /*
64  * Default number of maximum open files per smbd. This is
65  * also limited by the maximum available file descriptors
66  * per process and can also be set in smb.conf as "max open files"
67  * in the [global] section.
68  */
69
70 #ifndef MAX_OPEN_FILES
71 #define MAX_OPEN_FILES (MIN_OPEN_FILES_WINDOWS + MAX_OPEN_FUDGEFACTOR)
72 #endif
73
74 #define WORDMAX 0xFFFF
75
76 /* the maximum password length before we declare a likely attack */
77 #define MAX_PASS_LEN 200
78
79 /* separators for lists */
80 #define LIST_SEP " \t,;\n\r"
81
82 /* wchar separators for lists */
83 #define LIST_SEP_W wchar_list_sep
84
85 /* this is where browse lists are kept in the lock dir */
86 #define SERVER_LIST "browse.dat"
87
88 /* shall filenames with illegal chars in them get mangled in long
89    filename listings? */
90 #define MANGLE_LONG_FILENAMES 
91
92 /* define this if you want to stop spoofing with .. and soft links
93    NOTE: This also slows down the server considerably */
94 #define REDUCE_PATHS
95
96 /* the size of the directory cache */
97 #define DIRCACHESIZE 20
98
99 /* what default type of filesystem do we want this to show up as in a
100    NT file manager window? */
101 #define FSTYPE_STRING "NTFS"
102
103 /* the default guest account - normally set in the Makefile or smb.conf */
104 #ifndef GUEST_ACCOUNT
105 #define GUEST_ACCOUNT "nobody"
106 #endif
107
108 /* user to test password server with as invalid in security=server mode. */
109 #ifndef INVALID_USER_PREFIX
110 #define INVALID_USER_PREFIX "sambatest"
111 #endif
112
113 /* the default pager to use for the client "more" command. Users can
114    override this with the PAGER environment variable */
115 #ifndef PAGER
116 #define PAGER "more"
117 #endif
118
119 /* the size of the uid cache used to reduce valid user checks */
120 #define VUID_CACHE_SIZE 32
121
122 /* the following control timings of various actions. Don't change 
123    them unless you know what you are doing. These are all in seconds */
124 #define DEFAULT_SMBD_TIMEOUT (60*60*24*7)
125 #define SMBD_RELOAD_CHECK (180)
126 #define IDLE_CLOSED_TIMEOUT (60)
127 #define DPTR_IDLE_TIMEOUT (120)
128 #define SMBD_SELECT_TIMEOUT (60)
129 #define NMBD_SELECT_LOOP (10)
130 #define BROWSE_INTERVAL (60)
131 #define REGISTRATION_INTERVAL (10*60)
132 #define NMBD_INETD_TIMEOUT (120)
133 #define NMBD_MAX_TTL (24*60*60)
134 #define LPQ_LOCK_TIMEOUT (5)
135 #define NMBD_INTERFACES_RELOAD (120)
136 #define NMBD_UNEXPECTED_TIMEOUT (15)
137 #define SMBD_HOUSEKEEPING_INTERVAL SMBD_SELECT_TIMEOUT
138
139 /* the following are in milliseconds */
140 #define LOCK_RETRY_TIMEOUT (100)
141
142 /* do you want to dump core (carefully!) when an internal error is
143    encountered? Samba will be careful to make the core file only
144    accessible to root */
145 #define DUMP_CORE 1
146
147 /* shall we support browse requests via a FIFO to nmbd? */
148 #define ENABLE_FIFO 1
149
150 /* how long (in miliseconds) to wait for a socket connect to happen */
151 #define LONG_CONNECT_TIMEOUT 30000
152 #define SHORT_CONNECT_TIMEOUT 5000
153
154 /* the default netbios keepalive timeout */
155 #define DEFAULT_KEEPALIVE 300
156
157 /* the directory to sit in when idle */
158 /* #define IDLE_DIR "/" */
159
160 /* Timout (in seconds) to wait for an oplock break
161    message to return from the client. */
162
163 #define OPLOCK_BREAK_TIMEOUT 30
164
165 /* Timout (in seconds) to add to the oplock break timeout
166    to wait for the smbd to smbd message to return. */
167
168 #define OPLOCK_BREAK_TIMEOUT_FUDGEFACTOR 2
169
170 /* the read preciction code has been disabled until some problems with
171    it are worked out */
172 #define USE_READ_PREDICTION 0
173
174 /*
175  * Default passwd chat script.
176  */
177
178 #define DEFAULT_PASSWD_CHAT "*new*password* %n\\n *new*password* %n\\n *changed*"
179
180 /* Minimum length of allowed password when changing UNIX password. */
181 #define MINPASSWDLENGTH 5
182
183 /* maximum ID number used for session control. This cannot be larger
184    than 62*62 for the current code */
185 #define MAX_SESSION_ID 3000
186
187 /* For the benifit of PAM and the 'session exec' scripts, we fake up a terminal
188    name. This can be in one of two forms:  The first for systems not using
189    utmp (and therefore not constrained as to length or the need for a number
190    < 3000 or so) and the second for systems with this 'well behaved terminal
191    like name' constraint.
192 */
193
194 #ifndef SESSION_TEMPLATE
195 /* Paramaters are 'pid' and 'vuid' */
196 #define SESSION_TEMPLATE "smb/%lu/%d"
197 #endif
198
199 #ifndef SESSION_UTMP_TEMPLATE
200 #define SESSION_UTMP_TEMPLATE "smb/%d"
201 #endif
202
203 /* the maximum age in seconds of a password. Should be a lp_ parameter */
204 #define MAX_PASSWORD_AGE (21*24*60*60)
205
206 /* Default allocation roundup. */
207 #define SMB_ROUNDUP_ALLOCATION_SIZE 0x100000
208
209 /* shall we deny oplocks to clients that get timeouts? */
210 #define FASCIST_OPLOCK_BACKOFF 1
211
212 /* this enables the "rabbit pellet" fix for SMBwritebraw */
213 #define RABBIT_PELLET_FIX 1
214
215 /* Max number of jobs per print queue. */
216 #define PRINT_MAX_JOBID 10000
217
218 /* Max number of open RPC pipes. */
219 #define MAX_OPEN_PIPES 2048
220
221 /* Tuning for server auth mutex. */
222 #define CLI_AUTH_TIMEOUT 5000 /* In milli-seconds. */
223 #define NUM_CLI_AUTH_CONNECT_RETRIES 3
224 /* Number in seconds to wait for the mutex. This must be less than 30 seconds. */
225 #define SERVER_MUTEX_WAIT_TIME ( ((NUM_CLI_AUTH_CONNECT_RETRIES) * ((CLI_AUTH_TIMEOUT)/1000)) + 5)
226 /* Number in seconds for winbindd to wait for the mutex. Make this 2 * smbd wait time. */
227 #define WINBIND_SERVER_MUTEX_WAIT_TIME (( ((NUM_CLI_AUTH_CONNECT_RETRIES) * ((CLI_AUTH_TIMEOUT)/1000)) + 5)*2)
228
229 /* Buffer size to use when printing backtraces */
230 #define BACKTRACE_STACK_SIZE 64
231
232 /* size of listen() backlog in smbd */
233 #define SMBD_LISTEN_BACKLOG 50
234
235 /* Number of microseconds to wait before a sharing violation. */
236 #define SHARING_VIOLATION_USEC_WAIT 950000
237
238 /* Number of microseconds to wait before a updating the write time (2 secs). */
239 #define WRITE_TIME_UPDATE_USEC_DELAY 2000000
240
241 #define MAX_LDAP_REPLICATION_SLEEP_TIME 5000 /* In milliseconds. */
242
243 /* tdb hash size for the open database. */
244 #define SMB_OPEN_DATABASE_TDB_HASH_SIZE 10007
245
246 /* Characters we disallow in sharenames. */
247 #define INVALID_SHARENAME_CHARS "%<>*?|/\\+=;:\","
248
249 /* Seconds between connection attempts to a remote server. */
250 #define FAILED_CONNECTION_CACHE_TIMEOUT 30
251
252 /* Default hash size for the winbindd cache. */
253 #define WINBINDD_CACHE_TDB_DEFAULT_HASH_SIZE 5000
254
255 /* Windows minimum lock resolution timeout in ms */
256 #define WINDOWS_MINIMUM_LOCK_TIMEOUT_MS 200
257
258 /* Maximum size of RPC data we will accept for one call. */
259 #define MAX_RPC_DATA_SIZE (15*1024*1024)
260
261 #define CLIENT_NDR_PADDING_SIZE 8
262 #define SERVER_NDR_PADDING_SIZE 8
263
264 #define DEFAULT_SMB2_MAX_READ (1024*1024)
265 #define DEFAULT_SMB2_MAX_WRITE (1024*1024)
266 #define DEFAULT_SMB2_MAX_TRANSACT (1024*1024)
267 #define DEFAULT_SMB2_MAX_CREDITS 128
268 #define DEFAULT_SMB2_MAX_CREDIT_BITMAP_FACTOR 2
269
270 #endif