fix a bug that we've had for a long time where we don't handle EOF
[kai/samba.git] / source / 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 /* the print command on the server, %s is replaced with the filename  */
57 /* note that the -r removes the file after printing - you'll run out  */
58 /* of disk pretty quickly if you don't. This command is only used as  */
59 /* the default - it can be overridden in the configuration file.      */
60 #define PRINT_COMMAND "lpr -r %s"
61
62 /* the lpq command on the server. the printername is passed as an argument */
63 #ifndef LPQ_COMMAND
64 #define LPQ_COMMAND "lpq -P"
65 #endif
66
67 /* shall guest entries in printer queues get changed to user entries,
68    so they can be deleted using the windows print manager? */
69 #define LPQ_GUEST_TO_USER
70
71 /* shall filenames with illegal chars in them get mangled in long
72    filename listings? */
73 #define MANGLE_LONG_FILENAMES 
74
75 /* define this if you want to stop spoofing with .. and soft links
76    NOTE: This also slows down the server considerably */
77 #define REDUCE_PATHS
78
79 /* the size of the directory cache */
80 #define DIRCACHESIZE 20
81
82 /* what type of filesystem do we want this to show up as in a NT file
83    manager window? */
84 #define FSTYPE_STRING "Samba"
85
86 /* do you want smbd to send a 1 byte packet to nmbd to trigger it to start 
87    when smbd starts? */
88 #ifndef PRIME_NMBD
89 #define PRIME_NMBD 1
90 #endif
91
92 /* do you want session setups at user level security with a invalid
93    password to be rejected or allowed in as guest? WinNT rejects them
94    but it can be a pain as it means "net view" needs to use a password 
95
96    You have 3 choices:
97
98    GUEST_SESSSETUP = 0 means session setups with an invalid password
99    are rejected.
100
101    GUEST_SESSSETUP = 1 means session setups with an invalid password
102    are rejected, unless the username does not exist, in which case it
103    is treated as a guest login
104
105    GUEST_SESSSETUP = 2 means session setups with an invalid password
106    are treated as a guest login
107
108    Note that GUEST_SESSSETUP only has an effect in user or server
109    level security.
110    */
111 #ifndef GUEST_SESSSETUP
112 #define GUEST_SESSSETUP 0
113 #endif
114
115 /* the default pager to use for the client "more" command. Users can
116    override this with the PAGER environment variable */
117 #ifndef PAGER
118 #define PAGER "more"
119 #endif
120
121 /* the size of the uid cache used to reduce valid user checks */
122 #define UID_CACHE_SIZE 4
123
124 /* the following control timings of various actions. Don't change 
125    them unless you know what you are doing. These are all in seconds */
126 #define DEFAULT_SMBD_TIMEOUT (60*60*24*7)
127 #define SMBD_RELOAD_CHECK (10)
128 #define SHARE_MODES_CHECK (10)
129 #define SHARE_MODES_CLEAN (300)
130 #define IDLE_CLOSED_TIMEOUT (60)
131 #define DPTR_IDLE_TIMEOUT (120)
132 #define SMBD_SELECT_LOOP (10)
133 #define NMBD_SELECT_LOOP (2)
134 #define BROWSE_INTERVAL (60)
135 #define REGISTRATION_INTERVAL (10*60)
136 #define NMBD_INETD_TIMEOUT (120)
137 #define NMBD_MAX_TTL (24*60*60)
138 #define LPQ_LOCK_TIMEOUT (5)
139
140 /* the following are in milliseconds */
141 #define LOCK_RETRY_TIMEOUT (100)
142
143 /* do you want to dump core (carefully!) when an internal error is
144    encountered? Samba will be careful to make the core file only
145    accessible to root */
146 #define DUMP_CORE 1
147
148 /* what is the longest significant password available on your system? 
149  Knowing this speeds up password searches a lot */
150 #ifndef PASSWORD_LENGTH
151 #define PASSWORD_LENGTH 8
152 #endif
153
154 #define SMB_ALIGNMENT 1
155
156
157 /* shall we support browse requests via a FIFO to nmbd? */
158 #define ENABLE_FIFO 1
159
160 /* keep the password server open, this uses up a aocket, but is needed
161    by many apps */
162 #define KEEP_PASSWORD_SERVER_OPEN 1
163
164 #endif