summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/providers/ldap/ldap_id.c15
1 files changed, 13 insertions, 2 deletions
diff --git a/src/providers/ldap/ldap_id.c b/src/providers/ldap/ldap_id.c
index 1f3704d5b..d76a81a3e 100644
--- a/src/providers/ldap/ldap_id.c
+++ b/src/providers/ldap/ldap_id.c
@@ -1472,14 +1472,25 @@ static void get_user_and_group_users_done(struct tevent_req *subreq)
struct get_user_and_group_state);
int ret;
- ret = users_get_recv(subreq, &state->dp_error, NULL);
+ ret = users_get_recv(subreq, &state->dp_error, &state->sdap_ret);
talloc_zfree(subreq);
- if (ret == EOK) { /* Matching user found */
+ if (ret != EOK) { /* Fatal error while looking up user */
+ tevent_req_error(req, ret);
+ return;
+ }
+
+ if (state->sdap_ret == EOK) { /* Matching user found */
tevent_req_done(req);
return;
+ } else if (state->sdap_ret != ENOENT) {
+ tevent_req_error(req, EIO);
+ return;
}
+ /* Now the search finished fine but did not find an entry.
+ * Retry with groups. */
+
subreq = groups_get_send(req, state->ev, state->id_ctx,
state->sdom, state->conn,
state->filter_val, state->filter_type,