r24780: More work allowing libutil to be used by external users.
[kai/samba.git] / source4 / include / core.h
1 /* 
2    Unix SMB/CIFS implementation.
3    Core Samba data types
4
5    Copyright (C) Andrew Tridgell              1992-2000
6    Copyright (C) Stefan Metzmacher                        2004
7    Copyright (C) Jelmer Vernooij                          2005
8    
9    This program is free software; you can redistribute it and/or modify
10    it under the terms of the GNU General Public License as published by
11    the Free Software Foundation; either version 3 of the License, or
12    (at your option) any later version.
13    
14    This program is distributed in the hope that it will be useful,
15    but WITHOUT ANY WARRANTY; without even the implied warranty of
16    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17    GNU General Public License for more details.
18    
19    You should have received a copy of the GNU General Public License
20    along with this program.  If not, see <http://www.gnu.org/licenses/>.
21 */
22
23 #ifndef _SAMBA_CORE_H
24 #define _SAMBA_CORE_H
25
26 #include "libcli/util/nt_status.h"
27
28 #include <stdlib.h>
29
30 /* by making struct ldb_val and DATA_BLOB the same, we can simplify
31    a fair bit of code */
32 #define ldb_val datablob
33
34 /*
35   we use struct ipv4_addr to avoid having to include all the
36   system networking headers everywhere
37 */
38 struct ipv4_addr {
39         uint32_t addr;
40 };
41
42 typedef NTSTATUS (*init_module_fn) (void);
43
44 /* 
45    use the same structure for dom_sid2 as dom_sid. A dom_sid2 is really
46    just a dom sid, but with the sub_auths represented as a conformant
47    array. As with all in-structure conformant arrays, the array length
48    is placed before the start of the structure. That's what gives rise
49    to the extra num_auths elemenent. We don't want the Samba code to
50    have to bother with such esoteric NDR details, so its easier to just
51    define it as a dom_sid and use pidl magic to make it all work. It
52    just means you need to mark a sid as a "dom_sid2" in the IDL when you
53    know it is of the conformant array variety
54 */
55 #define dom_sid2 dom_sid
56
57 /* same struct as dom_sid but inside a 28 bytes fixed buffer in NDR */
58 #define dom_sid28 dom_sid
59
60 /* protocol types. It assumes that higher protocols include lower protocols
61    as subsets. FIXME: Move to one of the smb-specific headers */
62 enum protocol_types {
63         PROTOCOL_NONE,
64         PROTOCOL_CORE,
65         PROTOCOL_COREPLUS,
66         PROTOCOL_LANMAN1,
67         PROTOCOL_LANMAN2,
68         PROTOCOL_NT1,
69         PROTOCOL_SMB2
70 };
71
72 /* passed to br lock code. FIXME: Move to one of the smb-specific headers */
73 enum brl_type {
74         READ_LOCK,
75         WRITE_LOCK,
76         PENDING_READ_LOCK,
77         PENDING_WRITE_LOCK
78 };
79
80 enum server_role {
81         ROLE_STANDALONE=0,
82         ROLE_DOMAIN_MEMBER=1,
83         ROLE_DOMAIN_CONTROLLER=2,
84 };
85
86 enum announce_as {/* Types of machine we can announce as. */
87         ANNOUNCE_AS_NT_SERVER=1,
88         ANNOUNCE_AS_WIN95=2,
89         ANNOUNCE_AS_WFW=3,
90         ANNOUNCE_AS_NT_WORKSTATION=4
91 };
92
93 #endif /* _SAMBA_CORE_H */