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.
7 Copyright (C) Gerald Carter 2002.
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
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_FLUSH_KEY 0x0b
36 #define REG_GET_KEY_SEC 0x0c
37 #define _REG_UNK_0D 0x0d
38 #define _REG_UNK_0E 0x0e
39 #define _REG_UNK_12 0x12
40 #define _REG_UNK_13 0x13
41 #define REG_SET_KEY_SEC 0x15
42 #define REG_CREATE_VALUE 0x16
43 #define _REG_UNK_17 0x17
47 #define REG_OPEN_HKCR 0x00
48 #define REG_OPEN_HKLM 0x02
49 #define REG_OPEN_HKU 0x04
50 #define REG_CLOSE 0x05
51 #define REG_ENUM_KEY 0x09
52 #define REG_ENUM_VALUE 0x0a
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_SAVE_KEY 0x14 /* no idea what the real name is */
59 #define REG_UNKNOWN_1A 0x1a
62 #define HKEY_CLASSES_ROOT 0x80000000
63 #define HKEY_CURRENT_USER 0x80000001
64 #define HKEY_LOCAL_MACHINE 0x80000002
65 #define HKEY_USERS 0x80000003
67 #define KEY_HKLM "HKLM"
69 #define KEY_HKCR "HKCR"
70 #define KEY_PRINTING "HKLM\\SYSTEM\\CurrentControlSet\\Control\\Print"
71 #define KEY_TREE_ROOT ""
73 /* Registry data types */
77 #define REG_EXPAND_SZ 2
80 #define REG_DWORD_LE 4 /* DWORD, little endian */
81 #define REG_DWORD_BE 5 /* DWORD, big endian */
83 #define REG_MULTI_SZ 7
84 #define REG_RESOURCE_LIST 8
85 #define REG_FULL_RESOURCE_DESCRIPTOR 9
86 #define REG_RESOURCE_REQUIREMENTS_LIST 10
88 /* structure to contain registry values */
93 uint32 size
; /* in bytes */
97 /* container for regostry values */
102 REGISTRY_VALUE
**values
;
105 /* container for registry subkey names */
115 * container for function pointers to enumeration routines
116 * for vitural registry view
120 /* functions for enumerating subkeys and values */
121 int (*subkey_fn
)( char *key
, REGSUBKEY_CTR
*subkeys
);
122 int (*value_fn
) ( char *key
, REGVAL_CTR
*val
);
123 BOOL (*store_subkeys_fn
)( char *key
, REGSUBKEY_CTR
*subkeys
);
124 BOOL (*store_values_fn
)( char *key
, REGVAL_CTR
*val
);
128 char *keyname
; /* full path to name of key */
129 REGISTRY_OPS
*ops
; /* registry function hooks */
134 /* structure to store the registry handles */
136 typedef struct _RegistryKey
{
138 struct _RegistryKey
*prev
, *next
;
141 pstring name
; /* full name of registry key */
147 /* REG_Q_OPEN_HKCR */
148 typedef struct q_reg_open_hkcr_info
151 uint16 unknown_0
; /* 0x5428 - 16 bit unknown */
152 uint16 unknown_1
; /* random. changes */
153 uint32 level
; /* 0x0000 0002 - 32 bit unknown */
157 /* REG_R_OPEN_HKCR */
158 typedef struct r_reg_open_hkcr_info
160 POLICY_HND pol
; /* policy handle */
161 NTSTATUS status
; /* return status */
166 /* REG_Q_OPEN_HKLM */
167 typedef struct q_reg_open_hklm_info
170 uint16 unknown_0
; /* 0xE084 - 16 bit unknown */
171 uint16 unknown_1
; /* random. changes */
177 /* REG_R_OPEN_HKLM */
178 typedef struct r_reg_open_hklm_info
180 POLICY_HND pol
; /* policy handle */
181 NTSTATUS status
; /* return status */
188 typedef struct q_reg_open_hku_info
198 typedef struct r_reg_open_hku_info
200 POLICY_HND pol
; /* policy handle */
201 NTSTATUS status
; /* return status */
206 /* REG_Q_FLUSH_KEY */
207 typedef struct q_reg_open_flush_key_info
209 POLICY_HND pol
; /* policy handle */
213 /* REG_R_FLUSH_KEY */
214 typedef struct r_reg_open_flush_key_info
216 NTSTATUS status
; /* return status */
221 /* REG_Q_SET_KEY_SEC */
222 typedef struct q_reg_set_key_sec_info
224 POLICY_HND pol
; /* policy handle */
226 uint32 sec_info
; /* xxxx_SECURITY_INFORMATION */
228 uint32 ptr
; /* pointer */
229 BUFHDR hdr_sec
; /* header for security data */
230 SEC_DESC_BUF
*data
; /* security data */
234 /* REG_R_SET_KEY_SEC */
235 typedef struct r_reg_set_key_sec_info
242 /* REG_Q_GET_KEY_SEC */
243 typedef struct q_reg_get_key_sec_info
245 POLICY_HND pol
; /* policy handle */
247 uint32 sec_info
; /* xxxx_SECURITY_INFORMATION */
249 uint32 ptr
; /* pointer */
250 BUFHDR hdr_sec
; /* header for security data */
251 SEC_DESC_BUF
*data
; /* security data */
255 /* REG_R_GET_KEY_SEC */
256 typedef struct r_reg_get_key_sec_info
258 uint32 sec_info
; /* xxxx_SECURITY_INFORMATION */
260 uint32 ptr
; /* pointer */
261 BUFHDR hdr_sec
; /* header for security data */
262 SEC_DESC_BUF
*data
; /* security data */
268 /* REG_Q_CREATE_VALUE */
269 typedef struct q_reg_create_value_info
271 POLICY_HND pol
; /* policy handle */
273 UNIHDR hdr_name
; /* name of value */
276 uint32 type
; /* 1 = UNISTR, 3 = BYTES, 4 = DWORD, 7 = MULTI_UNISTR */
278 BUFFER3
*buf_value
; /* value, in byte buffer */
280 } REG_Q_CREATE_VALUE
;
282 /* REG_R_CREATE_VALUE */
283 typedef struct r_reg_create_value_info
285 NTSTATUS status
; /* return status */
287 } REG_R_CREATE_VALUE
;
289 /* REG_Q_ENUM_VALUE */
290 typedef struct q_reg_query_value_info
292 POLICY_HND pol
; /* policy handle */
294 uint32 val_index
; /* index */
296 UNIHDR hdr_name
; /* name of value */
299 uint32 ptr_type
; /* pointer */
300 uint32 type
; /* 1 = UNISTR, 3 = BYTES, 4 = DWORD, 7 = MULTI_UNISTR */
302 uint32 ptr_value
; /* pointer */
303 BUFFER2 buf_value
; /* value, in byte buffer */
305 uint32 ptr1
; /* pointer */
306 uint32 len_value1
; /* */
308 uint32 ptr2
; /* pointer */
309 uint32 len_value2
; /* */
314 /* REG_R_ENUM_VALUE */
315 typedef struct r_reg_enum_value_info
317 UNIHDR hdr_name
; /* name of value */
320 uint32 ptr_type
; /* pointer */
321 uint32 type
; /* 1 = UNISTR, 3 = BYTES, 4 = DWORD, 7 = MULTI_UNISTR */
323 uint32 ptr_value
; /* pointer */
324 BUFFER2 buf_value
; /* value, in byte buffer */
326 uint32 ptr1
; /* pointer */
327 uint32 len_value1
; /* */
329 uint32 ptr2
; /* pointer */
330 uint32 len_value2
; /* */
332 NTSTATUS status
; /* return status */
336 /* REG_Q_CREATE_KEY */
337 typedef struct q_reg_create_key_info
339 POLICY_HND pnt_pol
; /* parent key policy handle */
347 uint32 reserved
; /* 0x0000 0000 */
348 SEC_ACCESS sam_access
; /* access rights flags, see rpc_secdes.h */
351 uint32 sec_info
; /* xxxx_SECURITY_INFORMATION */
353 uint32 ptr2
; /* pointer */
354 BUFHDR hdr_sec
; /* header for security data */
355 uint32 ptr3
; /* pointer */
358 uint32 unknown_2
; /* 0x0000 0000 */
362 /* REG_R_CREATE_KEY */
363 typedef struct r_reg_create_key_info
365 POLICY_HND key_pol
; /* policy handle */
366 uint32 unknown
; /* 0x0000 0000 */
368 NTSTATUS status
; /* return status */
372 /* REG_Q_DELETE_KEY */
373 typedef struct q_reg_delete_key_info
375 POLICY_HND pnt_pol
; /* parent key policy handle */
381 /* REG_R_DELETE_KEY */
382 typedef struct r_reg_delete_key_info
384 POLICY_HND key_pol
; /* policy handle */
386 NTSTATUS status
; /* return status */
390 /* REG_Q_DELETE_VALUE */
391 typedef struct q_reg_delete_val_info
393 POLICY_HND pnt_pol
; /* parent key policy handle */
398 } REG_Q_DELETE_VALUE
;
400 /* REG_R_DELETE_VALUE */
401 typedef struct r_reg_delete_val_info
403 POLICY_HND key_pol
; /* policy handle */
405 NTSTATUS status
; /* return status */
407 } REG_R_DELETE_VALUE
;
409 /* REG_Q_QUERY_KEY */
410 typedef struct q_reg_query_info
412 POLICY_HND pol
; /* policy handle */
418 /* REG_R_QUERY_KEY */
419 typedef struct r_reg_query_key_info
425 uint32 max_subkeylen
;
426 uint32 reserved
; /* 0x0000 0000 - according to MSDN (max_subkeysize?) */
428 uint32 max_valnamelen
;
429 uint32 max_valbufsize
;
430 uint32 sec_desc
; /* 0x0000 0078 */
431 NTTIME mod_time
; /* modified time */
433 NTSTATUS status
; /* return status */
438 /* REG_Q_UNKNOWN_1A */
439 typedef struct q_reg_unk_1a_info
441 POLICY_HND pol
; /* policy handle */
445 /* REG_R_UNKNOWN_1A */
446 typedef struct r_reg_unk_1a_info
448 uint32 unknown
; /* 0x0500 0000 */
449 NTSTATUS status
; /* return status */
454 /* REG_Q_UNKNOWN_1A */
455 typedef struct q_reg_unknown_14
457 POLICY_HND pol
; /* policy handle */
459 UNIHDR hdr_file
; /* unicode product type header */
460 UNISTR2 uni_file
; /* local filename to save key as from regedt32.exe */
461 /* e.g. "c:\temp\test.dat" */
463 uint32 unknown
; /* 0x0000 0000 */
468 /* REG_R_UNKNOWN_1A */
469 typedef struct r_reg_unknown_14
471 NTSTATUS status
; /* return status */
478 typedef struct reg_q_close_info
480 POLICY_HND pol
; /* policy handle */
485 typedef struct reg_r_close_info
487 POLICY_HND pol
; /* policy handle. should be all zeros. */
489 NTSTATUS status
; /* return code */
495 typedef struct q_reg_enum_value_info
497 POLICY_HND pol
; /* policy handle */
501 uint16 key_name_len
; /* 0x0000 */
502 uint16 unknown_1
; /* 0x0414 */
504 uint32 ptr1
; /* pointer */
505 uint32 unknown_2
; /* 0x0000 020A */
506 uint8 pad1
[8]; /* padding - zeros */
508 uint32 ptr2
; /* pointer */
509 uint8 pad2
[8]; /* padding - zeros */
511 uint32 ptr3
; /* pointer */
512 NTTIME time
; /* current time? */
517 typedef struct r_reg_enum_key_info
519 uint16 key_name_len
; /* number of bytes in key name */
520 uint16 unknown_1
; /* 0x0414 - matches with query unknown_1 */
522 uint32 ptr1
; /* pointer */
523 uint32 unknown_2
; /* 0x0000 020A */
524 uint32 unknown_3
; /* 0x0000 0000 */
528 uint32 ptr2
; /* pointer */
529 uint8 pad2
[8]; /* padding - zeros */
531 uint32 ptr3
; /* pointer */
532 NTTIME time
; /* current time? */
534 NTSTATUS status
; /* return status */
540 typedef struct q_reg_info_info
542 POLICY_HND pol
; /* policy handle */
544 UNIHDR hdr_type
; /* unicode product type header */
545 UNISTR2 uni_type
; /* unicode product type - "ProductType" */
547 uint32 ptr_reserved
; /* pointer */
549 uint32 ptr_buf
; /* the next three fields follow if ptr_buf != 0 */
564 typedef struct r_reg_info_info
566 uint32 ptr_type
; /* key type pointer */
567 uint32 type
; /* key datatype */
569 uint32 ptr_uni_val
; /* key value pointer */
570 BUFFER2 uni_val
; /* key value */
578 NTSTATUS status
; /* return status */
583 /* REG_Q_OPEN_ENTRY */
584 typedef struct q_reg_open_entry_info
586 POLICY_HND pol
; /* policy handle */
588 UNIHDR hdr_name
; /* unicode registry string header */
589 UNISTR2 uni_name
; /* unicode registry string name */
591 uint32 unknown_0
; /* 32 bit unknown - 0x0000 0000 */
592 uint32 access_desired
;
598 /* REG_R_OPEN_ENTRY */
599 typedef struct r_reg_open_entry_info
601 POLICY_HND pol
; /* policy handle */
602 NTSTATUS status
; /* return status */
607 typedef struct q_reg_shutdown_info
612 UNIHDR hdr_msg
; /* shutdown message */
613 UNISTR2 uni_msg
; /* seconds */
614 uint32 timeout
; /* seconds */
615 uint8 force
; /* boolean: force shutdown */
616 uint8 reboot
; /* boolean: reboot on shutdown */
621 typedef struct r_reg_shutdown_info
623 NTSTATUS status
; /* return status */
627 /* REG_Q_ABORT_SHUTDOWN */
628 typedef struct q_reg_abort_shutdown_info
633 } REG_Q_ABORT_SHUTDOWN
;
635 /* REG_R_ABORT_SHUTDOWN */
636 typedef struct r_reg_abort_shutdown_info
638 NTSTATUS status
; /* return status */
640 } REG_R_ABORT_SHUTDOWN
;
643 #endif /* _RPC_REG_H */