2 Unix SMB/CIFS implementation.
4 Wrapper around winbindd_ads.c to centralize retry logic.
5 Copyright (C) Christof Schmitt 2016
7 Based on winbindd_reconnect.c
8 Copyright (C) Volker Lendecke 2005
10 This program is free software; you can redistribute it and/or modify
11 it under the terms of the GNU General Public License as published by
12 the Free Software Foundation; either version 3 of the License, or
13 (at your option) any later version.
15 This program is distributed in the hope that it will be useful,
16 but WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 GNU General Public License for more details.
20 You should have received a copy of the GNU General Public License
21 along with this program. If not, see <http://www.gnu.org/licenses/>.
30 #define DBGC_CLASS DBGC_WINBIND
32 extern struct winbindd_methods ads_methods;
35 static NTSTATUS query_user_list(struct winbindd_domain *domain,
37 uint32_t *num_entries,
38 struct wbint_userinfo **info)
42 result = ads_methods.query_user_list(domain, mem_ctx,
45 if (reconnect_need_retry(result, domain)) {
46 result = ads_methods.query_user_list(domain, mem_ctx,
53 /* list all domain groups */
54 static NTSTATUS enum_dom_groups(struct winbindd_domain *domain,
56 uint32_t *num_entries,
57 struct wb_acct_info **info)
61 result = ads_methods.enum_dom_groups(domain, mem_ctx,
64 if (reconnect_need_retry(result, domain)) {
65 result = ads_methods.enum_dom_groups(domain, mem_ctx,
72 /* List all domain groups */
73 static NTSTATUS enum_local_groups(struct winbindd_domain *domain,
75 uint32_t *num_entries,
76 struct wb_acct_info **info)
80 result = ads_methods.enum_local_groups(domain, mem_ctx,
83 if (reconnect_need_retry(result, domain)) {
84 result = ads_methods.enum_local_groups(domain, mem_ctx,
91 /* convert a single name to a sid in a domain */
92 static NTSTATUS name_to_sid(struct winbindd_domain *domain,
94 const char *domain_name,
98 enum lsa_SidType *type)
102 result = ads_methods.name_to_sid(domain, mem_ctx, domain_name, name,
105 if (reconnect_need_retry(result, domain)) {
106 result = ads_methods.name_to_sid(domain, mem_ctx,
107 domain_name, name, flags,
115 convert a domain SID to a user or group name
117 static NTSTATUS sid_to_name(struct winbindd_domain *domain,
119 const struct dom_sid *sid,
122 enum lsa_SidType *type)
126 result = ads_methods.sid_to_name(domain, mem_ctx, sid,
127 domain_name, name, type);
129 if (reconnect_need_retry(result, domain))
130 result = ads_methods.sid_to_name(domain, mem_ctx, sid,
131 domain_name, name, type);
136 static NTSTATUS rids_to_names(struct winbindd_domain *domain,
138 const struct dom_sid *sid,
143 enum lsa_SidType **types)
147 result = ads_methods.rids_to_names(domain, mem_ctx, sid,
149 domain_name, names, types);
150 if (reconnect_need_retry(result, domain)) {
151 result = ads_methods.rids_to_names(domain, mem_ctx, sid,
152 rids, num_rids, domain_name,
159 /* Lookup groups a user is a member of. I wish Unix had a call like this! */
160 static NTSTATUS lookup_usergroups(struct winbindd_domain *domain,
162 const struct dom_sid *user_sid,
163 uint32_t *num_groups,
164 struct dom_sid **user_gids)
168 result = ads_methods.lookup_usergroups(domain, mem_ctx, user_sid,
169 num_groups, user_gids);
171 if (reconnect_need_retry(result, domain)) {
172 result = ads_methods.lookup_usergroups(domain, mem_ctx,
173 user_sid, num_groups,
180 static NTSTATUS lookup_useraliases(struct winbindd_domain *domain,
183 const struct dom_sid *sids,
184 uint32_t *num_aliases, uint32_t **alias_rids)
188 result = ads_methods.lookup_useraliases(domain, mem_ctx, num_sids, sids,
189 num_aliases, alias_rids);
191 if (reconnect_need_retry(result, domain)) {
192 result = ads_methods.lookup_useraliases(domain, mem_ctx,
201 /* Lookup group membership given a rid. */
202 static NTSTATUS lookup_groupmem(struct winbindd_domain *domain,
204 const struct dom_sid *group_sid,
205 enum lsa_SidType type,
207 struct dom_sid **sid_mem, char ***names,
208 uint32_t **name_types)
212 result = ads_methods.lookup_groupmem(domain, mem_ctx, group_sid, type,
213 num_names, sid_mem, names,
216 if (reconnect_need_retry(result, domain)) {
217 result = ads_methods.lookup_groupmem(domain, mem_ctx, group_sid,
218 type, num_names, sid_mem,
225 /* find the sequence number for a domain */
226 static NTSTATUS sequence_number(struct winbindd_domain *domain, uint32_t *seq)
230 result = ads_methods.sequence_number(domain, seq);
232 if (reconnect_need_retry(result, domain)) {
233 result = ads_methods.sequence_number(domain, seq);
239 /* find the lockout policy of a domain */
240 static NTSTATUS lockout_policy(struct winbindd_domain *domain,
242 struct samr_DomInfo12 *policy)
246 result = ads_methods.lockout_policy(domain, mem_ctx, policy);
248 if (reconnect_need_retry(result, domain)) {
249 result = ads_methods.lockout_policy(domain, mem_ctx, policy);
255 /* find the password policy of a domain */
256 static NTSTATUS password_policy(struct winbindd_domain *domain,
258 struct samr_DomInfo1 *policy)
262 result = ads_methods.password_policy(domain, mem_ctx, policy);
264 if (reconnect_need_retry(result, domain)) {
265 result = ads_methods.password_policy(domain, mem_ctx, policy);
271 /* get a list of trusted domains */
272 static NTSTATUS trusted_domains(struct winbindd_domain *domain,
274 struct netr_DomainTrustList *trusts)
278 result = ads_methods.trusted_domains(domain, mem_ctx, trusts);
280 if (reconnect_need_retry(result, domain)) {
281 result = ads_methods.trusted_domains(domain, mem_ctx, trusts);
287 /* the rpc backend methods are exposed via this structure */
288 struct winbindd_methods reconnect_ads_methods = {