60daa261ba977ebbe36483ef6966470f131ad5ed
[samba.git] / source3 / include / rpc_lsa.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_LSA_H /* _RPC_LSA_H */
25 #define _RPC_LSA_H 
26
27 #include "rpc_misc.h"
28
29 enum SID_NAME_USE
30 {
31         SID_NAME_USER    = 1, /* user */
32         SID_NAME_DOM_GRP = 2, /* domain group */
33         SID_NAME_DOMAIN  = 3, /* domain: don't know what this is */
34         SID_NAME_ALIAS   = 4, /* local group */
35         SID_NAME_WKN_GRP = 5, /* well-known group */
36         SID_NAME_DELETED = 6, /* deleted account: needed for c2 rating */
37         SID_NAME_INVALID = 7, /* invalid account */
38         SID_NAME_UNKNOWN = 8  /* oops. */
39 };
40
41 /* ntlsa pipe */
42 #define LSA_CLOSE              0x00
43 #define LSA_QUERYINFOPOLICY    0x07
44 #define LSA_ENUMTRUSTDOM       0x0d
45 #define LSA_LOOKUPNAMES        0x0e
46 #define LSA_LOOKUPSIDS         0x0f
47 #define LSA_OPENPOLICY         0x06
48 #define LSA_OPENPOLICY2        0x2c
49 #define LSA_OPENSECRET         0x1C
50
51 /* XXXX these are here to get a compile! */
52 #define LSA_LOOKUPRIDS      0xFD
53
54 #define LSA_MAX_GROUPS 96
55 #define LSA_MAX_SIDS 128
56
57 /* DOM_QUERY - info class 3 and 5 LSA Query response */
58 typedef struct dom_query_info
59 {
60   uint16 uni_dom_max_len; /* domain name string length * 2 */
61   uint16 uni_dom_str_len; /* domain name string length * 2 */
62   uint32 buffer_dom_name; /* undocumented domain name string buffer pointer */
63   uint32 buffer_dom_sid; /* undocumented domain SID string buffer pointer */
64   UNISTR2 uni_domain_name; /* domain name (unicode string) */
65   DOM_SID2 dom_sid; /* domain SID */
66
67 } DOM_QUERY;
68
69 /* level 5 is same as level 3.  we hope. */
70 typedef DOM_QUERY DOM_QUERY_3;
71 typedef DOM_QUERY DOM_QUERY_5;
72
73 /* level 2 is auditing settings */
74 typedef struct dom_query_2
75 {
76         uint32 auditing_enabled;
77         uint32 count1; /* usualy 7, at least on nt4sp4 */
78         uint32 count2; /* the same */
79         uint32 *auditsettings;
80 } DOM_QUERY_2;
81
82 /* level 6 is server role information */
83 typedef struct dom_query_6
84 {
85         uint16 server_role; /* 2=backup, 3=primary */
86 } DOM_QUERY_6;
87
88 typedef struct seq_qos_info
89 {
90         uint32 len; /* 12 */
91         uint16 sec_imp_level; /* 0x02 - impersonation level */
92         uint8  sec_ctxt_mode; /* 0x01 - context tracking mode */
93         uint8  effective_only; /* 0x00 - effective only */
94         uint32 unknown;        /* 0x2000 0000 - not known */
95
96 } LSA_SEC_QOS;
97
98 typedef struct obj_attr_info
99 {
100         uint32 len;          /* 0x18 - length (in bytes) inc. the length field. */
101         uint32 ptr_root_dir; /* 0 - root directory (pointer) */
102         uint32 ptr_obj_name; /* 0 - object name (pointer) */
103         uint32 attributes;   /* 0 - attributes (undocumented) */
104         uint32 ptr_sec_desc; /* 0 - security descriptior (pointer) */
105         uint32 ptr_sec_qos;  /* security quality of service */
106         LSA_SEC_QOS *sec_qos;
107
108 } LSA_OBJ_ATTR;
109
110 /* LSA_Q_OPEN_POL - LSA Query Open Policy */
111 typedef struct lsa_q_open_pol_info
112 {
113         uint32 ptr;         /* undocumented buffer pointer */
114         uint16 system_name; /* 0x5c - system name */
115         LSA_OBJ_ATTR attr ; /* object attributes */
116
117         uint32 des_access; /* desired access attributes */
118
119 } LSA_Q_OPEN_POL;
120
121 /* LSA_R_OPEN_POL - response to LSA Open Policy */
122 typedef struct lsa_r_open_pol_info
123 {
124         POLICY_HND pol; /* policy handle */
125         uint32 status; /* return code */
126
127 } LSA_R_OPEN_POL;
128
129 /* LSA_Q_OPEN_POL2 - LSA Query Open Policy */
130 typedef struct lsa_q_open_pol2_info
131 {
132         uint32       ptr;             /* undocumented buffer pointer */
133         UNISTR2      uni_server_name; /* server name, starting with two '\'s */
134         LSA_OBJ_ATTR attr           ; /* object attributes */
135
136         uint32 des_access; /* desired access attributes */
137
138 } LSA_Q_OPEN_POL2;
139
140 /* LSA_R_OPEN_POL2 - response to LSA Open Policy */
141 typedef struct lsa_r_open_pol2_info
142 {
143         POLICY_HND pol; /* policy handle */
144         uint32 status; /* return code */
145
146 } LSA_R_OPEN_POL2;
147
148 /* LSA_Q_QUERY_SEC_OBJ - LSA query security */
149 typedef struct lsa_query_sec_obj_info
150 {
151         POLICY_HND pol; /* policy handle */
152         uint32 sec_info;
153
154 } LSA_Q_QUERY_SEC_OBJ;
155
156 /* LSA_R_QUERY_SEC_OBJ - probably an open */
157 typedef struct r_lsa_query_sec_obj_info
158 {
159         uint32 ptr;
160         SEC_DESC_BUF *buf;
161
162         uint32 status;         /* return status */
163
164 } LSA_R_QUERY_SEC_OBJ;
165
166 /* LSA_Q_QUERY_INFO - LSA query info policy */
167 typedef struct lsa_query_info
168 {
169         POLICY_HND pol; /* policy handle */
170     uint16 info_class; /* info class */
171
172 } LSA_Q_QUERY_INFO;
173
174 /* LSA_INFO_UNION */
175 typedef union lsa_info_union
176 {
177         DOM_QUERY_2 id2;
178         DOM_QUERY_3 id3;
179         DOM_QUERY_5 id5;
180         DOM_QUERY_6 id6;
181 } LSA_INFO_UNION;
182
183 /* LSA_R_QUERY_INFO - response to LSA query info policy */
184 typedef struct lsa_r_query_info
185 {
186     uint32 undoc_buffer; /* undocumented buffer pointer */
187     uint16 info_class; /* info class (same as info class in request) */
188    
189         LSA_INFO_UNION dom; 
190
191         uint32 status; /* return code */
192
193 } LSA_R_QUERY_INFO;
194
195 /* LSA_Q_ENUM_TRUST_DOM - LSA enumerate trusted domains */
196 typedef struct lsa_enum_trust_dom_info
197 {
198         POLICY_HND pol; /* policy handle */
199     uint32 enum_context; /* enumeration context handle */
200     uint32 preferred_len; /* preferred maximum length */
201
202 } LSA_Q_ENUM_TRUST_DOM;
203
204 /* LSA_R_ENUM_TRUST_DOM - response to LSA enumerate trusted domains */
205 typedef struct lsa_r_enum_trust_dom_info
206 {
207         uint32 enum_context; /* enumeration context handle */
208         uint32 num_domains; /* number of domains */
209         uint32 ptr_enum_domains; /* buffer pointer to num domains */
210
211         /* this lot is only added if ptr_enum_domains is non-NULL */
212         uint32 num_domains2; /* number of domains */
213         UNIHDR2 *hdr_domain_name;
214         UNISTR2 *uni_domain_name;
215         DOM_SID2 *domain_sid;
216
217         uint32 status; /* return code */
218
219 } LSA_R_ENUM_TRUST_DOM;
220
221 /* LSA_Q_CLOSE */
222 typedef struct lsa_q_close_info
223 {
224         POLICY_HND pol; /* policy handle */
225
226 } LSA_Q_CLOSE;
227
228 /* LSA_R_CLOSE */
229 typedef struct lsa_r_close_info
230 {
231         POLICY_HND pol; /* policy handle.  should be all zeros. */
232
233         uint32 status; /* return code */
234
235 } LSA_R_CLOSE;
236
237
238 #define MAX_REF_DOMAINS 32
239
240 /* DOM_TRUST_HDR */
241 typedef struct dom_trust_hdr
242 {
243         UNIHDR hdr_dom_name; /* referenced domain unicode string headers */
244         uint32 ptr_dom_sid;
245
246 } DOM_TRUST_HDR;
247         
248 /* DOM_TRUST_INFO */
249 typedef struct dom_trust_info
250 {
251         UNISTR2  uni_dom_name; /* domain name unicode string */
252         DOM_SID2 ref_dom     ; /* referenced domain SID */
253
254 } DOM_TRUST_INFO;
255         
256 /* DOM_R_REF */
257 typedef struct dom_ref_info
258 {
259     uint32 num_ref_doms_1; /* num referenced domains */
260     uint32 ptr_ref_dom; /* pointer to referenced domains */
261     uint32 max_entries; /* 32 - max number of entries */
262     uint32 num_ref_doms_2; /* num referenced domains */
263
264     DOM_TRUST_HDR  hdr_ref_dom[MAX_REF_DOMAINS]; /* referenced domains */
265     DOM_TRUST_INFO ref_dom    [MAX_REF_DOMAINS]; /* referenced domains */
266
267 } DOM_R_REF;
268
269 /* the domain_idx points to a SID associated with the name */
270
271 /* LSA_TRANS_NAME - translated name */
272 typedef struct lsa_trans_name_info
273 {
274         uint16 sid_name_use; /* value is 5 for a well-known group; 2 for a domain group; 1 for a user... */
275         UNIHDR hdr_name; 
276         uint32 domain_idx; /* index into DOM_R_REF array of SIDs */
277
278 } LSA_TRANS_NAME;
279
280 #define MAX_LOOKUP_SIDS 30
281
282 /* LSA_TRANS_NAME_ENUM - LSA Translated Name Enumeration container */
283 typedef struct lsa_trans_name_enum_info
284 {
285         uint32 num_entries;
286         uint32 ptr_trans_names;
287         uint32 num_entries2;
288         
289         LSA_TRANS_NAME *name; /* translated names  */
290         UNISTR2 *uni_name;
291
292 } LSA_TRANS_NAME_ENUM;
293
294 /* LSA_SID_ENUM - LSA SID enumeration container */
295 typedef struct lsa_sid_enum_info
296 {
297         uint32 num_entries;
298         uint32 ptr_sid_enum;
299         uint32 num_entries2;
300         
301         uint32 *ptr_sid; /* domain SID pointers to be looked up. */
302         DOM_SID2 *sid; /* domain SIDs to be looked up. */
303
304 } LSA_SID_ENUM;
305
306 /* LSA_Q_LOOKUP_SIDS - LSA Lookup SIDs */
307 typedef struct lsa_q_lookup_sids
308 {
309         POLICY_HND          pol; /* policy handle */
310         LSA_SID_ENUM        sids;
311         LSA_TRANS_NAME_ENUM names;
312         LOOKUP_LEVEL        level;
313         uint32              mapped_count;
314
315 } LSA_Q_LOOKUP_SIDS;
316
317 /* LSA_R_LOOKUP_SIDS - response to LSA Lookup SIDs */
318 typedef struct lsa_r_lookup_sids
319 {
320         uint32              ptr_dom_ref;
321         DOM_R_REF           *dom_ref; /* domain reference info */
322
323         LSA_TRANS_NAME_ENUM *names;
324         uint32              mapped_count;
325
326         uint32              status; /* return code */
327
328 } LSA_R_LOOKUP_SIDS;
329
330 /* LSA_Q_LOOKUP_NAMES - LSA Lookup NAMEs */
331 typedef struct lsa_q_lookup_names
332 {
333         POLICY_HND pol; /* policy handle */
334         uint32 num_entries;
335         uint32 num_entries2;
336         UNIHDR  *hdr_name; /* name buffer pointers */
337         UNISTR2 *uni_name; /* names to be looked up */
338
339         uint32 num_trans_entries;
340         uint32 ptr_trans_sids; /* undocumented domain SID buffer pointer */
341         uint32 lookup_level;
342         uint32 mapped_count;
343
344 } LSA_Q_LOOKUP_NAMES;
345
346 /* LSA_R_LOOKUP_NAMES - response to LSA Lookup NAMEs by name */
347 typedef struct lsa_r_lookup_names
348 {
349         uint32 ptr_dom_ref;
350         DOM_R_REF *dom_ref; /* domain reference info */
351
352         uint32 num_entries;
353         uint32 ptr_entries;
354         uint32 num_entries2;
355         DOM_RID2 *dom_rid; /* domain RIDs being looked up */
356
357         uint32 mapped_count;
358
359         uint32 status; /* return code */
360
361 } LSA_R_LOOKUP_NAMES;
362
363 #endif /* _RPC_LSA_H */