2 Unix SMB/Netbios implementation.
4 SMB parameters and setup
5 Copyright (C) Andrew Tridgell 1992-1997
6 Copyright (C) Luke Kenneth Casson Leighton 1996-1997
7 Copyright (C) Paul Ashton 1997
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 2 of the License, or
12 (at your option) any later version.
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.
19 You should have received a copy of the GNU General Public License
20 along with this program; if not, write to the Free Software
21 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
24 #ifndef _RPC_REG_H /* _RPC_REG_H */
28 /* winreg pipe defines */
29 #define REG_OPEN_HKLM 0x02
30 #define REG_OPEN_HKU 0x04
31 #define REG_FLUSH_KEY 0x0B
32 #define REG_UNK_1A 0x1a
33 #define REG_QUERY_KEY 0x10
34 #define REG_ENUM_KEY 0x09
35 #define REG_CREATE_KEY 0x06
36 #define REG_DELETE_KEY 0x07
37 #define REG_DELETE_VALUE 0x08
38 #define REG_CREATE_VALUE 0x16
39 #define REG_GET_KEY_SEC 0x0c
40 #define REG_ENUM_VALUE 0x0a
41 #define REG_OPEN_ENTRY 0x0f
43 #define REG_CLOSE 0x05
45 #define HKEY_LOCAL_MACHINE 0x80000000
46 #define HKEY_USERS 0x80000003
49 typedef struct q_reg_open_policy_info
52 uint16 unknown_0; /* 0xE084 - 16 bit unknown */
53 uint16 unknown_1; /* random. changes */
54 uint32 level; /* 0x0000 0002 - 32 bit unknown */
59 typedef struct r_reg_open_policy_info
61 POLICY_HND pol; /* policy handle */
62 uint32 status; /* return status */
68 typedef struct q_reg_open_unk4_info
71 uint16 unknown_0; /* 0xE084 - 16 bit unknown */
72 uint16 unknown_1; /* random. changes */
73 uint32 level; /* 0x0000 0002 - 32 bit unknown */
78 typedef struct r_reg_open_unk4_info
80 POLICY_HND pol; /* policy handle */
81 uint32 status; /* return status */
87 typedef struct q_reg_open_flush_key_info
89 POLICY_HND pol; /* policy handle */
94 typedef struct r_reg_open_flush_key_info
96 uint32 status; /* return status */
101 /* REG_Q_GET_KEY_SEC */
102 typedef struct q_reg_get_key_sec_info
104 POLICY_HND pol; /* policy handle */
106 uint32 unknown; /* 0x0000 0007 */
108 uint32 ptr; /* pointer */
109 BUFHDR hdr_sec; /* header for security data */
110 SEC_DESC_BUF *data; /* security data */
114 /* REG_R_GET_KEY_SEC */
115 typedef struct r_reg_get_key_sec_info
117 uint32 unknown; /* 0x0000 0007 */
119 uint32 ptr; /* pointer */
120 BUFHDR hdr_sec; /* header for security data */
121 SEC_DESC_BUF *data; /* security data */
127 /* REG_Q_CREATE_VALUE */
128 typedef struct q_reg_create_value_info
130 POLICY_HND pol; /* policy handle */
132 UNIHDR hdr_name; /* name of value */
135 uint32 type; /* 1 = UNISTR, 3 = BYTES, 4 = DWORD, 7 = MULTI_UNISTR */
137 BUFFER3 *buf_value; /* value, in byte buffer */
139 } REG_Q_CREATE_VALUE;
141 /* REG_R_CREATE_VALUE */
142 typedef struct r_reg_create_value_info
144 uint32 status; /* return status */
146 } REG_R_CREATE_VALUE;
148 /* REG_Q_ENUM_VALUE */
149 typedef struct q_reg_query_value_info
151 POLICY_HND pol; /* policy handle */
153 uint32 val_index; /* index */
155 UNIHDR hdr_name; /* name of value */
158 uint32 ptr_type; /* pointer */
159 uint32 type; /* 1 = UNISTR, 3 = BYTES, 4 = DWORD, 7 = MULTI_UNISTR */
161 uint32 ptr_value; /* pointer */
162 BUFFER2 buf_value; /* value, in byte buffer */
164 uint32 ptr1; /* pointer */
165 uint32 len_value1; /* */
167 uint32 ptr2; /* pointer */
168 uint32 len_value2; /* */
172 /* REG_R_ENUM_VALUE */
173 typedef struct r_reg_enum_value_info
175 UNIHDR hdr_name; /* name of value */
178 uint32 ptr_type; /* pointer */
179 uint32 type; /* 1 = UNISTR, 3 = BYTES, 4 = DWORD, 7 = MULTI_UNISTR */
181 uint32 ptr_value; /* pointer */
182 BUFFER2 *buf_value; /* value, in byte buffer */
184 uint32 ptr1; /* pointer */
185 uint32 len_value1; /* */
187 uint32 ptr2; /* pointer */
188 uint32 len_value2; /* */
190 uint32 status; /* return status */
194 /* REG_Q_CREATE_KEY */
195 typedef struct q_reg_create_key_info
197 POLICY_HND pnt_pol; /* parent key policy handle */
205 uint32 reserved; /* 0x0000 0000 */
206 SEC_INFO sam_access; /* access rights flags, see rpc_secdes.h */
209 uint32 unknown_0; /* 0x0000 000C */
212 uint32 sec_len1; /* 0x14 - length of security descriptor, bytes */
213 uint32 sec_len2; /* 0x14 - length of security descriptor, bytes */
214 uint32 sec_len3; /* 0x0 - length of security descriptor, bytes */
215 uint32 sec_len4; /* 0x14 - length of security descriptor, bytes */
216 uint32 sec_len5; /* 0x0 - length of security descriptor, bytes */
217 uint32 sec_len6; /* 0x14 - length of security descriptor, bytes */
221 uint8 buf_unk[20]; /* 01 00 00 80 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 */
224 uint32 unknown_2; /* 0x0000 0000 */
228 /* REG_R_CREATE_KEY */
229 typedef struct r_reg_create_key_info
231 POLICY_HND key_pol; /* policy handle */
232 uint32 unknown; /* 0x0000 0000 */
234 uint32 status; /* return status */
238 /* REG_Q_DELETE_KEY */
239 typedef struct q_reg_delete_key_info
241 POLICY_HND pnt_pol; /* parent key policy handle */
247 /* REG_R_DELETE_KEY */
248 typedef struct r_reg_delete_key_info
250 POLICY_HND key_pol; /* policy handle */
252 uint32 status; /* return status */
256 /* REG_Q_DELETE_VALUE */
257 typedef struct q_reg_delete_val_info
259 POLICY_HND pnt_pol; /* parent key policy handle */
264 } REG_Q_DELETE_VALUE;
266 /* REG_R_DELETE_VALUE */
267 typedef struct r_reg_delete_val_info
269 POLICY_HND key_pol; /* policy handle */
271 uint32 status; /* return status */
273 } REG_R_DELETE_VALUE;
275 /* REG_Q_QUERY_KEY */
276 typedef struct q_reg_query_info
278 POLICY_HND pol; /* policy handle */
284 /* REG_R_QUERY_KEY */
285 typedef struct r_reg_query_key_info
291 uint32 max_subkeylen;
292 uint32 max_subkeysize; /* 0x0000 0000 */
294 uint32 max_valnamelen;
295 uint32 max_valbufsize;
296 uint32 sec_desc; /* 0x0000 0078 */
297 NTTIME mod_time; /* modified time */
299 uint32 status; /* return status */
305 typedef struct q_reg_unk_1a_info
307 POLICY_HND pol; /* policy handle */
312 typedef struct r_reg_unk_1a_info
314 uint32 unknown; /* 0x0500 0000 */
315 uint32 status; /* return status */
321 typedef struct reg_q_close_info
323 POLICY_HND pol; /* policy handle */
328 typedef struct reg_r_close_info
330 POLICY_HND pol; /* policy handle. should be all zeros. */
332 uint32 status; /* return code */
338 typedef struct q_reg_enum_value_info
340 POLICY_HND pol; /* policy handle */
344 uint16 key_name_len; /* 0x0000 */
345 uint16 unknown_1; /* 0x0414 */
347 uint32 ptr1; /* pointer */
348 uint32 unknown_2; /* 0x0000 020A */
349 uint8 pad1[8]; /* padding - zeros */
351 uint32 ptr2; /* pointer */
352 uint8 pad2[8]; /* padding - zeros */
354 uint32 ptr3; /* pointer */
355 NTTIME time; /* current time? */
360 typedef struct r_reg_enum_key_info
362 uint16 key_name_len; /* number of bytes in key name */
363 uint16 unknown_1; /* 0x0414 - matches with query unknown_1 */
365 uint32 ptr1; /* pointer */
366 uint32 unknown_2; /* 0x0000 020A */
367 uint32 unknown_3; /* 0x0000 0000 */
371 uint32 ptr2; /* pointer */
372 uint8 pad2[8]; /* padding - zeros */
374 uint32 ptr3; /* pointer */
375 NTTIME time; /* current time? */
377 uint32 status; /* return status */
383 typedef struct q_reg_info_info
385 POLICY_HND pol; /* policy handle */
387 UNIHDR hdr_type; /* unicode product type header */
388 UNISTR2 uni_type; /* unicode product type - "ProductType" */
390 uint32 ptr1; /* pointer */
391 NTTIME time; /* current time? */
392 uint8 major_version1; /* 0x4 - os major version? */
393 uint8 minor_version1; /* 0x1 - os minor version? */
394 uint8 pad1[10]; /* padding - zeros */
396 uint32 ptr2; /* pointer */
397 uint8 major_version2; /* 0x4 - os major version? */
398 uint8 minor_version2; /* 0x1 - os minor version? */
399 uint8 pad2[2]; /* padding - zeros */
401 uint32 ptr3; /* pointer */
402 uint32 unknown; /* 0x0000 0000 */
407 typedef struct r_reg_info_info
409 uint32 ptr1; /* buffer pointer */
410 uint32 level; /* 0x1 - info level? */
412 uint32 ptr_type; /* pointer to o/s type */
413 BUFFER2 uni_type; /* unicode string o/s type - "LanmanNT" */
415 uint32 ptr2; /* pointer to unknown_0 */
416 uint32 unknown_0; /* 0x12 */
418 uint32 ptr3; /* pointer to unknown_1 */
419 uint32 unknown_1; /* 0x12 */
421 uint32 status; /* return status */
426 /* REG_Q_OPEN_ENTRY */
427 typedef struct q_reg_open_entry_info
429 POLICY_HND pol; /* policy handle */
431 UNIHDR hdr_name; /* unicode registry string header */
432 UNISTR2 uni_name; /* unicode registry string name */
434 uint32 unknown_0; /* 32 bit unknown - 0x0000 0000 */
435 uint32 unknown_1; /* 32 bit unknown - 0x0200 0000 */
441 /* REG_R_OPEN_ENTRY */
442 typedef struct r_reg_open_entry_info
444 POLICY_HND pol; /* policy handle */
445 uint32 status; /* return status */
451 #endif /* _RPC_REG_H */