converted another bunch of stuff to NTSTATUS
[vlendec/samba-autobuild/.git] / source3 / include / rpc_reg.h
1 /* 
2    Unix SMB/Netbios implementation.
3    Version 1.9.
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
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 2 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, write to the Free Software
21    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22 */
23
24 #ifndef _RPC_REG_H /* _RPC_REG_H */
25 #define _RPC_REG_H 
26
27
28 /* winreg pipe defines */
29 #define REG_OPEN_HKCR           0x00
30 #define _REG_UNK_01             0x01
31 #define REG_OPEN_HKLM           0x02
32 #define _REG_UNK_03             0x03
33 #define REG_OPEN_HKU            0x04
34 #define REG_CLOSE               0x05
35 #define REG_CREATE_KEY          0x06
36 #define REG_DELETE_KEY          0x07
37 #define REG_DELETE_VALUE        0x08
38 #define REG_ENUM_KEY            0x09
39 #define REG_ENUM_VALUE          0x0a
40 #define REG_FLUSH_KEY           0x0b
41 #define REG_GET_KEY_SEC         0x0c
42 #define _REG_UNK_0D             0x0d
43 #define _REG_UNK_0E             0x0e
44 #define REG_OPEN_ENTRY          0x0f
45 #define REG_QUERY_KEY           0x10
46 #define REG_INFO                0x11
47 #define _REG_UNK_12             0x12
48 #define _REG_UNK_13             0x13
49 #define _REG_UNK_14             0x14
50 #define REG_SET_KEY_SEC         0x15
51 #define REG_CREATE_VALUE        0x16
52 #define _REG_UNK_17             0x17
53 #define REG_SHUTDOWN            0x18
54 #define REG_ABORT_SHUTDOWN      0x19
55 #define REG_UNK_1A              0x1a
56
57 #define HKEY_CLASSES_ROOT       0x80000000
58 #define HKEY_CURRENT_USER       0x80000001
59 #define HKEY_LOCAL_MACHINE      0x80000002
60 #define HKEY_USERS              0x80000003
61
62 /* REG_Q_OPEN_HKCR   */
63 typedef struct q_reg_open_hkcr_info
64 {
65         uint32 ptr;
66         uint16 unknown_0; /* 0x5428      - 16 bit unknown */
67         uint16 unknown_1; /* random.  changes */
68         uint32 level;     /* 0x0000 0002 - 32 bit unknown */
69
70 } REG_Q_OPEN_HKCR  ;
71
72 /* REG_R_OPEN_HKCR   */
73 typedef struct r_reg_open_hkcr_info
74 {
75         POLICY_HND pol;       /* policy handle */
76         NTSTATUS status;         /* return status */
77
78 } REG_R_OPEN_HKCR;
79
80
81 /* REG_Q_OPEN_HKLM   */
82 typedef struct q_reg_open_hklm_info
83 {
84         uint32 ptr;
85         uint16 unknown_0;       /* 0xE084      - 16 bit unknown */
86         uint16 unknown_1;       /* random.  changes */
87         uint32 access_mask;     /* 0x0000 0002 - 32 bit unknown */
88
89 }
90 REG_Q_OPEN_HKLM;
91
92 /* REG_R_OPEN_HKLM   */
93 typedef struct r_reg_open_hklm_info
94 {
95         POLICY_HND pol;         /* policy handle */
96         NTSTATUS status;                /* return status */
97
98 }
99 REG_R_OPEN_HKLM;
100
101
102 /* REG_Q_OPEN_HKU */
103 typedef struct q_reg_open_hku_info
104 {
105         uint32 ptr;
106         uint16 unknown_0; /* 0xE084      - 16 bit unknown */
107         uint16 unknown_1; /* random.  changes */
108         uint32 level;     /* 0x0000 0002 - 32 bit unknown */
109
110 } REG_Q_OPEN_HKU;
111
112 /* REG_R_OPEN_HKU */
113 typedef struct r_reg_open_hku_info
114 {
115         POLICY_HND pol;       /* policy handle */
116         NTSTATUS status;         /* return status */
117
118 } REG_R_OPEN_HKU;
119
120
121 /* REG_Q_FLUSH_KEY */
122 typedef struct q_reg_open_flush_key_info
123 {
124         POLICY_HND pol;       /* policy handle */
125
126 } REG_Q_FLUSH_KEY;
127
128 /* REG_R_FLUSH_KEY */
129 typedef struct r_reg_open_flush_key_info
130 {
131         NTSTATUS status;         /* return status */
132
133 } REG_R_FLUSH_KEY;
134
135
136 /* REG_Q_SET_KEY_SEC */
137 typedef struct q_reg_set_key_sec_info
138 {
139         POLICY_HND pol;         /* policy handle */
140
141         uint32 sec_info;       /* xxxx_SECURITY_INFORMATION */
142
143         uint32 ptr;       /* pointer */
144         BUFHDR hdr_sec;    /* header for security data */
145         SEC_DESC_BUF *data;    /* security data */
146         
147 } REG_Q_SET_KEY_SEC;
148
149 /* REG_R_SET_KEY_SEC */
150 typedef struct r_reg_set_key_sec_info
151 {
152         NTSTATUS status;
153         
154 } REG_R_SET_KEY_SEC;
155
156
157 /* REG_Q_GET_KEY_SEC */
158 typedef struct q_reg_get_key_sec_info
159 {
160         POLICY_HND pol;         /* policy handle */
161
162         uint32 sec_info;       /* xxxx_SECURITY_INFORMATION */
163
164         uint32 ptr;       /* pointer */
165         BUFHDR hdr_sec;    /* header for security data */
166         SEC_DESC_BUF *data;    /* security data */
167         
168 } REG_Q_GET_KEY_SEC;
169
170 /* REG_R_GET_KEY_SEC */
171 typedef struct r_reg_get_key_sec_info
172 {
173         uint32 sec_info;       /* xxxx_SECURITY_INFORMATION */
174
175         uint32 ptr;       /* pointer */
176         BUFHDR hdr_sec;    /* header for security data */
177         SEC_DESC_BUF *data;    /* security data */
178
179         NTSTATUS status;
180         
181 } REG_R_GET_KEY_SEC;
182
183 /* REG_Q_CREATE_VALUE */
184 typedef struct q_reg_create_value_info
185 {
186         POLICY_HND pol;    /* policy handle */
187
188         UNIHDR hdr_name;   /* name of value */
189         UNISTR2 uni_name;
190
191         uint32 type;       /* 1 = UNISTR, 3 = BYTES, 4 = DWORD, 7 = MULTI_UNISTR */
192
193         BUFFER3 *buf_value; /* value, in byte buffer */
194
195 } REG_Q_CREATE_VALUE;
196
197 /* REG_R_CREATE_VALUE */
198 typedef struct r_reg_create_value_info
199
200         NTSTATUS status;         /* return status */
201
202 } REG_R_CREATE_VALUE;
203
204 /* REG_Q_ENUM_VALUE */
205 typedef struct q_reg_query_value_info
206 {
207         POLICY_HND pol;    /* policy handle */
208
209         uint32 val_index;  /* index */
210
211         UNIHDR hdr_name;   /* name of value */
212         UNISTR2 uni_name;
213
214         uint32 ptr_type;   /* pointer */
215         uint32 type;       /* 1 = UNISTR, 3 = BYTES, 4 = DWORD, 7 = MULTI_UNISTR */
216
217         uint32 ptr_value;  /* pointer */
218         BUFFER2 buf_value; /* value, in byte buffer */
219
220         uint32 ptr1;       /* pointer */
221         uint32 len_value1; /* */
222
223         uint32 ptr2;       /* pointer */
224         uint32 len_value2; /* */
225
226 } REG_Q_ENUM_VALUE;
227
228 /* REG_R_ENUM_VALUE */
229 typedef struct r_reg_enum_value_info
230
231         UNIHDR hdr_name;        /* name of value */
232         UNISTR2 uni_name;
233
234         uint32 ptr_type;            /* pointer */
235         uint32 type;        /* 1 = UNISTR, 3 = BYTES, 4 = DWORD, 7 = MULTI_UNISTR */
236
237         uint32 ptr_value;       /* pointer */
238         BUFFER2 *buf_value;    /* value, in byte buffer */
239
240         uint32 ptr1;            /* pointer */
241         uint32 len_value1;       /* */
242
243         uint32 ptr2;            /* pointer */
244         uint32 len_value2;       /* */
245
246         NTSTATUS status;         /* return status */
247
248 } REG_R_ENUM_VALUE;
249
250 /* REG_Q_CREATE_KEY */
251 typedef struct q_reg_create_key_info
252 {
253         POLICY_HND pnt_pol;       /* parent key policy handle */
254
255         UNIHDR hdr_name;
256         UNISTR2 uni_name;
257
258         UNIHDR hdr_class;
259         UNISTR2 uni_class;
260
261         uint32 reserved; /* 0x0000 0000 */
262         SEC_ACCESS sam_access; /* access rights flags, see rpc_secdes.h */
263
264         uint32 ptr1;
265         uint32 sec_info; /* xxxx_SECURITY_INFORMATION */
266
267         uint32 ptr2;       /* pointer */
268         BUFHDR hdr_sec;    /* header for security data */
269         uint32 ptr3;       /* pointer */
270         SEC_DESC_BUF *data;
271
272         uint32 unknown_2; /* 0x0000 0000 */
273
274 } REG_Q_CREATE_KEY;
275
276 /* REG_R_CREATE_KEY */
277 typedef struct r_reg_create_key_info
278 {
279         POLICY_HND key_pol;       /* policy handle */
280         uint32 unknown; /* 0x0000 0000 */
281
282         NTSTATUS status;         /* return status */
283
284 } REG_R_CREATE_KEY;
285
286 /* REG_Q_DELETE_KEY */
287 typedef struct q_reg_delete_key_info
288 {
289         POLICY_HND pnt_pol;       /* parent key policy handle */
290
291         UNIHDR hdr_name;
292         UNISTR2 uni_name;
293 } REG_Q_DELETE_KEY;
294
295 /* REG_R_DELETE_KEY */
296 typedef struct r_reg_delete_key_info
297 {
298         POLICY_HND key_pol;       /* policy handle */
299
300         NTSTATUS status;         /* return status */
301
302 } REG_R_DELETE_KEY;
303
304 /* REG_Q_DELETE_VALUE */
305 typedef struct q_reg_delete_val_info
306 {
307         POLICY_HND pnt_pol;       /* parent key policy handle */
308
309         UNIHDR hdr_name;
310         UNISTR2 uni_name;
311
312 } REG_Q_DELETE_VALUE;
313
314 /* REG_R_DELETE_VALUE */
315 typedef struct r_reg_delete_val_info
316 {
317         POLICY_HND key_pol;       /* policy handle */
318
319         NTSTATUS status;         /* return status */
320
321 } REG_R_DELETE_VALUE;
322
323 /* REG_Q_QUERY_KEY */
324 typedef struct q_reg_query_info
325 {
326         POLICY_HND pol;       /* policy handle */
327         UNIHDR hdr_class;
328         UNISTR2 uni_class;
329
330 } REG_Q_QUERY_KEY;
331
332 /* REG_R_QUERY_KEY */
333 typedef struct r_reg_query_key_info
334 {
335         UNIHDR hdr_class;
336         UNISTR2 uni_class;
337
338         uint32 num_subkeys;
339         uint32 max_subkeylen;
340         uint32 max_subkeysize; /* 0x0000 0000 */
341         uint32 num_values;
342         uint32 max_valnamelen;
343         uint32 max_valbufsize; 
344         uint32 sec_desc; /* 0x0000 0078 */
345         NTTIME mod_time;  /* modified time */
346
347         NTSTATUS status;         /* return status */
348
349 } REG_R_QUERY_KEY;
350
351
352 /* REG_Q_UNK_1A */
353 typedef struct q_reg_unk_1a_info
354 {
355         POLICY_HND pol;       /* policy handle */
356
357 } REG_Q_UNK_1A;
358
359 /* REG_R_UNK_1A */
360 typedef struct r_reg_unk_1a_info
361 {
362         uint32 unknown;         /* 0x0500 0000 */
363         NTSTATUS status;         /* return status */
364
365 } REG_R_UNK_1A;
366
367
368 /* REG_Q_CLOSE */
369 typedef struct reg_q_close_info
370 {
371         POLICY_HND pol; /* policy handle */
372
373 } REG_Q_CLOSE;
374
375 /* REG_R_CLOSE */
376 typedef struct reg_r_close_info
377 {
378         POLICY_HND pol; /* policy handle.  should be all zeros. */
379
380         NTSTATUS status; /* return code */
381
382 } REG_R_CLOSE;
383
384
385 /* REG_Q_ENUM_KEY */
386 typedef struct q_reg_enum_value_info
387 {
388         POLICY_HND pol;         /* policy handle */
389
390         uint32 key_index;       
391
392         uint16 key_name_len;    /* 0x0000 */
393         uint16 unknown_1;       /* 0x0414 */
394
395         uint32 ptr1;            /* pointer */
396         uint32 unknown_2;       /* 0x0000 020A */
397         uint8  pad1[8];         /* padding - zeros */
398
399         uint32 ptr2;            /* pointer */
400         uint8  pad2[8];         /* padding - zeros */
401
402         uint32 ptr3;            /* pointer */
403         NTTIME time;            /* current time? */
404
405 } REG_Q_ENUM_KEY;
406
407 /* REG_R_ENUM_KEY */
408 typedef struct r_reg_enum_key_info
409
410         uint16 key_name_len;    /* number of bytes in key name */
411         uint16 unknown_1;       /* 0x0414 - matches with query unknown_1 */
412
413         uint32 ptr1;            /* pointer */
414         uint32 unknown_2;       /* 0x0000 020A */
415         uint32 unknown_3;       /* 0x0000 0000 */
416
417         UNISTR3 key_name;
418
419         uint32 ptr2;            /* pointer */
420         uint8  pad2[8];         /* padding - zeros */
421
422         uint32 ptr3;            /* pointer */
423         NTTIME time;            /* current time? */
424
425         NTSTATUS status;         /* return status */
426
427 } REG_R_ENUM_KEY;
428
429
430 /* REG_Q_INFO */
431 typedef struct q_reg_info_info
432 {
433         POLICY_HND pol;         /* policy handle */
434
435         UNIHDR  hdr_type;       /* unicode product type header */
436         UNISTR2 uni_type;       /* unicode product type - "ProductType" */
437
438         uint32 ptr_reserved;    /* pointer */
439   
440         uint32 ptr_buf;         /* the next three fields follow if ptr_buf != 0 */
441         uint32 ptr_bufsize;
442         uint32 bufsize;
443         uint32 buf_unk;
444
445         uint32 unk1;
446         uint32 ptr_buflen;
447         uint32 buflen;
448   
449         uint32 ptr_buflen2;
450         uint32 buflen2;
451
452 } REG_Q_INFO;
453
454 /* REG_R_INFO */
455 typedef struct r_reg_info_info
456
457         uint32 ptr_type;        /* key type pointer */
458         uint32 type;            /* key datatype  */
459
460         uint32 ptr_uni_val;     /* key value pointer */
461         BUFFER2 *uni_val;       /* key value */
462
463         uint32 ptr_max_len;
464         uint32 buf_max_len;
465
466         uint32 ptr_len;
467         uint32 buf_len;
468   
469         NTSTATUS status;        /* return status */
470
471 } REG_R_INFO;
472
473
474 /* REG_Q_OPEN_ENTRY */
475 typedef struct q_reg_open_entry_info
476 {
477         POLICY_HND pol;        /* policy handle */
478
479         UNIHDR  hdr_name;       /* unicode registry string header */
480         UNISTR2 uni_name;       /* unicode registry string name */
481
482         uint32 unknown_0;       /* 32 bit unknown - 0x0000 0000 */
483         uint32 unknown_1;       /* 32 bit unknown - 0x0200 0000 */
484
485 } REG_Q_OPEN_ENTRY;
486
487
488
489 /* REG_R_OPEN_ENTRY */
490 typedef struct r_reg_open_entry_info
491 {
492         POLICY_HND pol;       /* policy handle */
493         NTSTATUS status;         /* return status */
494
495 } REG_R_OPEN_ENTRY;
496
497 /* REG_Q_SHUTDOWN */
498 typedef struct q_reg_shutdown_info
499 {
500         uint32 ptr_0;
501         uint32 ptr_1;
502         uint32 ptr_2;
503         UNIHDR hdr_msg;         /* shutdown message */
504         UNISTR2 uni_msg;        /* seconds */
505         uint32 timeout;         /* seconds */
506         uint16 flags;
507                 
508 } REG_Q_SHUTDOWN;
509
510 /* REG_R_SHUTDOWN */
511 typedef struct r_reg_shutdown_info
512 {
513         NTSTATUS status;                /* return status */
514
515 } REG_R_SHUTDOWN;
516
517 /* REG_Q_ABORT_SHUTDOWN */
518 typedef struct q_reg_abort_shutdown_info
519 {
520         uint32 ptr_server;
521         uint16 server;
522
523 } REG_Q_ABORT_SHUTDOWN;
524
525 /* REG_R_ABORT_SHUTDOWN */
526 typedef struct r_reg_abort_shutdown_info
527
528         NTSTATUS status; /* return status */
529
530 } REG_R_ABORT_SHUTDOWN;
531
532
533 #endif /* _RPC_REG_H */
534