Windows: cm_attrs_t requires inclusion of cm_vnodeops.h
[openafs.git] / src / WINNT / afsd / smb.h
1 /*
2  * Copyright 2000, International Business Machines Corporation and others.
3  * All Rights Reserved.
4  * 
5  * This software has been released under the terms of the IBM Public
6  * License.  For details, see the LICENSE file in the top-level source
7  * directory or online at http://www.openafs.org/dl/license10.html
8  */
9
10 #ifndef __SMB_H_ENV__
11 #define __SMB_H_ENV__ 1
12
13 /* #define DEBUG_SMB_REFCOUNT 1 */
14
15 #if _WIN32_WINNT < 0x0501
16 #undef _WIN32_WINNT
17 #define _WIN32_WINNT 0x0501
18 #endif
19 #include <ntsecapi.h>
20
21 #include <cm_nls.h>
22
23 /* basic core protocol SMB structure */
24 #pragma pack(push, 1)
25 typedef struct smb {
26     unsigned char id[4];
27     unsigned char com;
28     unsigned char rcls;
29     unsigned char reh;
30     unsigned char errLow;
31     unsigned char errHigh;
32     unsigned char reb;
33     unsigned short flg2;
34     unsigned short res[6];
35     unsigned short tid;
36     unsigned short pid;
37     unsigned short uid;
38     unsigned short mid;
39     unsigned char wct;
40     unsigned char vdata[1];
41 } smb_t;
42 #pragma pack(pop)
43
44 /* reb values */
45 #define SMB_FLAGS_SUPPORT_LOCKREAD         0x01
46 #define SMB_FLAGS_CLIENT_BUF_AVAIL         0x02
47 #define SMB_FLAGS_CASELESS_PATHNAMES       0x08
48 #define SMB_FLAGS_CANONICAL_PATHNAMES      0x10
49 #define SMB_FLAGS_REQUEST_OPLOCK           0x20
50 #define SMB_FLAGS_REQUEST_BATCH_OPLOCK     0x40
51 #define SMB_FLAGS_SERVER_TO_CLIENT         0x80
52
53 /* flg2 values */
54
55 #define SMB_FLAGS2_KNOWS_LONG_NAMES        0x0001
56 #define SMB_FLAGS2_KNOWS_EAS               0x0002
57 #define SMB_FLAGS2_SECURITY_SIGNATURE      0x0004
58 #define SMB_FLAGS2_RESERVED1               0x0008
59 #define SMB_FLAGS2_IS_LONG_NAME            0x0040
60 #define SMB_FLAGS2_EXT_SEC                 0x0800
61 #define SMB_FLAGS2_DFS_PATHNAMES           0x1000
62 #define SMB_FLAGS2_PAGING_IO               0x2000
63 #define SMB_FLAGS2_32BIT_STATUS            0x4000
64 #define SMB_FLAGS2_UNICODE                 0x8000
65
66 #define KNOWS_LONG_NAMES(inp) ((((smb_t *)inp)->flg2 & SMB_FLAGS2_KNOWS_LONG_NAMES)?1:0)
67 #define WANTS_DFS_PATHNAMES(inp) ((((smb_t *)inp)->flg2 & SMB_FLAGS2_DFS_PATHNAMES)?1:0)
68 #define WANTS_UNICODE(inp) ((((smb_t *)inp)->flg2 & SMB_FLAGS2_UNICODE)?1:0)
69
70 /* Information Levels */
71 #define SMB_INFO_STANDARD               1
72 #define SMB_INFO_QUERY_EA_SIZE          2
73 #define SMB_INFO_QUERY_EAS_FROM_LIST    3
74 #define SMB_INFO_QUERY_ALL_EAS          4
75 #define SMB_INFO_IS_NAME_VALID          6
76
77 #define SMB_QUERY_FILE_BASIC_INFO       0x101
78 #define SMB_QUERY_FILE_STANDARD_INFO    0x102
79 #define SMB_QUERY_FILE_EA_INFO          0x103
80 #define SMB_QUERY_FILE_NAME_INFO        0x104
81 #define SMB_QUERY_FILE_ALL_INFO         0x107
82 #define SMB_QUERY_FILE_ALT_NAME_INFO    0x108
83 #define SMB_QUERY_FILE_STREAM_INFO      0x109
84 #define SMB_QUERY_FILE_COMPRESSION_INFO 0x10B
85 #define SMB_QUERY_FILE_UNIX_BASIC       0x200
86 #define SMB_QUERY_FILE_UNIX_LINK        0x201
87 #define SMB_INFO_PASSTHROUGH           0x1000
88
89 #define SMB_SET_FILE_BASIC_INFO         0x101
90 #define SMB_SET_FILE_DISPOSITION_INFO   0x102
91 #define SMB_SET_FILE_ALLOCATION_INFO    0x103
92 #define SMB_SET_FILE_END_OF_FILE_INFO   0x104
93 #define SMB_SET_FILE_UNIX_BASIC         0x200
94 #define SMB_SET_FILE_UNIX_LINK          0x201
95 #define SMB_SET_FILE_UNIX_HLINK         0x203
96
97 #define SMB_INFO_ALLOCATION             1
98 #define SMB_INFO_VOLUME                 2
99 #define SMB_QUERY_FS_LABEL_INFO         0x101
100 #define SMB_QUERY_FS_VOLUME_INFO        0x102
101 #define SMB_QUERY_FS_SIZE_INFO          0x103
102 #define SMB_QUERY_FS_DEVICE_INFO        0x104
103 #define SMB_QUERY_FS_ATTRIBUTE_INFO     0x105
104 #define SMB_QUERY_FS_QUOTA_INFO         0x106
105 #define SMB_QUERY_FS_CONTROL_INFO       0x107
106 #define SMB_INFO_UNIX                   0x200
107 #define SMB_INFO_MACOS                  0x301
108
109 #define SMB_FIND_FILE_DIRECTORY_INFO      0x101
110 #define SMB_FIND_FILE_FULL_DIRECTORY_INFO 0x102
111 #define SMB_FIND_FILE_NAMES_INFO          0x103
112 #define SMB_FIND_FILE_BOTH_DIRECTORY_INFO 0x104
113
114 /* SMB_COM_TRANSACTION Named pipe operations */
115 #define SMB_TRANS_SET_NMPIPE_STATE      0x0001
116 #define SMB_TRANS_RAW_READ_NMPIPE       0x0011
117 #define SMB_TRANS_QUERY_NMPIPE_STATE    0x0021
118 #define SMB_TRANS_QUERY_NMPIPE_INFO     0x0022
119 #define SMB_TRANS_PEEK_NMPIPE           0x0023
120 #define SMB_TRANS_TRANSACT_NMPIPE       0x0026
121 #define SMB_TRANS_RAW_WRITE_NMPIPE      0x0031
122 #define SMB_TRANS_READ_NMPIPE           0x0036
123 #define SMB_TRANS_WRITE_NMPIPE          0x0037
124 #define SMB_TRANS_WAIT_NMPIPE           0x0053
125 #define SMB_TRANS_CALL_NMPIPE           0x0054
126
127 /* more defines */
128 #define SMB_NOPCODES            256     /* # of opcodes in the dispatch table */
129
130 /* threads per VC */
131 #define SMB_THREADSPERVC        4       /* threads per VC */
132
133 /* flags for functions */
134 #define SMB_FLAG_CREATE         1       /* create the structure if necessary */
135 #define SMB_FLAG_AFSLOGON       2       /* operating on behalf of afslogon.dll */
136
137 /* max # of bytes we'll receive in an incoming SMB message */
138 /* the maximum is 2^18-1 for NBT and 2^25-1 for Raw transport messages */
139 /* we will use something smaller but large enough to be efficient */
140 #define SMB_PACKETSIZE  32768 /* was 8400 */
141 /* raw mode is considered obsolete and cannot be used with message signing */
142 #define SMB_MAXRAWSIZE  65536
143 /* max STRING characters per packet per request */
144 #define SMB_STRINGBUFSIZE 4096
145
146 /* Negotiate protocol constants */
147 /* Security */
148 #define NEGOTIATE_SECURITY_USER_LEVEL               0x01
149 #define NEGOTIATE_SECURITY_CHALLENGE_RESPONSE       0x02
150 #define NEGOTIATE_SECURITY_SIGNATURES_ENABLED       0x04
151 #define NEGOTIATE_SECURITY_SIGNATURES_REQUIRED      0x08
152
153 /* Capabilities */
154 #define NTNEGOTIATE_CAPABILITY_RAWMODE                  0x00000001L
155 #define NTNEGOTIATE_CAPABILITY_MPXMODE                  0x00000002L
156 #define NTNEGOTIATE_CAPABILITY_UNICODE                  0x00000004L
157 #define NTNEGOTIATE_CAPABILITY_LARGEFILES               0x00000008L
158 #define NTNEGOTIATE_CAPABILITY_NTSMB                    0x00000010L
159 #define NTNEGOTIATE_CAPABILITY_RPCAPI                   0x00000020L
160 #define NTNEGOTIATE_CAPABILITY_NTSTATUS                 0x00000040L
161 #define NTNEGOTIATE_CAPABILITY_LEVEL_II_OPLOCKS         0x00000080L
162 #define NTNEGOTIATE_CAPABILITY_LOCK_AND_READ            0x00000100L
163 #define NTNEGOTIATE_CAPABILITY_NTFIND                   0x00000200L
164 #define NTNEGOTIATE_CAPABILITY_DFS                      0x00001000L
165 #define NTNEGOTIATE_CAPABILITY_NT_INFO_PASSTHRU         0x00002000L
166 #define NTNEGOTIATE_CAPABILITY_LARGE_READX              0x00004000L
167 #define NTNEGOTIATE_CAPABILITY_LARGE_WRITEX             0x00008000L
168 #define NTNEGOTIATE_CAPABILITY_UNIX                     0x00800000L
169 #define NTNEGOTIATE_CAPABILITY_BULK_TRANSFER            0x20000000L
170 #define NTNEGOTIATE_CAPABILITY_COMPRESSED               0x40000000L
171 #define NTNEGOTIATE_CAPABILITY_EXTENDED_SECURITY        0x80000000L
172
173 /* a packet structure for receiving SMB messages; locked by smb_globalLock.
174  * Most of the work involved is in handling chained requests and responses.
175  *
176  * When handling input, inWctp points to the current request's wct field (and
177  * the other parameters and request data can be found from this field).  The
178  * opcode, unfortunately, isn't available there, so is instead copied to the
179  * packet's inCom field.  It is initially set to com, but each chained
180  * operation sets it, also.
181  * The function smb_AdvanceInput advances an input packet to the next request
182  * in the chain.  The inCom field is set to 0xFF when there are no more
183  * requests.  The inCount field is 0 if this is the first request, and
184  * otherwise counts which request it is.
185  *
186  * When handling output, we also have to chain all of the responses together.
187  * The function smb_GetResponsePacket will setup outWctp to point to the right
188  * place.
189  */
190 #define SMB_PACKETMAGIC 0x7436353       /* magic # for packets */
191 typedef struct smb_packet {
192     char data[SMB_PACKETSIZE];
193     struct smb_packet *nextp;           /* in free list, or whatever */
194     long magic;
195     cm_space_t *spacep;                 /* use this for stripping last component */
196     NCB *ncbp;                          /* use this for sending */
197     struct smb_vc *vcp;
198     unsigned long resumeCode;
199     unsigned short inCount;
200     unsigned short fid;                 /* for calls bundled with openAndX */
201     unsigned char *wctp;
202     unsigned char inCom;
203     unsigned char oddByte;
204     unsigned short ncb_length;
205     unsigned char flags;
206     cm_space_t *stringsp;               /* decoded strings from this packet */
207 } smb_packet_t;
208
209 /* smb_packet flags */
210 #define SMB_PACKETFLAG_NOSEND                   1
211 #define SMB_PACKETFLAG_SUSPENDED                2
212
213 /* a structure for making Netbios calls; locked by smb_globalLock */
214 #define SMB_NCBMAGIC    0x2334344
215 typedef struct myncb {
216     NCB ncb;                            /* ncb to use */
217     struct myncb *nextp;                /* when on free list */
218     long magic;
219 } smb_ncb_t;
220
221 /* structures representing environments from kernel / SMB network.
222  * Most have their own locks, but the tree connection fields and
223  * reference counts are locked by the smb_rctLock.  Those fields will
224  * be marked in comments.
225  */
226
227 /* one per virtual circuit */
228 typedef struct smb_vc {
229     struct smb_vc *nextp;               /* not used */
230     afs_uint32 magic;                   /* a magic value to detect bad entries */
231     afs_int32 refCount;                 /* the reference count */
232     afs_uint32 flags;                   /* the flags, if any; locked by mx */
233     osi_mutex_t mx;                     /* the mutex */
234     afs_uint32 vcID;                    /* VC id */
235     unsigned short lsn;                 /* the NCB LSN associated with this */
236     unsigned short uidCounter;          /* session ID counter */
237     unsigned short tidCounter;          /* tree ID counter */
238     unsigned short fidCounter;          /* file handle ID counter */
239     struct smb_tid *tidsp;              /* the first child in the tid list */
240     struct smb_user *usersp;            /* the first child in the user session list */
241     struct smb_fid *fidsp;              /* the first child in the open file list */
242     unsigned char errorCount;
243     clientchar_t rname[17];
244     int lana;
245     char encKey[MSV1_0_CHALLENGE_LENGTH]; /* MSV1_0_CHALLENGE_LENGTH is 8 */
246     void * secCtx;                      /* security context when negotiating SMB extended auth
247                                          * valid when SMB_VCFLAG_AUTH_IN_PROGRESS is set
248                                          */
249     unsigned short session;             /* This is the Session Index associated with the NCBs */
250 } smb_vc_t;
251
252 #define SMB_VC_MAGIC ('S' | 'C'<<8 | 'A'<<16 | 'C'<<24)
253                                         /* have we negotiated ... */
254 #define SMB_VCFLAG_USEV3        1       /* ... version 3 of the protocol */
255 #define SMB_VCFLAG_USECORE      2       /* ... the core protocol */
256 #define SMB_VCFLAG_USENT        4       /* ... NT LM 0.12 or beyond */
257 #define SMB_VCFLAG_STATUS32     8       /* use 32-bit NT status codes */
258 #define SMB_VCFLAG_REMOTECONN   0x10    /* bad: remote conns not allowed */
259 #define SMB_VCFLAG_ALREADYDEAD  0x20    /* do not get tokens from this vc */
260 #define SMB_VCFLAG_SESSX_RCVD   0x40    /* we received at least one session setups on this vc */
261 #define SMB_VCFLAG_AUTH_IN_PROGRESS 0x80 /* a SMB NT extended authentication is in progress */
262 #define SMB_VCFLAG_CLEAN_IN_PROGRESS 0x100
263 #define SMB_VCFLAG_USEUNICODE   0x200   /* une UNICODE for STRING fields (NTLM 0.12 or later) */
264
265 /* one per user session */
266 typedef struct smb_user {
267     struct smb_user *nextp;             /* next sibling */
268     afs_int32 refCount;                 /* ref count */
269     afs_uint32 flags;                   /* flags; locked by mx */
270     osi_mutex_t mx;
271     unsigned short userID;              /* the session identifier */
272     struct smb_vc *vcp;                 /* back ptr to virtual circuit */
273     struct smb_username *unp;           /* user name struct */
274     afs_uint32  deleteOk;               /* ok to del: locked by smb_rctLock */
275 } smb_user_t;
276
277 #define SMB_USERFLAG_DELETE         1   /* delete struct when ref count zero */
278
279 typedef struct smb_username {
280     struct smb_username *nextp;         /* next sibling */
281     afs_int32 refCount;                 /* ref count */
282     long flags;                         /* flags; locked by mx */
283     osi_mutex_t mx;
284     struct cm_user *userp;              /* CM user structure */
285     clientchar_t *name;                 /* user name */
286     clientchar_t *machine;              /* machine name */
287     time_t last_logoff_t;               /* most recent logoff time */
288 } smb_username_t;
289
290 /* The SMB_USERNAMEFLAG_AFSLOGON is used to preserve the existence of an 
291  * smb_username_t even when the refCount is zero.  This is used to ensure
292  * that tokens set to a username during the integrated logon process are 
293  * preserved until the SMB Session that will require the tokens is created.
294  * The cm_IoctlSetTokens() function when executed from the Network Provider
295  * connects to the AFS Client Service using the credentials of the machine
296  * and not the user for whom the tokens are being configured. */
297 #define SMB_USERNAMEFLAG_AFSLOGON   1
298
299 /* The SMB_USERNAMEFLAG_LOGOFF is used to indicate that the user most
300  * recently logged off at 'last_logoff_t'.  The smb_username_t should not
301  * be deleted even if the refCount is zero before 'last_logoff_t' + 
302  * 'smb_LogoffTransferTimeout' if 'smb_LogoffTokenTransfer' is non-zero.
303  * The smb_Daemon() thread is responsible for purging the expired objects */
304
305 #define SMB_USERNAMEFLAG_LOGOFF     2
306
307 #define SMB_MAX_USERNAME_LENGTH 256
308
309 /* one per tree-connect */
310 typedef struct smb_tid {
311     struct smb_tid *nextp;              /* next sibling */
312     afs_int32 refCount;
313     afs_uint32 flags;                   /* protected by mx */
314     osi_mutex_t mx;                     /* for non-tree-related stuff */
315     unsigned short tid;                 /* the tid */
316     struct smb_vc *vcp;                 /* back ptr */
317     struct cm_user *userp;              /* user logged in at the
318                                          * tree connect level (base) */
319     clientchar_t *pathname;             /* pathname derived from sharename */
320     afs_uint32  deleteOk;               /* ok to del: locked by smb_rctLock */
321 } smb_tid_t;
322
323 #define SMB_TIDFLAG_IPC         1       /* IPC$ */
324
325 /* one per process ID */
326 typedef struct smb_pid {
327     struct smb_pid *nextp;              /* next sibling */
328     afs_int32 refCount;
329     long flags;
330     osi_mutex_t mx;                     /* for non-tree-related stuff */
331     unsigned short pid;                 /* the pid */
332     struct smb_tid *tidp;               /* back ptr */
333 } smb_pid_t;
334
335
336 /* Defined in smb_ioctl.h */
337 struct smb_ioctl;
338
339 /* Defined in smb_rpc.h */
340 struct smb_rpc;
341
342 /* one per file ID; these are really file descriptors */
343 typedef struct smb_fid {
344     osi_queue_t q;
345     afs_int32 refCount;
346     afs_uint32 flags;                   /* protected by mx */
347     osi_mutex_t mx;                     /* for non-tree-related stuff */
348     unsigned short fid;                 /* the file ID */
349     struct smb_vc *vcp;                 /* back ptr */
350     struct cm_scache *scp;              /* scache of open file */
351     struct cm_user *userp;              /* user that opened the file
352                                            originally (used to close
353                                            the file if session is
354                                            terminated) */
355     osi_hyper_t offset;                 /* our file pointer */
356     struct smb_ioctl *ioctlp;           /* ptr to ioctl structure */
357                                         /* Under NT, we may need to know the
358                                          * parent directory and pathname used
359                                          * to open the file, either to delete
360                                          * the file on close, or to do a
361                                          * change notification */
362     struct smb_rpc   *rpcp;             /* ptr to RPC structure.  Used
363                                            to keep track of endpoint
364                                            that was opened for the
365                                            RPC. */
366     struct cm_scache *NTopen_dscp;      /* parent directory (NT) */
367     clientchar_t *NTopen_pathp;         /* path used in open (NT) */
368     clientchar_t *NTopen_wholepathp;    /* entire path, not just last name */
369     int curr_chunk;                     /* chunk being read */
370     int prev_chunk;                     /* previous chunk read */
371     int raw_writers;                    /* pending async raw writes */
372     EVENT_HANDLE raw_write_event;       /* signal this when raw_writers zero */
373     afs_uint32  deleteOk;               /* ok to del: locked by smb_rctLock */
374 } smb_fid_t;
375
376 #define SMB_FID_OPENREAD_LISTDIR        1       /* open for reading / listing directory */
377 #define SMB_FID_OPENWRITE               2       /* open for writing */
378 #define SMB_FID_CREATED                 4       /* a new file */
379 #define SMB_FID_IOCTL                   8       /* a file descriptor for the
380                                                  * magic ioctl file */
381 #define SMB_FID_OPENDELETE              0x10    /* open for deletion (NT) */
382 #define SMB_FID_DELONCLOSE              0x20    /* marked for deletion */
383
384 /*
385  * Now some special flags to work around a bug in NT Client
386  */
387 #define SMB_FID_LENGTHSETDONE           0x40    /* have done 0-length write */
388 #define SMB_FID_MTIMESETDONE            0x80    /* have set modtime via Tr2 */
389 #define SMB_FID_LOOKSLIKECOPY   (SMB_FID_LENGTHSETDONE | SMB_FID_MTIMESETDONE)
390 #define SMB_FID_NTOPEN                  0x100   /* have dscp and pathp */
391 #define SMB_FID_SEQUENTIAL              0x200
392 #define SMB_FID_RANDOM                  0x400
393 #define SMB_FID_EXECUTABLE              0x800
394
395 #define SMB_FID_SHARE_READ              0x1000
396 #define SMB_FID_SHARE_WRITE             0x2000
397
398 #define SMB_FID_RPC                     0x4000  /* open for MS RPC */
399 #define SMB_FID_MESSAGEMODEPIPE         0x8000  /* message mode pipe */
400 #define SMB_FID_BLOCKINGPIPE           0x10000  /* blocking pipe */
401 #define SMB_FID_RPC_INCALL             0x20000  /* in an RPC call */
402
403 #define SMB_FID_QLOCK_HIGH              0x7f000000
404 #define SMB_FID_QLOCK_LOW               0x00000000
405 #define SMB_FID_QLOCK_LENGTH            1
406 #define SMB_FID_QLOCK_PID               0
407
408 /*
409  * SMB file attributes (16-bit)
410  */
411 #define SMB_ATTR_READONLY       0x0001
412 #define SMB_ATTR_HIDDEN         0x0002 /* hidden file for the purpose of dir listings */
413 #define SMB_ATTR_SYSTEM         0x0004
414 #define SMB_ATTR_VOLUMEID       0x0008 /* obsolete */
415 #define SMB_ATTR_DIRECTORY      0x0010
416 #define SMB_ATTR_ARCHIVE        0x0020
417 #define SMB_ATTR_DEVICE         0x0040
418
419 /* the following are Extended File Attributes (32-bit) */
420 #define SMB_ATTR_NORMAL         0x0080 /* normal file. Only valid if used alone */
421 #define SMB_ATTR_TEMPORARY      0x0100
422 #define SMB_ATTR_SPARSE_FILE    0x0200 /* used with dfs links */
423 #define SMB_ATTR_REPARSE_POINT  0x0400
424 #define SMB_ATTR_COMPRESSED     0x0800 /* file or dir is compressed */
425 #define SMB_ATTR_OFFLINE        0x1000
426 #define SMB_ATTR_NOT_CONTENT_INDEXED 0x2000
427 #define SMB_ATTR_ENCRYPTED      0x4000
428 #define SMB_ATTR_POSIX_SEMANTICS        0x01000000
429 #define SMB_ATTR_BACKUP_SEMANTICS       0x02000000
430 #define SMB_ATTR_DELETE_ON_CLOSE        0x04000000
431 #define SMB_ATTR_SEQUENTIAL_SCAN        0x08000000
432 #define SMB_ATTR_RANDOM_ACCESS          0x10000000
433 #define SMB_ATTR_NO_BUFFERING           0x20000000
434 #define SMB_ATTR_WRITE_THROUGH          0x80000000
435
436 #define LOCKING_ANDX_SHARED_LOCK        0x01 /* Read-only lock */
437 #define LOCKING_ANDX_OPLOCK_RELEASE     0x02 /* Oplock break notification */
438 #define LOCKING_ANDX_CHANGE_LOCKTYPE    0x04 /* Change lock type */
439 #define LOCKING_ANDX_CANCEL_LOCK        0x08 /* Cancel outstanding request */
440 #define LOCKING_ANDX_LARGE_FILES        0x10 /* Large file locking format */
441
442 /* File type constants */
443 #define SMB_FILETYPE_DISK               0x0000
444 #define SMB_FILETYPE_BYTE_MODE_PIPE     0x0001
445 #define SMB_FILETYPE_MESSAGE_MODE_PIPE  0x0002
446 #define SMB_FILETYPE_PRINTER            0x0003
447 #define SMB_FILETYPE_UNKNOWN            0xffff
448
449 /* Device state constants */
450 #define SMB_DEVICESTATE_READASBYTESTREAM    0x0000
451 #define SMB_DEVICESTATE_READMSGFROMPIPE     0x0100
452 #define SMB_DEVICESTATE_BYTESTREAMPIPE      0x0000
453 #define SMB_DEVICESTATE_MESSAGEMODEPIPE     0x0400
454 #define SMB_DEVICESTATE_PIPECLIENTEND       0x0000
455 #define SMB_DEVICESTATE_PIPESERVEREND       0x4000
456 #define SMB_DEVICESTATE_BLOCKING            0x8000
457
458 /* for tracking in-progress directory searches */
459 typedef struct smb_dirSearch {
460     osi_queue_t q;                      /* queue of all outstanding cookies */
461     osi_mutex_t mx;                     /* just in case the caller screws up */
462     afs_int32 refCount;                 /* reference count */
463     long cookie;                        /* value returned to the caller */
464     struct cm_scache *scp;              /* vnode of the dir we're searching */
465     time_t lastTime;                    /* last time we used this (osi_Time) */
466     long flags;                         /* flags (see below);
467                                          * locked by smb_globalLock */
468     unsigned short attribute;           /* search attribute
469                                          * (used for extended protocol) */
470     clientchar_t tidPath[256];          /* tid path */
471     clientchar_t relPath[1024];         /* relative path */        
472     clientchar_t mask[256];             /* search mask for V3 */
473 } smb_dirSearch_t;
474
475 #define SMB_DIRSEARCH_DELETE    1       /* delete struct when ref count zero */
476 #define SMB_DIRSEARCH_HITEOF    2       /* perhaps useful for advisory later */
477 #define SMB_DIRSEARCH_SMALLID   4       /* cookie can only be 8 bits, not 16 */
478 #define SMB_DIRSEARCH_BULKST    8       /* get bulk stat info */
479
480 /* type for patching directory listings */
481 typedef struct smb_dirListPatch {
482     osi_queue_t q;
483     char *dptr;                      /* ptr to attr, time, data, sizel, sizeh */
484     long flags;                         /* flags.  See below */
485     cm_fid_t fid;
486     cm_dirEntry_t *dep;                 /* temp */
487 } smb_dirListPatch_t;
488
489 /* dirListPatch Flags */
490 #define SMB_DIRLISTPATCH_DOTFILE 1  
491 /* the file referenced is a dot file
492  * Note: will not be set if smb_hideDotFiles is false 
493  */
494
495 /* individual lock on a waiting lock request */
496 typedef struct smb_waitingLock {
497     osi_queue_t      q;
498     cm_key_t         key;
499     LARGE_INTEGER    LOffset;
500     LARGE_INTEGER    LLength;
501     cm_file_lock_t * lockp;
502     int              state;
503 } smb_waitingLock_t;
504
505 #define SMB_WAITINGLOCKSTATE_WAITING   0
506 #define SMB_WAITINGLOCKSTATE_DONE      1
507 #define SMB_WAITINGLOCKSTATE_ERROR     2
508 #define SMB_WAITINGLOCKSTATE_CANCELLED 3
509
510 /* waiting lock request */
511 typedef struct smb_waitingLockRequest {
512     osi_queue_t   q;
513     smb_vc_t *    vcp;
514     cm_scache_t * scp;
515     smb_packet_t *inp;
516     smb_packet_t *outp;
517     int           lockType;
518     time_t        start_t;              /* osi_Time */
519     afs_uint32    msTimeout;            /* msecs, 0xFFFFFFFF = wait forever */
520     smb_waitingLock_t * locks;
521 } smb_waitingLockRequest_t;
522
523 extern smb_waitingLockRequest_t *smb_allWaitingLocks;
524
525 typedef long (smb_proc_t)(smb_vc_t *vcp, smb_packet_t *inp, smb_packet_t *outp);
526
527 typedef struct smb_dispatch {
528     smb_proc_t *procp;                  /* proc to call */
529     int flags;                          /* flags describing function */
530 } smb_dispatch_t;
531
532 #define SMB_DISPATCHFLAG_CHAINED        1       /* this is an _AND_X function */
533 #define SMB_DISPATCHFLAG_NORESPONSE     2       /* don't send the response
534                                                  * packet, typically because
535                                                  * the response was already
536                                                  * sent.
537                                                  */
538 #define SMB_MAX_PATH                    260     /* max path length */
539
540 /* prototypes */
541
542 extern void smb_Init(osi_log_t *logp, int useV3,
543         int nThreads
544         , void *aMBfunc
545   );
546
547 extern void smb_DosUTimeFromUnixTime(afs_uint32 *dosUTimep, time_t unixTime);
548
549 extern void smb_UnixTimeFromDosUTime(time_t *unixTimep, afs_uint32 dosUTime);
550
551 extern void CompensateForSmbClientLastWriteTimeBugs(afs_uint32 *dosTimep);
552
553 #ifdef DEBUG_SMB_REFCOUNT
554 extern smb_vc_t *smb_FindVCDbg(unsigned short lsn, int flags, int lana, char *, long);
555 #define smb_FindVC(a,b,c) smb_FindVCDbg(a,b,c,__FILE__,__LINE__);
556
557 extern void smb_HoldVCDbg(smb_vc_t *vcp, char *, long);
558 #define smb_HoldVC(a) smb_HoldVCDbg(a,__FILE__,__LINE__);
559
560 extern void smb_HoldVCNoLockDbg(smb_vc_t *vcp, char *, long);
561 #define smb_HoldVCNoLock(a) smb_HoldVCNoLockDbg(a,__FILE__,__LINE__);
562
563 extern void smb_ReleaseVCDbg(smb_vc_t *vcp, char *, long);
564 #define smb_ReleaseVC(a) smb_ReleaseVCDbg(a,__FILE__,__LINE__);
565
566 extern void smb_ReleaseVCNoLockDbg(smb_vc_t *vcp, char *, long);
567 #define smb_ReleaseVCNoLock(a) smb_ReleaseVCNoLockDbg(a,__FILE__,__LINE__);
568 #else
569 extern smb_vc_t *smb_FindVC(unsigned short lsn, int flags, int lana);
570
571 extern void smb_HoldVC(smb_vc_t *vcp);
572
573 extern void smb_HoldVCNoLock(smb_vc_t *vcp);
574
575 extern void smb_ReleaseVC(smb_vc_t *vcp);
576
577 extern void smb_ReleaseVCNoLock(smb_vc_t *vcp);
578 #endif
579
580 extern void smb_CleanupDeadVC(smb_vc_t *vcp);
581
582 extern void smb_MarkAllVCsDead(smb_vc_t *exclude_vcp);
583
584 #ifdef DEBUG_SMB_REFCOUNT
585 extern smb_tid_t *smb_FindTIDDbg(smb_vc_t *vcp, unsigned short tid, int flags, char *, long);
586 #define smb_FindTID(a,b,c) smb_FindTIDDbg(a,b,c,__FILE__,__LINE__);
587
588 extern void smb_HoldTIDNoLockDbg(smb_tid_t *tidp, char *, long);
589 #define smb_HoldTIDNoLock(a) smb_HoldTIDNoLockDbg(a,__FILE__,__LINE__);
590
591 extern void smb_ReleaseTIDDbg(smb_tid_t *tidp, afs_uint32 locked, char *, long);
592 #define smb_ReleaseTID(a,b) smb_ReleaseTIDDbg(a,b,__FILE__,__LINE__);
593 #else
594 extern smb_tid_t *smb_FindTID(smb_vc_t *vcp, unsigned short tid, int flags);
595
596 extern void smb_HoldTIDNoLock(smb_tid_t *tidp);
597
598 extern void smb_ReleaseTID(smb_tid_t *tidp, afs_uint32 locked);
599 #endif
600
601 extern smb_user_t *smb_FindUID(smb_vc_t *vcp, unsigned short uid, int flags);
602
603 extern smb_username_t *smb_FindUserByName(clientchar_t *usern, clientchar_t *machine, afs_uint32 flags);
604
605 extern cm_user_t *smb_FindCMUserByName(clientchar_t *usern, clientchar_t *machine, afs_uint32 flags);
606
607 extern smb_user_t *smb_FindUserByNameThisSession(smb_vc_t *vcp, clientchar_t *usern); 
608
609 extern void smb_ReleaseUsername(smb_username_t *unp);
610
611 extern void smb_HoldUIDNoLock(smb_user_t *uidp);
612
613 extern void smb_ReleaseUID(smb_user_t *uidp);
614
615 extern cm_user_t *smb_GetUserFromVCP(smb_vc_t *vcp, smb_packet_t *inp);
616
617 extern cm_user_t *smb_GetUserFromUID(smb_user_t *uidp);
618
619 extern long smb_LookupTIDPath(smb_vc_t *vcp, unsigned short tid, clientchar_t ** tidPathp);
620
621 #ifdef DEBUG_SMB_REFCOUNT
622 extern smb_fid_t *smb_FindFIDDbg(smb_vc_t *vcp, unsigned short fid, int flags, char *, long);
623 #define smb_FindFID(a,b,c) smb_FindFIDDbg(a,b,c,__FILE__,__LINE__);
624
625 extern smb_fid_t *smb_FindFIDByScacheDbg(smb_vc_t *vcp, cm_scache_t * scp, char *, long);
626 #define smb_FindFIDByScache(a,b) smb_FindFIDByScacheDbg(a,b,__FILE__,__LINE__);
627
628 extern void smb_HoldFIDNoLockDbg(smb_fid_t *fidp, char *, long);
629 #define smb_HoldFIDNoLock(a) smb_HoldFIDNoLockDbg(a,__FILE__,__LINE__);
630
631 extern void smb_ReleaseFIDDbg(smb_fid_t *fidp, char *, long);
632 #define smb_ReleaseFID(a) smb_ReleaseFIDDbg(a,__FILE__,__LINE__);
633 #else
634 extern smb_fid_t *smb_FindFID(smb_vc_t *vcp, unsigned short fid, int flags);
635
636 extern smb_fid_t *smb_FindFIDByScache(smb_vc_t *vcp, cm_scache_t * scp);
637
638 extern void smb_HoldFIDNoLock(smb_fid_t *fidp);
639
640 extern void smb_ReleaseFID(smb_fid_t *fidp);
641 #endif
642
643 extern long smb_CloseFID(smb_vc_t *vcp, smb_fid_t *fidp, cm_user_t *userp,
644                          afs_uint32 dosTime);
645
646 extern int smb_FindShare(smb_vc_t *vcp, smb_user_t *uidp, clientchar_t *shareName, clientchar_t **pathNamep);
647
648 extern int smb_FindShareCSCPolicy(clientchar_t *shareName);
649
650 extern smb_dirSearch_t *smb_FindDirSearchNL(long cookie);
651
652 extern void smb_DeleteDirSearch(smb_dirSearch_t *dsp);
653
654 extern void smb_ReleaseDirSearch(smb_dirSearch_t *dsp);
655
656 extern smb_dirSearch_t *smb_FindDirSearch(long cookie);
657
658 extern smb_dirSearch_t *smb_NewDirSearch(int isV3);
659
660 extern smb_packet_t *smb_CopyPacket(smb_packet_t *packetp);
661
662 extern void smb_FreePacket(smb_packet_t *packetp);
663
664 extern unsigned char *smb_GetSMBData(smb_packet_t *smbp, int *nbytesp);
665
666 extern void smb_SetSMBDataLength(smb_packet_t *smbp, unsigned int dsize);
667
668 extern unsigned short smb_GetSMBParm(smb_packet_t *smbp, int parm);
669
670 extern unsigned char smb_GetSMBParmByte(smb_packet_t *smbp, int parm);
671
672 extern unsigned int smb_GetSMBParmLong(smb_packet_t *smbp, int parm);
673
674 extern unsigned int smb_GetSMBOffsetParm(smb_packet_t *smbp, int parm, int offset);
675
676 extern void smb_SetSMBParm(smb_packet_t *smbp, int slot, unsigned int parmValue);
677
678 extern void smb_SetSMBParmLong(smb_packet_t *smbp, int slot, unsigned int parmValue);
679
680 extern void smb_SetSMBParmDouble(smb_packet_t *smbp, int slot, char *parmValuep);
681
682 extern void smb_SetSMBParmByte(smb_packet_t *smbp, int slot, unsigned int parmValue);
683
684 extern void smb_StripLastComponent(clientchar_t *outPathp, clientchar_t **lastComponentp,
685         clientchar_t *inPathp);
686
687 #define SMB_STRF_FORCEASCII (1<<0)
688 #define SMB_STRF_ANSIPATH   (1<<1)
689 #define SMB_STRF_IGNORENUL  (1<<2)
690 #define SMB_STRF_SRCNULTERM (1<<3)
691
692 extern clientchar_t *smb_ParseASCIIBlock(smb_packet_t * pktp, unsigned char *inp,
693                                          char **chainpp, int flags);
694
695 extern clientchar_t *smb_ParseString(smb_packet_t * pktp, unsigned char * inp,
696                                      char ** chainpp, int flags);
697
698 extern clientchar_t *smb_ParseStringBuf(const unsigned char * bufbase,
699                                         cm_space_t ** stringspp,
700                                         unsigned char *inp, size_t *pcb_max,
701                                         char **chainpp, int flags);
702
703 extern clientchar_t *smb_ParseStringCb(smb_packet_t * pktp, unsigned char * inp,
704                                        size_t cb, char ** chainpp, int flags);
705
706 extern clientchar_t *smb_ParseStringCch(smb_packet_t * pktp, unsigned char * inp,
707                                         size_t cch, char ** chainpp, int flags);
708
709 extern unsigned char * smb_UnparseString(smb_packet_t * pktp, unsigned char * outp,
710                                    clientchar_t * str,
711                                    size_t * plen, int flags);
712
713 extern unsigned char *smb_ParseVblBlock(unsigned char *inp, char **chainpp,
714                                   int *lengthp);
715
716 extern smb_packet_t *smb_GetResponsePacket(smb_vc_t *vcp, smb_packet_t *inp);
717
718 extern void smb_SendPacket(smb_vc_t *vcp, smb_packet_t *inp);
719
720 extern void smb_MapCoreError(long code, smb_vc_t *vcp, unsigned short *scodep,
721         unsigned char *classp);
722
723 extern void smb_MapNTError(long code, unsigned long *NTStatusp);
724
725 extern void smb_MapWin32Error(long code, unsigned long *Win32Ep);
726
727 /* some globals, too */
728 extern char *smb_localNamep;
729
730 extern osi_log_t *smb_logp;
731
732 extern osi_rwlock_t smb_globalLock;
733
734 extern osi_rwlock_t smb_rctLock;
735
736 extern int smb_LogoffTokenTransfer;
737 extern time_t smb_LogoffTransferTimeout;
738
739 extern int smb_maxVCPerServer; /* max # of VCs per server */
740 extern int smb_maxMpxRequests; /* max # of mpx requests */
741
742 extern int smb_StoreAnsiFilenames;
743 extern int smb_hideDotFiles;
744 extern unsigned int smb_IsDotFile(clientchar_t *lastComp);
745 extern afs_uint32 smb_AsyncStore;
746 extern afs_uint32 smb_AsyncStoreSize;
747
748 /* the following are used for smb auth */
749 extern int smb_authType; /* Type of SMB authentication to be used. One from below. */
750
751 #define SMB_AUTH_NONE 0
752 #define SMB_AUTH_NTLM 1
753 #define SMB_AUTH_EXTENDED 2
754
755 extern HANDLE smb_lsaHandle; /* LSA handle obtained during smb_init if using SMB auth */
756 extern ULONG smb_lsaSecPackage; /* LSA security package id. Set during smb_init */
757 extern clientchar_t smb_ServerDomainName[];
758 extern int smb_ServerDomainNameLength;
759 extern clientchar_t smb_ServerOS[];
760 extern int smb_ServerOSLength;
761 extern clientchar_t smb_ServerLanManager[];
762 extern int smb_ServerLanManagerLength;
763 extern GUID smb_ServerGUID;
764 extern LSA_STRING smb_lsaLogonOrigin;
765 extern LONG smb_UseUnicode;
766
767 /* used for getting a challenge for SMB auth */
768 typedef struct _MSV1_0_LM20_CHALLENGE_REQUEST {  
769     MSV1_0_PROTOCOL_MESSAGE_TYPE MessageType;
770 } MSV1_0_LM20_CHALLENGE_REQUEST, *PMSV1_0_LM20_CHALLENGE_REQUEST;
771
772 typedef struct _MSV1_0_LM20_CHALLENGE_RESPONSE {  
773     MSV1_0_PROTOCOL_MESSAGE_TYPE MessageType;  
774     UCHAR ChallengeToClient[MSV1_0_CHALLENGE_LENGTH];
775 } MSV1_0_LM20_CHALLENGE_RESPONSE, *PMSV1_0_LM20_CHALLENGE_RESPONSE;
776 /**/
777
778 extern long smb_AuthenticateUserLM(smb_vc_t *vcp, clientchar_t * accountName, clientchar_t * primaryDomain, char * ciPwd, unsigned ciPwdLength, char * csPwd, unsigned csPwdLength);
779
780 extern long smb_GetNormalizedUsername(clientchar_t * usern, const clientchar_t * accountName, const clientchar_t * domainName);
781
782 extern void smb_FormatResponsePacket(smb_vc_t *vcp, smb_packet_t *inp,
783         smb_packet_t *op);
784
785 extern char *myCrt_Dispatch(int i); 
786
787 extern char *myCrt_2Dispatch(int i);
788
789 extern char *myCrt_RapDispatch(int i);
790
791 extern char * myCrt_NmpipeDispatch(int i);
792
793 extern unsigned int smb_Attributes(cm_scache_t *scp);
794
795 extern int smb_ChainFID(int fid, smb_packet_t *inp);
796
797 extern unsigned char *smb_ParseDataBlock(unsigned char *inp, char **chainpp, int *lengthp);
798
799 extern unsigned char *smb_ParseVblBlock(unsigned char *inp, char **chainpp, int *lengthp);
800
801 extern int smb_SUser(cm_user_t *userp);
802
803 long smb_WriteData(smb_fid_t *fidp, osi_hyper_t *offsetp, afs_uint32 count, char *op,
804         cm_user_t *userp, long *writtenp);
805
806 extern long smb_ReadData(smb_fid_t *fidp, osi_hyper_t *offsetp, afs_uint32 count,
807         char *op, cm_user_t *userp, long *readp);
808
809 extern long smb_Rename(smb_vc_t *vcp, smb_packet_t *inp, clientchar_t *oldPathp, clientchar_t *newPathp, int attrs);
810
811 extern long smb_Link(smb_vc_t *vcp, smb_packet_t *inp, clientchar_t *oldPathp, clientchar_t *newPathp);
812
813 extern BOOL smb_IsLegalFilename(clientchar_t *filename);
814
815 extern char *smb_GetSharename(void);
816
817 extern DWORD smb_ServerExceptionFilter(void);
818
819 extern void smb_RestartListeners(int);
820 extern void smb_StopListeners(int);
821 extern void smb_StopListener(NCB *ncbp, int lana, int wait);
822 extern long smb_IsNetworkStarted(void);
823 extern void smb_LanAdapterChange(int);
824 extern void smb_SetLanAdapterChangeDetected(void);
825
826 extern void smb_InitReq(cm_req_t *reqp);
827
828 #define SMB_LISTENER_UNINITIALIZED -1
829 #define SMB_LISTENER_STOPPED 0
830 #define SMB_LISTENER_STARTED 1
831
832 /* include other include files */
833 #include "smb3.h"
834 #include "smb_ioctl.h"
835 #include "smb_iocons.h"
836 #include "smb_rpc.h"
837 #include "cm_vnodeops.h"
838
839 extern int smb_unixModeDefaultFile;
840 extern int smb_unixModeDefaultDir;
841 extern void smb_SetInitialModeBitsForFile(int smb_attr, cm_attr_t * attr);
842 extern void smb_SetInitialModeBitsForDir(int smb_attr, cm_attr_t * attr);
843
844 cm_user_t *smb_FindOrCreateUser(smb_vc_t *vcp, clientchar_t *usern);
845
846 int smb_DumpVCP(FILE *outputFile, char *cookie, int lock);
847
848 void smb_Shutdown(void);
849
850 #ifdef NOTSERVICE
851 extern void smb_LogPacket(smb_packet_t *packet);
852 #endif /* NOTSERVICE */
853
854 #ifndef MSV1_0_OPTION_ALLOW_BLANK_PASSWORD
855 #define MSV1_0_OPTION_ALLOW_BLANK_PASSWORD      0x1
856 #define MSV1_0_OPTION_DISABLE_ADMIN_LOCKOUT     0x2
857 #define MSV1_0_OPTION_DISABLE_FORCE_GUEST       0x4
858 #define MSV1_0_OPTION_TRY_CACHE_FIRST           0x10
859
860 typedef struct _MSV1_0_SETPROCESSOPTION_REQUEST {
861     MSV1_0_PROTOCOL_MESSAGE_TYPE MessageType;
862     ULONG ProcessOptions;
863     BOOLEAN DisableOptions;
864 } MSV1_0_SETPROCESSOPTION_REQUEST, *PMSV1_0_SETPROCESSOPTION_REQUEST; 
865 #endif
866
867 #endif /* whole file */