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_LSA_H /* _RPC_LSA_H */
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. */
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
51 /* XXXX these are here to get a compile! */
52 #define LSA_LOOKUPRIDS 0xFD
54 #define LSA_MAX_GROUPS 96
55 #define LSA_MAX_SIDS 32
57 /* DOM_QUERY - info class 3 and 5 LSA Query response */
58 typedef struct dom_query_info
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 */
69 /* level 5 is same as level 3. we hope. */
70 typedef DOM_QUERY DOM_QUERY_3
;
71 typedef DOM_QUERY DOM_QUERY_5
;
73 typedef struct seq_qos_info
76 uint16 sec_imp_level
; /* 0x02 - impersonation level */
77 uint8 sec_ctxt_mode
; /* 0x01 - context tracking mode */
78 uint8 effective_only
; /* 0x00 - effective only */
79 uint32 unknown
; /* 0x2000 0000 - not known */
83 typedef struct obj_attr_info
85 uint32 len
; /* 0x18 - length (in bytes) inc. the length field. */
86 uint32 ptr_root_dir
; /* 0 - root directory (pointer) */
87 uint32 ptr_obj_name
; /* 0 - object name (pointer) */
88 uint32 attributes
; /* 0 - attributes (undocumented) */
89 uint32 ptr_sec_desc
; /* 0 - security descriptior (pointer) */
90 uint32 ptr_sec_qos
; /* security quality of service */
95 /* LSA_Q_OPEN_POL - LSA Query Open Policy */
96 typedef struct lsa_q_open_pol_info
98 uint32 ptr
; /* undocumented buffer pointer */
99 uint16 system_name
; /* 0x5c - system name */
100 LSA_OBJ_ATTR attr
; /* object attributes */
102 uint32 des_access
; /* desired access attributes */
106 /* LSA_R_OPEN_POL - response to LSA Open Policy */
107 typedef struct lsa_r_open_pol_info
109 POLICY_HND pol
; /* policy handle */
110 uint32 status
; /* return code */
114 /* LSA_Q_OPEN_POL2 - LSA Query Open Policy */
115 typedef struct lsa_q_open_pol2_info
117 uint32 ptr
; /* undocumented buffer pointer */
118 UNISTR2 uni_server_name
; /* server name, starting with two '\'s */
119 LSA_OBJ_ATTR attr
; /* object attributes */
121 uint32 des_access
; /* desired access attributes */
125 /* LSA_R_OPEN_POL2 - response to LSA Open Policy */
126 typedef struct lsa_r_open_pol2_info
128 POLICY_HND pol
; /* policy handle */
129 uint32 status
; /* return code */
133 /* LSA_Q_QUERY_INFO - LSA query info policy */
134 typedef struct lsa_query_info
136 POLICY_HND pol
; /* policy handle */
137 uint16 info_class
; /* info class */
141 /* LSA_R_QUERY_INFO - response to LSA query info policy */
142 typedef struct lsa_r_query_info
144 uint32 undoc_buffer
; /* undocumented buffer pointer */
145 uint16 info_class
; /* info class (same as info class in request) */
154 uint32 status
; /* return code */
158 /* LSA_Q_ENUM_TRUST_DOM - LSA enumerate trusted domains */
159 typedef struct lsa_enum_trust_dom_info
161 POLICY_HND pol
; /* policy handle */
162 uint32 enum_context
; /* enumeration context handle */
163 uint32 preferred_len
; /* preferred maximum length */
165 } LSA_Q_ENUM_TRUST_DOM
;
167 /* LSA_R_ENUM_TRUST_DOM - response to LSA enumerate trusted domains */
168 typedef struct lsa_r_enum_trust_dom_info
170 uint32 enum_context
; /* enumeration context handle */
171 uint32 num_domains
; /* number of domains */
172 uint32 ptr_enum_domains
; /* buffer pointer to num domains */
174 /* this lot is only added if ptr_enum_domains is non-NULL */
175 uint32 num_domains2
; /* number of domains */
176 UNIHDR2 hdr_domain_name
;
177 UNISTR2 uni_domain_name
;
178 DOM_SID2 other_domain_sid
;
180 uint32 status
; /* return code */
182 } LSA_R_ENUM_TRUST_DOM
;
185 typedef struct lsa_q_close_info
187 POLICY_HND pol
; /* policy handle */
192 typedef struct lsa_r_close_info
194 POLICY_HND pol
; /* policy handle. should be all zeros. */
196 uint32 status
; /* return code */
201 #define MAX_REF_DOMAINS 32
204 typedef struct dom_trust_hdr
206 UNIHDR hdr_dom_name
; /* referenced domain unicode string headers */
212 typedef struct dom_trust_info
214 UNISTR2 uni_dom_name
; /* domain name unicode string */
215 DOM_SID2 ref_dom
; /* referenced domain SID */
220 typedef struct dom_ref_info
222 uint32 num_ref_doms_1
; /* num referenced domains */
223 uint32 ptr_ref_dom
; /* pointer to referenced domains */
224 uint32 max_entries
; /* 32 - max number of entries */
225 uint32 num_ref_doms_2
; /* num referenced domains */
227 DOM_TRUST_HDR hdr_ref_dom
[MAX_REF_DOMAINS
]; /* referenced domains */
228 DOM_TRUST_INFO ref_dom
[MAX_REF_DOMAINS
]; /* referenced domains */
232 /* the domain_idx points to a SID associated with the name */
234 /* LSA_TRANS_NAME - translated name */
235 typedef struct lsa_trans_name_info
237 uint32 sid_name_use
; /* value is 5 for a well-known group; 2 for a domain group; 1 for a user... */
239 uint32 domain_idx
; /* index into DOM_R_REF array of SIDs */
243 #define MAX_LOOKUP_SIDS 30
245 /* LSA_TRANS_NAME_ENUM - LSA Translated Name Enumeration container */
246 typedef struct lsa_trans_name_enum_info
249 uint32 ptr_trans_names
;
252 LSA_TRANS_NAME name
[MAX_LOOKUP_SIDS
]; /* translated names */
253 UNISTR2 uni_name
[MAX_LOOKUP_SIDS
];
255 } LSA_TRANS_NAME_ENUM
;
257 /* LSA_SID_ENUM - LSA SID enumeration container */
258 typedef struct lsa_sid_enum_info
264 uint32 ptr_sid
[MAX_LOOKUP_SIDS
]; /* domain SID pointers to be looked up. */
265 DOM_SID2 sid
[MAX_LOOKUP_SIDS
]; /* domain SIDs to be looked up. */
269 /* LSA_Q_LOOKUP_SIDS - LSA Lookup SIDs */
270 typedef struct lsa_q_lookup_sids
272 POLICY_HND pol
; /* policy handle */
274 LSA_TRANS_NAME_ENUM names
;
280 /* LSA_R_LOOKUP_SIDS - response to LSA Lookup SIDs */
281 typedef struct lsa_r_lookup_sids
284 DOM_R_REF
*dom_ref
; /* domain reference info */
286 LSA_TRANS_NAME_ENUM
*names
;
289 uint32 status
; /* return code */
293 /* LSA_Q_LOOKUP_NAMES - LSA Lookup NAMEs */
294 typedef struct lsa_q_lookup_names
296 POLICY_HND pol
; /* policy handle */
299 UNIHDR hdr_name
[MAX_LOOKUP_SIDS
]; /* name buffer pointers */
300 UNISTR2 uni_name
[MAX_LOOKUP_SIDS
]; /* names to be looked up */
302 uint32 num_trans_entries
;
303 uint32 ptr_trans_sids
; /* undocumented domain SID buffer pointer */
307 } LSA_Q_LOOKUP_NAMES
;
309 /* LSA_R_LOOKUP_NAMES - response to LSA Lookup NAMEs by name */
310 typedef struct lsa_r_lookup_names
313 DOM_R_REF
*dom_ref
; /* domain reference info */
318 DOM_RID2
*dom_rid
; /* domain RIDs being looked up */
322 uint32 status
; /* return code */
324 } LSA_R_LOOKUP_NAMES
;
326 #endif /* _RPC_LSA_H */