2 Unix SMB/CIFS implementation.
3 SMB parameters and setup
4 Copyright (C) Andrew Tridgell 1992-1997
5 Copyright (C) Luke Kenneth Casson Leighton 1996-1997
6 Copyright (C) Paul Ashton 1997
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
23 #ifndef _RPC_REG_H /* _RPC_REG_H */
27 /* winreg pipe defines
29 #define REG_OPEN_HKCR 0x00
30 #define _REG_UNK_01 0x01
31 #define _REG_UNK_03 0x03
32 #define REG_CREATE_KEY 0x06
33 #define REG_DELETE_KEY 0x07
34 #define REG_DELETE_VALUE 0x08
35 #define REG_ENUM_VALUE 0x0a
36 #define REG_FLUSH_KEY 0x0b
37 #define REG_GET_KEY_SEC 0x0c
38 #define _REG_UNK_0D 0x0d
39 #define _REG_UNK_0E 0x0e
40 #define _REG_UNK_12 0x12
41 #define _REG_UNK_13 0x13
42 #define _REG_UNK_14 0x14
43 #define REG_SET_KEY_SEC 0x15
44 #define REG_CREATE_VALUE 0x16
45 #define _REG_UNK_17 0x17
49 #define REG_OPEN_HKLM 0x02
50 #define REG_OPEN_HKU 0x04
51 #define REG_CLOSE 0x05
52 #define REG_ENUM_KEY 0x09
53 #define REG_OPEN_ENTRY 0x0f
54 #define REG_QUERY_KEY 0x10
56 #define REG_SHUTDOWN 0x18
57 #define REG_ABORT_SHUTDOWN 0x19
58 #define REG_UNKNOWN_1A 0x1a
61 #define HKEY_CLASSES_ROOT 0x80000000
62 #define HKEY_CURRENT_USER 0x80000001
63 #define HKEY_LOCAL_MACHINE 0x80000002
64 #define HKEY_USERS 0x80000003
66 #define KEY_HKLM "HKLM"
68 #define KEY_PRINTING "HKLM\\SYSTEM\\CurrentControlSet\\Control\\Print"
71 /* Registry data types */
75 #define REG_EXPAND_SZ 2
78 #define REG_DWORD_LE 4 /* DWORD, little endian */
79 #define REG_DWORD_BE 5 /* DWORD, big endian */
81 #define REG_MULTI_SZ 7
82 #define REG_RESOURCE_LIST 8
83 #define REG_FULL_RESOURCE_DESCRIPTOR 9
84 #define REG_RESOURCE_REQUIREMENTS_LIST 10
86 /* Shutdown options */
87 #define REG_FORCE_SHUTDOWN 0x001
88 #define REG_REBOOT_ON_SHUTDOWN 0x100
90 /* structure to contain registry values */
92 typedef struct _RegistryValue
{
95 uint32 size
; /* in bytes */
105 * container for function pointers to enumeration routines
106 * for vitural registry view
109 typedef struct _reg_ops
{
110 /* functions for enumerating subkeys and values */
111 int (*subkey_fn
)( char *key
, char **subkeys
);
112 int (*subkey_specific_fn
)( char *key
, char** subkey
, uint32 index
);
113 int (*value_fn
) ( char *key
, REGISTRY_VALUE
**val
);
114 BOOL (*store_subkeys_fn
)( char *key
, char **subkeys
, uint32 num_subkeys
);
115 BOOL (*store_values_fn
)( char *key
, REGISTRY_VALUE
**val
, uint32 num_values
);
118 typedef struct _reg_hook
{
119 char *keyname
; /* full path to name of key */
120 REGISTRY_OPS
*ops
; /* registry function hooks */
125 /* structure to store the registry handles */
127 typedef struct _RegistryKey
{
129 struct _RegistryKey
*prev
, *next
;
132 fstring name
; /* full name of registry key */
138 /* REG_Q_OPEN_HKCR */
139 typedef struct q_reg_open_hkcr_info
142 uint16 unknown_0
; /* 0x5428 - 16 bit unknown */
143 uint16 unknown_1
; /* random. changes */
144 uint32 level
; /* 0x0000 0002 - 32 bit unknown */
148 /* REG_R_OPEN_HKCR */
149 typedef struct r_reg_open_hkcr_info
151 POLICY_HND pol
; /* policy handle */
152 NTSTATUS status
; /* return status */
157 /* REG_Q_OPEN_HKLM */
158 typedef struct q_reg_open_hklm_info
161 uint16 unknown_0
; /* 0xE084 - 16 bit unknown */
162 uint16 unknown_1
; /* random. changes */
168 /* REG_R_OPEN_HKLM */
169 typedef struct r_reg_open_hklm_info
171 POLICY_HND pol
; /* policy handle */
172 NTSTATUS status
; /* return status */
179 typedef struct q_reg_open_hku_info
189 typedef struct r_reg_open_hku_info
191 POLICY_HND pol
; /* policy handle */
192 NTSTATUS status
; /* return status */
197 /* REG_Q_FLUSH_KEY */
198 typedef struct q_reg_open_flush_key_info
200 POLICY_HND pol
; /* policy handle */
204 /* REG_R_FLUSH_KEY */
205 typedef struct r_reg_open_flush_key_info
207 NTSTATUS status
; /* return status */
212 /* REG_Q_SET_KEY_SEC */
213 typedef struct q_reg_set_key_sec_info
215 POLICY_HND pol
; /* policy handle */
217 uint32 sec_info
; /* xxxx_SECURITY_INFORMATION */
219 uint32 ptr
; /* pointer */
220 BUFHDR hdr_sec
; /* header for security data */
221 SEC_DESC_BUF
*data
; /* security data */
225 /* REG_R_SET_KEY_SEC */
226 typedef struct r_reg_set_key_sec_info
233 /* REG_Q_GET_KEY_SEC */
234 typedef struct q_reg_get_key_sec_info
236 POLICY_HND pol
; /* policy handle */
238 uint32 sec_info
; /* xxxx_SECURITY_INFORMATION */
240 uint32 ptr
; /* pointer */
241 BUFHDR hdr_sec
; /* header for security data */
242 SEC_DESC_BUF
*data
; /* security data */
246 /* REG_R_GET_KEY_SEC */
247 typedef struct r_reg_get_key_sec_info
249 uint32 sec_info
; /* xxxx_SECURITY_INFORMATION */
251 uint32 ptr
; /* pointer */
252 BUFHDR hdr_sec
; /* header for security data */
253 SEC_DESC_BUF
*data
; /* security data */
259 /* REG_Q_CREATE_VALUE */
260 typedef struct q_reg_create_value_info
262 POLICY_HND pol
; /* policy handle */
264 UNIHDR hdr_name
; /* name of value */
267 uint32 type
; /* 1 = UNISTR, 3 = BYTES, 4 = DWORD, 7 = MULTI_UNISTR */
269 BUFFER3
*buf_value
; /* value, in byte buffer */
271 } REG_Q_CREATE_VALUE
;
273 /* REG_R_CREATE_VALUE */
274 typedef struct r_reg_create_value_info
276 NTSTATUS status
; /* return status */
278 } REG_R_CREATE_VALUE
;
280 /* REG_Q_ENUM_VALUE */
281 typedef struct q_reg_query_value_info
283 POLICY_HND pol
; /* policy handle */
285 uint32 val_index
; /* index */
287 UNIHDR hdr_name
; /* name of value */
290 uint32 ptr_type
; /* pointer */
291 uint32 type
; /* 1 = UNISTR, 3 = BYTES, 4 = DWORD, 7 = MULTI_UNISTR */
293 uint32 ptr_value
; /* pointer */
294 BUFFER2 buf_value
; /* value, in byte buffer */
296 uint32 ptr1
; /* pointer */
297 uint32 len_value1
; /* */
299 uint32 ptr2
; /* pointer */
300 uint32 len_value2
; /* */
304 /* REG_R_ENUM_VALUE */
305 typedef struct r_reg_enum_value_info
307 UNIHDR hdr_name
; /* name of value */
310 uint32 ptr_type
; /* pointer */
311 uint32 type
; /* 1 = UNISTR, 3 = BYTES, 4 = DWORD, 7 = MULTI_UNISTR */
313 uint32 ptr_value
; /* pointer */
314 BUFFER2
*buf_value
; /* value, in byte buffer */
316 uint32 ptr1
; /* pointer */
317 uint32 len_value1
; /* */
319 uint32 ptr2
; /* pointer */
320 uint32 len_value2
; /* */
322 NTSTATUS status
; /* return status */
326 /* REG_Q_CREATE_KEY */
327 typedef struct q_reg_create_key_info
329 POLICY_HND pnt_pol
; /* parent key policy handle */
337 uint32 reserved
; /* 0x0000 0000 */
338 SEC_ACCESS sam_access
; /* access rights flags, see rpc_secdes.h */
341 uint32 sec_info
; /* xxxx_SECURITY_INFORMATION */
343 uint32 ptr2
; /* pointer */
344 BUFHDR hdr_sec
; /* header for security data */
345 uint32 ptr3
; /* pointer */
348 uint32 unknown_2
; /* 0x0000 0000 */
352 /* REG_R_CREATE_KEY */
353 typedef struct r_reg_create_key_info
355 POLICY_HND key_pol
; /* policy handle */
356 uint32 unknown
; /* 0x0000 0000 */
358 NTSTATUS status
; /* return status */
362 /* REG_Q_DELETE_KEY */
363 typedef struct q_reg_delete_key_info
365 POLICY_HND pnt_pol
; /* parent key policy handle */
371 /* REG_R_DELETE_KEY */
372 typedef struct r_reg_delete_key_info
374 POLICY_HND key_pol
; /* policy handle */
376 NTSTATUS status
; /* return status */
380 /* REG_Q_DELETE_VALUE */
381 typedef struct q_reg_delete_val_info
383 POLICY_HND pnt_pol
; /* parent key policy handle */
388 } REG_Q_DELETE_VALUE
;
390 /* REG_R_DELETE_VALUE */
391 typedef struct r_reg_delete_val_info
393 POLICY_HND key_pol
; /* policy handle */
395 NTSTATUS status
; /* return status */
397 } REG_R_DELETE_VALUE
;
399 /* REG_Q_QUERY_KEY */
400 typedef struct q_reg_query_info
402 POLICY_HND pol
; /* policy handle */
408 /* REG_R_QUERY_KEY */
409 typedef struct r_reg_query_key_info
415 uint32 max_subkeylen
;
416 uint32 reserved
; /* 0x0000 0000 - according to MSDN (max_subkeysize?) */
418 uint32 max_valnamelen
;
419 uint32 max_valbufsize
;
420 uint32 sec_desc
; /* 0x0000 0078 */
421 NTTIME mod_time
; /* modified time */
423 NTSTATUS status
; /* return status */
428 /* REG_Q_UNKNOWN_1A */
429 typedef struct q_reg_unk_1a_info
431 POLICY_HND pol
; /* policy handle */
435 /* REG_R_UNKNOWN_1A */
436 typedef struct r_reg_unk_1a_info
438 uint32 unknown
; /* 0x0500 0000 */
439 NTSTATUS status
; /* return status */
445 typedef struct reg_q_close_info
447 POLICY_HND pol
; /* policy handle */
452 typedef struct reg_r_close_info
454 POLICY_HND pol
; /* policy handle. should be all zeros. */
456 NTSTATUS status
; /* return code */
462 typedef struct q_reg_enum_value_info
464 POLICY_HND pol
; /* policy handle */
468 uint16 key_name_len
; /* 0x0000 */
469 uint16 unknown_1
; /* 0x0414 */
471 uint32 ptr1
; /* pointer */
472 uint32 unknown_2
; /* 0x0000 020A */
473 uint8 pad1
[8]; /* padding - zeros */
475 uint32 ptr2
; /* pointer */
476 uint8 pad2
[8]; /* padding - zeros */
478 uint32 ptr3
; /* pointer */
479 NTTIME time
; /* current time? */
484 typedef struct r_reg_enum_key_info
486 uint16 key_name_len
; /* number of bytes in key name */
487 uint16 unknown_1
; /* 0x0414 - matches with query unknown_1 */
489 uint32 ptr1
; /* pointer */
490 uint32 unknown_2
; /* 0x0000 020A */
491 uint32 unknown_3
; /* 0x0000 0000 */
495 uint32 ptr2
; /* pointer */
496 uint8 pad2
[8]; /* padding - zeros */
498 uint32 ptr3
; /* pointer */
499 NTTIME time
; /* current time? */
501 NTSTATUS status
; /* return status */
507 typedef struct q_reg_info_info
509 POLICY_HND pol
; /* policy handle */
511 UNIHDR hdr_type
; /* unicode product type header */
512 UNISTR2 uni_type
; /* unicode product type - "ProductType" */
514 uint32 ptr_reserved
; /* pointer */
516 uint32 ptr_buf
; /* the next three fields follow if ptr_buf != 0 */
531 typedef struct r_reg_info_info
533 uint32 ptr_type
; /* key type pointer */
534 uint32 type
; /* key datatype */
536 uint32 ptr_uni_val
; /* key value pointer */
537 BUFFER2
*uni_val
; /* key value */
545 NTSTATUS status
; /* return status */
550 /* REG_Q_OPEN_ENTRY */
551 typedef struct q_reg_open_entry_info
553 POLICY_HND pol
; /* policy handle */
555 UNIHDR hdr_name
; /* unicode registry string header */
556 UNISTR2 uni_name
; /* unicode registry string name */
558 uint32 unknown_0
; /* 32 bit unknown - 0x0000 0000 */
559 uint32 access_desired
;
565 /* REG_R_OPEN_ENTRY */
566 typedef struct r_reg_open_entry_info
568 POLICY_HND pol
; /* policy handle */
569 NTSTATUS status
; /* return status */
574 typedef struct q_reg_shutdown_info
579 UNIHDR hdr_msg
; /* shutdown message */
580 UNISTR2 uni_msg
; /* seconds */
581 uint32 timeout
; /* seconds */
587 typedef struct r_reg_shutdown_info
589 NTSTATUS status
; /* return status */
593 /* REG_Q_ABORT_SHUTDOWN */
594 typedef struct q_reg_abort_shutdown_info
599 } REG_Q_ABORT_SHUTDOWN
;
601 /* REG_R_ABORT_SHUTDOWN */
602 typedef struct r_reg_abort_shutdown_info
604 NTSTATUS status
; /* return status */
606 } REG_R_ABORT_SHUTDOWN
;
609 #endif /* _RPC_REG_H */