source: branches/samba-3.2.x/source/include/rpc_misc.h

Last change on this file was 133, checked in by Paul Smedley, 17 years ago

Update trunk to 3.2.0pre3

File size: 10.2 KB
Line 
1/*
2 Unix SMB/CIFS implementation.
3
4 Copyright (C) Andrew Tridgell 1992-1997
5 Copyright (C) Luke Kenneth Casson Leighton 1996-1997
6 Copyright (C) Paul Ashton 1997
7 Copyright (C) Gerald (Jerry) Carter 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 _RPC_MISC_H /* _RPC_MISC_H */
24#define _RPC_MISC_H
25
26#define SMB_RPC_INTERFACE_VERSION 1
27#define PRS_POINTER_CAST bool (*)(const char*, prs_struct*, int, void*)
28
29enum unistr2_term_codes { UNI_FLAGS_NONE = 0, UNI_STR_TERMINATE = 1, UNI_MAXLEN_TERMINATE = 2, UNI_BROKEN_NON_NULL = 3, UNI_STR_DBLTERMINATE = 4 };
30
31
32
33/**********************************************************************
34 * well-known RIDs - Relative IDs
35 **********************************************************************/
36
37/* RIDs - Well-known users ... */
38#define DOMAIN_USER_RID_ADMIN (0x000001F4L)
39#define DOMAIN_USER_RID_GUEST (0x000001F5L)
40#define DOMAIN_USER_RID_KRBTGT (0x000001F6L)
41
42/* RIDs - well-known groups ... */
43#define DOMAIN_GROUP_RID_ADMINS (0x00000200L)
44#define DOMAIN_GROUP_RID_USERS (0x00000201L)
45#define DOMAIN_GROUP_RID_GUESTS (0x00000202L)
46#define DOMAIN_GROUP_RID_COMPUTERS (0x00000203L)
47
48#define DOMAIN_GROUP_RID_CONTROLLERS (0x00000204L)
49#define DOMAIN_GROUP_RID_CERT_ADMINS (0x00000205L)
50#define DOMAIN_GROUP_RID_SCHEMA_ADMINS (0x00000206L)
51#define DOMAIN_GROUP_RID_ENTERPRISE_ADMINS (0x00000207L)
52
53/* is the following the right number? I bet it is --simo
54#define DOMAIN_GROUP_RID_POLICY_ADMINS (0x00000208L)
55*/
56
57/* RIDs - well-known aliases ... */
58#define BUILTIN_ALIAS_RID_ADMINS (0x00000220L)
59#define BUILTIN_ALIAS_RID_USERS (0x00000221L)
60#define BUILTIN_ALIAS_RID_GUESTS (0x00000222L)
61#define BUILTIN_ALIAS_RID_POWER_USERS (0x00000223L)
62
63#define BUILTIN_ALIAS_RID_ACCOUNT_OPS (0x00000224L)
64#define BUILTIN_ALIAS_RID_SYSTEM_OPS (0x00000225L)
65#define BUILTIN_ALIAS_RID_PRINT_OPS (0x00000226L)
66#define BUILTIN_ALIAS_RID_BACKUP_OPS (0x00000227L)
67
68#define BUILTIN_ALIAS_RID_REPLICATOR (0x00000228L)
69#define BUILTIN_ALIAS_RID_RAS_SERVERS (0x00000229L)
70#define BUILTIN_ALIAS_RID_PRE_2K_ACCESS (0x0000022aL)
71
72
73/**********************************************************************
74 * Masks for mappings between unix uid and gid types and
75 * NT RIDS.
76 **********************************************************************/
77
78#define BASE_RID (0x000003E8L)
79
80/* Take the bottom bit. */
81#define RID_TYPE_MASK 1
82#define RID_MULTIPLIER 2
83
84/* The two common types. */
85#define USER_RID_TYPE 0
86#define GROUP_RID_TYPE 1
87
88
89
90/**********************************************************************
91 * RPC policy handle used pretty much everywhere
92 **********************************************************************/
93
94typedef struct policy_handle POLICY_HND;
95typedef struct {
96 uint32 ptr_hnd; /* pointer to enumeration handle */
97 uint32 handle; /* enumeration handle */
98} ENUM_HND;
99
100#define OUR_HANDLE(hnd) (((hnd)==NULL) ? "NULL" :\
101 ( IVAL((hnd)->uuid.node,2) == (uint32)sys_getpid() ? "OURS" : \
102 "OTHER")), ((unsigned int)IVAL((hnd)->uuid.node,2)),\
103 ((unsigned int)sys_getpid() )
104
105
106/**********************************************************************
107 * Buffer Headers -- use by SEC_DESC_BUF in winreg and netlogon code
108 **********************************************************************/
109
110/* TODO: replace this with an encompassing buffer structure */
111typedef struct {
112 uint32 buf_max_len;
113 uint32 buf_len;
114} BUFHDR;
115
116/* this is a BUFHDR + a pointer to a buffer */
117typedef struct {
118 uint32 info_level;
119 uint32 length; /* uint8 chars */
120 uint32 buffer;
121} BUFHDR2;
122
123/* generic buffer ? wrapped around void*? */
124typedef struct {
125 uint32 size;
126 uint32 buffer;
127} BUFHDR4;
128
129
130/**********************************************************************
131 * Buffers
132 **********************************************************************/
133
134/* buffer used by \winreg\ calls to fill in arbitrary REG_XXX values.
135 It *may* look like a UNISTR2 but it is *not*. This is not a goof
136 by the winreg developers. It is a generic buffer. buffer length
137 is stored in bytes (not # of uint16's) */
138
139typedef struct {
140 uint32 buf_max_len;
141 uint32 offset;
142 uint32 buf_len;
143 uint16 *buffer;
144} REGVAL_BUFFER;
145
146/* generic rpc version of the DATA_BLOB. Just a length and uint8 array */
147
148typedef struct {
149 uint32 buf_len;
150 uint8 *buffer;
151} RPC_DATA_BLOB;
152
153/**********************************************************************
154 * Buffers use by spoolss (i might be able to replace it with
155 * an RPC_DATA_BLOB)
156 **********************************************************************/
157
158typedef struct {
159 uint32 buf_len;
160 uint16 *buffer; /* data */
161} BUFFER5;
162
163
164/**********************************************************************
165 * Unicode and basic string headers
166 **********************************************************************/
167
168typedef struct {
169 uint16 str_str_len;
170 uint16 str_max_len;
171 uint32 buffer; /* non-zero */
172} STRHDR;
173
174typedef struct {
175 uint16 uni_str_len;
176 uint16 uni_max_len;
177 uint32 buffer;
178} UNIHDR;
179
180/**********************************************************************
181 * UNICODE string variations
182 **********************************************************************/
183
184
185typedef struct { /* UNISTR - unicode string size and buffer */
186 uint16 *buffer; /* unicode characters. ***MUST*** be
187 little-endian. ***MUST*** be null-terminated */
188} UNISTR;
189
190typedef struct { /* UNISTR2 - unicode string size (in
191 uint16 unicode chars) and buffer */
192 uint32 uni_max_len;
193 uint32 offset;
194 uint32 uni_str_len;
195 uint16 *buffer; /* unicode characters. ***MUST*** be little-endian.
196 **must** be null-terminated and the uni_str_len
197 should include the NULL character */
198} UNISTR2;
199
200/* i think this is the same as a BUFFER5 used in the spoolss code --jerry */
201/* not sure about how the termination matches between the uint16 buffers thought */
202
203typedef struct { /* UNISTR3 - XXXX not sure about this structure */
204 uint32 uni_str_len;
205 UNISTR str;
206} UNISTR3;
207
208typedef struct { /* Buffer wrapped around a UNISTR2 */
209 uint16 length; /* number of bytes not counting NULL terminatation */
210 uint16 size; /* number of bytes including NULL terminatation */
211 UNISTR2 *string;
212} UNISTR4;
213
214typedef struct {
215 uint32 count;
216 UNISTR4 *strings;
217} UNISTR4_ARRAY;
218
219
220/**********************************************************************
221 * String variations
222 **********************************************************************/
223
224typedef struct { /* STRING2 - string size (in uint8 chars) and buffer */
225 uint32 str_max_len;
226 uint32 offset;
227 uint32 str_str_len;
228 uint8 *buffer; /* uint8 characters. **NOT** necessarily null-terminated */
229} STRING2;
230
231
232
233
234/**********************************************************************
235 * Domain SID structures
236 **********************************************************************/
237
238typedef struct {
239 uint32 num_auths; /* length, bytes, including length of len :-) */
240 DOM_SID sid;
241} DOM_SID2;
242
243
244/**********************************************************************
245 * Domain SID structures
246 **********************************************************************/
247
248/* DOM_RID - domain RID structure for ntlsa pipe */
249typedef struct {
250 uint16 type; /* value is SID_NAME_USE enum */
251 uint32 rid;
252 uint32 rid_idx; /* referenced domain index */
253} DOM_RID;
254
255/* DOM_RID2 - second domain RID structure for ntlsa pipe */
256typedef struct {
257 uint16 type; /* value is SID_NAME_USE enum */
258 uint32 rid;
259 uint32 rid_idx; /* referenced domain index */
260 uint32 unknown;
261} DOM_RID2;
262
263typedef struct { /* DOM_RID3 - domain RID structure for samr pipe */
264 uint32 rid; /* domain-relative (to a SID) id */
265 uint32 type1; /* value is 0x1 */
266 uint32 ptr_type; /* undocumented pointer */
267 uint32 type2; /* value is 0x1 */
268 uint32 unk; /* value is 0x2 */
269} DOM_RID3;
270
271/* DOM_RID4 - rid + user attributes */
272typedef struct domrid4_info
273{
274 uint32 unknown;
275 uint16 attr;
276 uint32 rid; /* user RID */
277} DOM_RID4;
278
279/* DOM_GID - group id + user attributes */
280typedef struct {
281 uint32 g_rid; /* a group RID */
282 uint32 attr;
283} DOM_GID;
284
285/**********************************************************************
286 * ????
287 **********************************************************************/
288
289/* DOM_CLNT_SRV - client / server names */
290typedef struct clnt_srv_info {
291 uint32 undoc_buffer; /* undocumented 32 bit buffer pointer */
292 UNISTR2 uni_logon_srv; /* logon server name */
293 uint32 undoc_buffer2; /* undocumented 32 bit buffer pointer */
294 UNISTR2 uni_comp_name; /* client machine name */
295} DOM_CLNT_SRV;
296
297/* DOM_LOG_INFO - login info */
298typedef struct log_info {
299 uint32 undoc_buffer; /* undocumented 32 bit buffer pointer */
300 UNISTR2 uni_logon_srv; /* logon server name */
301 UNISTR2 uni_acct_name; /* account name */
302 uint16 sec_chan; /* secure channel type */
303 UNISTR2 uni_comp_name; /* client machine name */
304} DOM_LOG_INFO;
305
306/* DOM_CHAL - challenge info */
307typedef struct chal_info {
308 unsigned char data[8]; /* credentials */
309} DOM_CHAL;
310
311/* DOM_CREDs - timestamped client or server credentials */
312typedef struct cred_info {
313 DOM_CHAL challenge; /* credentials */
314 UTIME timestamp; /* credential time-stamp */
315} DOM_CRED;
316
317/* DOM_CLNT_INFO - client info */
318typedef struct clnt_info {
319 DOM_LOG_INFO login;
320 DOM_CRED cred;
321} DOM_CLNT_INFO;
322
323/* DOM_CLNT_INFO2 - client info */
324typedef struct clnt_info2 {
325 DOM_CLNT_SRV login;
326 uint32 ptr_cred;
327 DOM_CRED cred;
328} DOM_CLNT_INFO2;
329
330/* DOM_LOGON_ID - logon id */
331typedef struct logon_info {
332 uint32 low;
333 uint32 high;
334} DOM_LOGON_ID;
335
336/* OWF INFO */
337typedef struct owf_info {
338 uint8 data[16];
339} OWF_INFO;
340
341
342#endif /* _RPC_MISC_H */
Note: See TracBrowser for help on using the repository browser.