2 Unix SMB/CIFS implementation.
4 Wrapper around winbindd_rpc.c to centralize retry logic.
6 Copyright (C) Volker Lendecke 2005
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 3 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.
27 #define DBGC_CLASS DBGC_WINBIND
29 extern struct winbindd_methods msrpc_methods;
32 static NTSTATUS query_user_list(struct winbindd_domain *domain,
35 WINBIND_USERINFO **info)
39 result = msrpc_methods.query_user_list(domain, mem_ctx,
42 if (NT_STATUS_EQUAL(result, NT_STATUS_UNSUCCESSFUL))
43 result = msrpc_methods.query_user_list(domain, mem_ctx,
48 /* list all domain groups */
49 static NTSTATUS enum_dom_groups(struct winbindd_domain *domain,
52 struct acct_info **info)
56 result = msrpc_methods.enum_dom_groups(domain, mem_ctx,
59 if (NT_STATUS_EQUAL(result, NT_STATUS_UNSUCCESSFUL))
60 result = msrpc_methods.enum_dom_groups(domain, mem_ctx,
65 /* List all domain groups */
67 static NTSTATUS enum_local_groups(struct winbindd_domain *domain,
70 struct acct_info **info)
74 result = msrpc_methods.enum_local_groups(domain, mem_ctx,
77 if (NT_STATUS_EQUAL(result, NT_STATUS_UNSUCCESSFUL))
78 result = msrpc_methods.enum_local_groups(domain, mem_ctx,
84 /* convert a single name to a sid in a domain */
85 static NTSTATUS name_to_sid(struct winbindd_domain *domain,
87 enum winbindd_cmd orig_cmd,
88 const char *domain_name,
91 enum lsa_SidType *type)
95 result = msrpc_methods.name_to_sid(domain, mem_ctx, orig_cmd,
99 if (NT_STATUS_EQUAL(result, NT_STATUS_UNSUCCESSFUL))
100 result = msrpc_methods.name_to_sid(domain, mem_ctx, orig_cmd,
108 convert a domain SID to a user or group name
110 static NTSTATUS sid_to_name(struct winbindd_domain *domain,
115 enum lsa_SidType *type)
119 result = msrpc_methods.sid_to_name(domain, mem_ctx, sid,
120 domain_name, name, type);
122 if (NT_STATUS_EQUAL(result, NT_STATUS_UNSUCCESSFUL))
123 result = msrpc_methods.sid_to_name(domain, mem_ctx, sid,
124 domain_name, name, type);
129 static NTSTATUS rids_to_names(struct winbindd_domain *domain,
136 enum lsa_SidType **types)
140 result = msrpc_methods.rids_to_names(domain, mem_ctx, sid,
142 domain_name, names, types);
143 if (NT_STATUS_EQUAL(result, NT_STATUS_UNSUCCESSFUL)) {
144 result = msrpc_methods.rids_to_names(domain, mem_ctx, sid,
153 /* Lookup user information from a rid or username. */
154 static NTSTATUS query_user(struct winbindd_domain *domain,
156 const DOM_SID *user_sid,
157 WINBIND_USERINFO *user_info)
161 result = msrpc_methods.query_user(domain, mem_ctx, user_sid,
164 if (NT_STATUS_EQUAL(result, NT_STATUS_UNSUCCESSFUL))
165 result = msrpc_methods.query_user(domain, mem_ctx, user_sid,
171 /* Lookup groups a user is a member of. I wish Unix had a call like this! */
172 static NTSTATUS lookup_usergroups(struct winbindd_domain *domain,
174 const DOM_SID *user_sid,
175 uint32 *num_groups, DOM_SID **user_gids)
179 result = msrpc_methods.lookup_usergroups(domain, mem_ctx,
180 user_sid, num_groups,
183 if (NT_STATUS_EQUAL(result, NT_STATUS_UNSUCCESSFUL))
184 result = msrpc_methods.lookup_usergroups(domain, mem_ctx,
185 user_sid, num_groups,
191 static NTSTATUS lookup_useraliases(struct winbindd_domain *domain,
193 uint32 num_sids, const DOM_SID *sids,
194 uint32 *num_aliases, uint32 **alias_rids)
198 result = msrpc_methods.lookup_useraliases(domain, mem_ctx,
203 if (NT_STATUS_EQUAL(result, NT_STATUS_UNSUCCESSFUL))
204 result = msrpc_methods.lookup_useraliases(domain, mem_ctx,
212 /* Lookup group membership given a rid. */
213 static NTSTATUS lookup_groupmem(struct winbindd_domain *domain,
215 const DOM_SID *group_sid, uint32 *num_names,
216 DOM_SID **sid_mem, char ***names,
221 result = msrpc_methods.lookup_groupmem(domain, mem_ctx,
222 group_sid, num_names,
226 if (NT_STATUS_EQUAL(result, NT_STATUS_UNSUCCESSFUL))
227 result = msrpc_methods.lookup_groupmem(domain, mem_ctx,
228 group_sid, num_names,
235 /* find the sequence number for a domain */
236 static NTSTATUS sequence_number(struct winbindd_domain *domain, uint32 *seq)
240 result = msrpc_methods.sequence_number(domain, seq);
242 if (NT_STATUS_EQUAL(result, NT_STATUS_UNSUCCESSFUL))
243 result = msrpc_methods.sequence_number(domain, seq);
248 /* find the lockout policy of a domain */
249 static NTSTATUS lockout_policy(struct winbindd_domain *domain,
251 SAM_UNK_INFO_12 *policy)
255 result = msrpc_methods.lockout_policy(domain, mem_ctx, policy);
257 if (NT_STATUS_EQUAL(result, NT_STATUS_UNSUCCESSFUL))
258 result = msrpc_methods.lockout_policy(domain, mem_ctx, policy);
263 /* find the password policy of a domain */
264 static NTSTATUS password_policy(struct winbindd_domain *domain,
266 SAM_UNK_INFO_1 *policy)
270 result = msrpc_methods.password_policy(domain, mem_ctx, policy);
272 if (NT_STATUS_EQUAL(result, NT_STATUS_UNSUCCESSFUL))
273 result = msrpc_methods.password_policy(domain, mem_ctx, policy);
278 /* get a list of trusted domains */
279 static NTSTATUS trusted_domains(struct winbindd_domain *domain,
288 result = msrpc_methods.trusted_domains(domain, mem_ctx,
290 alt_names, dom_sids);
292 if (NT_STATUS_EQUAL(result, NT_STATUS_UNSUCCESSFUL))
293 result = msrpc_methods.trusted_domains(domain, mem_ctx,
295 alt_names, dom_sids);
300 /* the rpc backend methods are exposed via this structure */
301 struct winbindd_methods reconnect_methods = {