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_POLICY 0x02
30 #define REG_OPEN_UNK_4 0x04
31 #define REG_UNK_1A 0x1a
32 #define REG_QUERY_KEY 0x10
33 #define REG_ENUM_KEY 0x09
34 #define REG_CREATE_KEY 0x06
35 #define REG_CREATE_VALUE 0x16
36 #define REG_GET_KEY_SEC 0x0c
37 #define REG_ENUM_VALUE 0x0a
38 #define REG_OPEN_ENTRY 0x0f
40 #define REG_CLOSE 0x05
43 /* REG_Q_OPEN_POLICY */
44 typedef struct q_reg_open_policy_info
47 uint16 unknown_0; /* 0xE084 - 16 bit unknown */
48 uint16 unknown_1; /* random. changes */
49 uint32 level; /* 0x0000 0002 - 32 bit unknown */
53 /* REG_R_OPEN_POLICY */
54 typedef struct r_reg_open_policy_info
56 POLICY_HND pol; /* policy handle */
57 uint32 status; /* return status */
62 /* REG_Q_OPEN_UNK_4 */
63 typedef struct q_reg_open_unk4_info
66 uint16 unknown_0; /* 0xE084 - 16 bit unknown */
67 uint16 unknown_1; /* random. changes */
68 uint32 level; /* 0x0000 0002 - 32 bit unknown */
72 /* REG_R_OPEN_UNK_4 */
73 typedef struct r_reg_open_unk4_info
75 POLICY_HND pol; /* policy handle */
76 uint32 status; /* return status */
81 /* REG_Q_GET_KEY_SEC */
82 typedef struct q_reg_get_key_sec_info
84 POLICY_HND pol; /* policy handle */
86 uint32 unknown; /* 0x0000 0007 */
88 uint32 ptr; /* pointer */
89 BUFHDR hdr_sec; /* header for security data */
90 SEC_DESC_BUF *data; /* security data */
94 /* REG_R_GET_KEY_SEC */
95 typedef struct r_reg_get_key_sec_info
97 uint32 unknown; /* 0x0000 0007 */
99 uint32 ptr; /* pointer */
100 BUFHDR hdr_sec; /* header for security data */
101 SEC_DESC_BUF *data; /* security data */
107 /* REG_Q_CREATE_VALUE */
108 typedef struct q_reg_create_value_info
110 POLICY_HND pol; /* policy handle */
112 UNIHDR hdr_name; /* name of value */
115 uint32 type; /* 1 = UNISTR, 3 = BYTES, 4 = DWORD, 7 = MULTI_UNISTR */
117 BUFFER3 *buf_value; /* value, in byte buffer */
119 } REG_Q_CREATE_VALUE;
121 /* REG_R_CREATE_VALUE */
122 typedef struct r_reg_create_value_info
124 uint32 status; /* return status */
126 } REG_R_CREATE_VALUE;
128 /* REG_Q_ENUM_VALUE */
129 typedef struct q_reg_query_value_info
131 POLICY_HND pol; /* policy handle */
133 uint32 val_index; /* index */
135 UNIHDR hdr_name; /* name of value */
138 uint32 ptr_type; /* pointer */
139 uint32 type; /* 1 = UNISTR, 3 = BYTES, 4 = DWORD, 7 = MULTI_UNISTR */
141 uint32 ptr_value; /* pointer */
142 BUFFER2 buf_value; /* value, in byte buffer */
144 uint32 ptr1; /* pointer */
145 uint32 len_value1; /* */
147 uint32 ptr2; /* pointer */
148 uint32 len_value2; /* */
152 /* REG_R_ENUM_VALUE */
153 typedef struct r_reg_enum_value_info
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; /* */
170 uint32 status; /* return status */
174 /* REG_Q_CREATE_KEY */
175 typedef struct q_reg_create_key_info
177 POLICY_HND pnt_pol; /* parent key policy handle */
185 uint32 reserved; /* 0x0000 0000 */
186 SEC_INFO sam_access; /* access rights flags, see rpc_secdes.h */
189 uint32 unknown_0; /* 0x0000 000C */
192 uint32 unk_len1; /* 0x0000 0014 */
193 uint32 unk_len2; /* 0x0000 0014 */
194 uint32 unknown_1; /* 0x0002 0000 */
195 BUFFER2 buf_unk; /* 01 00 00 80 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 */
197 uint32 unknown_2; /* 0x0000 0000 */
200 /* REG_R_CREATE_KEY */
201 typedef struct r_reg_create_key_info
203 POLICY_HND key_pol; /* policy handle */
204 uint32 unknown; /* 0x0000 0000 */
206 uint32 status; /* return status */
210 /* REG_Q_QUERY_KEY */
211 typedef struct q_reg_query_info
213 POLICY_HND pol; /* policy handle */
219 /* REG_R_QUERY_KEY */
220 typedef struct r_reg_query_key_info
226 uint32 max_subkeylen;
227 uint32 max_subkeysize; /* 0x0000 0000 */
229 uint32 max_valnamelen;
230 uint32 max_valbufsize;
231 uint32 sec_desc; /* 0x0000 0078 */
232 NTTIME mod_time; /* modified time */
234 uint32 status; /* return status */
240 typedef struct q_reg_unk_1a_info
242 POLICY_HND pol; /* policy handle */
247 typedef struct r_reg_unk_1a_info
249 uint32 unknown; /* 0x0500 0000 */
250 uint32 status; /* return status */
256 typedef struct reg_q_close_info
258 POLICY_HND pol; /* policy handle */
263 typedef struct reg_r_close_info
265 POLICY_HND pol; /* policy handle. should be all zeros. */
267 uint32 status; /* return code */
273 typedef struct q_reg_enum_value_info
275 POLICY_HND pol; /* policy handle */
279 uint16 key_name_len; /* 0x0000 */
280 uint16 unknown_1; /* 0x0414 */
282 uint32 ptr1; /* pointer */
283 uint32 unknown_2; /* 0x0000 020A */
284 uint8 pad1[8]; /* padding - zeros */
286 uint32 ptr2; /* pointer */
287 uint8 pad2[8]; /* padding - zeros */
289 uint32 ptr3; /* pointer */
290 NTTIME time; /* current time? */
295 typedef struct r_reg_enum_key_info
297 uint16 key_name_len; /* number of bytes in key name */
298 uint16 unknown_1; /* 0x0414 - matches with query unknown_1 */
300 uint32 ptr1; /* pointer */
301 uint32 unknown_2; /* 0x0000 020A */
302 uint32 unknown_3; /* 0x0000 0000 */
306 uint32 ptr2; /* pointer */
307 uint8 pad2[8]; /* padding - zeros */
309 uint32 ptr3; /* pointer */
310 NTTIME time; /* current time? */
312 uint32 status; /* return status */
318 typedef struct q_reg_info_info
320 POLICY_HND pol; /* policy handle */
322 UNIHDR hdr_type; /* unicode product type header */
323 UNISTR2 uni_type; /* unicode product type - "ProductType" */
325 uint32 ptr1; /* pointer */
326 NTTIME time; /* current time? */
327 uint8 major_version1; /* 0x4 - os major version? */
328 uint8 minor_version1; /* 0x1 - os minor version? */
329 uint8 pad1[10]; /* padding - zeros */
331 uint32 ptr2; /* pointer */
332 uint8 major_version2; /* 0x4 - os major version? */
333 uint8 minor_version2; /* 0x1 - os minor version? */
334 uint8 pad2[2]; /* padding - zeros */
336 uint32 ptr3; /* pointer */
337 uint32 unknown; /* 0x0000 0000 */
342 typedef struct r_reg_info_info
344 uint32 ptr1; /* buffer pointer */
345 uint32 level; /* 0x1 - info level? */
347 uint32 ptr_type; /* pointer to o/s type */
348 BUFFER2 uni_type; /* unicode string o/s type - "LanmanNT" */
350 uint32 ptr2; /* pointer to unknown_0 */
351 uint32 unknown_0; /* 0x12 */
353 uint32 ptr3; /* pointer to unknown_1 */
354 uint32 unknown_1; /* 0x12 */
356 uint32 status; /* return status */
361 /* REG_Q_OPEN_ENTRY */
362 typedef struct q_reg_open_entry_info
364 POLICY_HND pol; /* policy handle */
366 UNIHDR hdr_name; /* unicode registry string header */
367 UNISTR2 uni_name; /* unicode registry string name */
369 uint32 unknown_0; /* 32 bit unknown - 0x0000 0000 */
370 uint32 unknown_1; /* 32 bit unknown - 0x0200 0000 */
376 /* REG_R_OPEN_ENTRY */
377 typedef struct r_reg_open_entry_info
379 POLICY_HND pol; /* policy handle */
380 uint32 status; /* return status */
386 #endif /* _RPC_REG_H */