Blame SOURCES/0007-ad-use-right-sdap_domain-in-ad_domain_info_send.patch

5e7e84
From 51e92297157562511baf8902777f02a4aa2e70e6 Mon Sep 17 00:00:00 2001
5e7e84
From: Sumit Bose <sbose@redhat.com>
5e7e84
Date: Tue, 15 Mar 2022 11:36:45 +0100
5e7e84
Subject: [PATCH] ad: use right sdap_domain in ad_domain_info_send
5e7e84
MIME-Version: 1.0
5e7e84
Content-Type: text/plain; charset=UTF-8
5e7e84
Content-Transfer-Encoding: 8bit
5e7e84
5e7e84
Originally ad_domain_info_send() was only called when there was only a
5e7e84
single domain available and hence only a single sdap_domain struct with
5e7e84
the search bases in the sdap_domain list. Since ad_domain_info_send() is
5e7e84
now called at other times as well the right sdap_domain struct must be
5e7e84
selected so that the right search bases are used.
5e7e84
5e7e84
Resolves: https://github.com/SSSD/sssd/issues/6063
5e7e84
5e7e84
Reviewed-by: Iker Pedrosa <ipedrosa@redhat.com>
5e7e84
Reviewed-by: Pavel Březina <pbrezina@redhat.com>
5e7e84
---
5e7e84
 src/providers/ad/ad_domain_info.c    | 10 +++++-
5e7e84
 src/providers/ldap/ldap_common.h     |  3 ++
5e7e84
 src/providers/ldap/sdap_domain.c     | 21 ++++++++++++
5e7e84
 src/tests/cmocka/test_search_bases.c | 48 +++++++++++++++++++++++++++-
5e7e84
 4 files changed, 80 insertions(+), 2 deletions(-)
5e7e84
5e7e84
diff --git a/src/providers/ad/ad_domain_info.c b/src/providers/ad/ad_domain_info.c
5e7e84
index 52b2e2442..f3a82a198 100644
5e7e84
--- a/src/providers/ad/ad_domain_info.c
5e7e84
+++ b/src/providers/ad/ad_domain_info.c
5e7e84
@@ -181,6 +181,7 @@ struct ad_domain_info_state {
5e7e84
     struct sdap_id_op *id_op;
5e7e84
     struct sdap_id_ctx *id_ctx;
5e7e84
     struct sdap_options *opts;
5e7e84
+    struct sdap_domain *sdom;
5e7e84
 
5e7e84
     const char *dom_name;
5e7e84
     int base_iter;
5e7e84
@@ -215,6 +216,13 @@ ad_domain_info_send(TALLOC_CTX *mem_ctx,
5e7e84
     state->id_ctx = conn->id_ctx;
5e7e84
     state->opts = conn->id_ctx->opts;
5e7e84
     state->dom_name = dom_name;
5e7e84
+    state->sdom = sdap_domain_get_by_name(state->opts, state->dom_name);
5e7e84
+    if (state->sdom == NULL || state->sdom->search_bases == NULL) {
5e7e84
+        DEBUG(SSSDBG_OP_FAILURE, "Missing internal domain data.\n");
5e7e84
+        ret = EINVAL;
5e7e84
+        goto immediate;
5e7e84
+    }
5e7e84
+
5e7e84
 
5e7e84
     ret = ad_domain_info_next(req);
5e7e84
     if (ret != EOK && ret != EAGAIN) {
5e7e84
@@ -243,7 +251,7 @@ ad_domain_info_next(struct tevent_req *req)
5e7e84
     struct ad_domain_info_state *state =
5e7e84
         tevent_req_data(req, struct ad_domain_info_state);
5e7e84
 
5e7e84
-    base = state->opts->sdom->search_bases[state->base_iter];
5e7e84
+    base = state->sdom->search_bases[state->base_iter];
5e7e84
     if (base == NULL) {
5e7e84
         return EOK;
5e7e84
     }
5e7e84
diff --git a/src/providers/ldap/ldap_common.h b/src/providers/ldap/ldap_common.h
5e7e84
index c78338b5d..426ee68df 100644
5e7e84
--- a/src/providers/ldap/ldap_common.h
5e7e84
+++ b/src/providers/ldap/ldap_common.h
5e7e84
@@ -391,6 +391,9 @@ sdap_domain_remove(struct sdap_options *opts,
5e7e84
 struct sdap_domain *sdap_domain_get(struct sdap_options *opts,
5e7e84
                                     struct sss_domain_info *dom);
5e7e84
 
5e7e84
+struct sdap_domain *sdap_domain_get_by_name(struct sdap_options *opts,
5e7e84
+                                            const char *dom_name);
5e7e84
+
5e7e84
 struct sdap_domain *sdap_domain_get_by_dn(struct sdap_options *opts,
5e7e84
                                           const char *dn);
5e7e84
 
5e7e84
diff --git a/src/providers/ldap/sdap_domain.c b/src/providers/ldap/sdap_domain.c
5e7e84
index fa6e9340d..1785dd20d 100644
5e7e84
--- a/src/providers/ldap/sdap_domain.c
5e7e84
+++ b/src/providers/ldap/sdap_domain.c
5e7e84
@@ -44,6 +44,27 @@ sdap_domain_get(struct sdap_options *opts,
5e7e84
     return sditer;
5e7e84
 }
5e7e84
 
5e7e84
+struct sdap_domain *
5e7e84
+sdap_domain_get_by_name(struct sdap_options *opts,
5e7e84
+                        const char *dom_name)
5e7e84
+{
5e7e84
+    struct sdap_domain *sditer = NULL;
5e7e84
+
5e7e84
+    if (dom_name == NULL) {
5e7e84
+        DEBUG(SSSDBG_OP_FAILURE, "Missing domain name.\n");
5e7e84
+        return NULL;
5e7e84
+    }
5e7e84
+
5e7e84
+    DLIST_FOR_EACH(sditer, opts->sdom) {
5e7e84
+        if (sditer->dom->name != NULL
5e7e84
+                && strcasecmp(sditer->dom->name, dom_name) == 0) {
5e7e84
+            break;
5e7e84
+        }
5e7e84
+    }
5e7e84
+
5e7e84
+    return sditer;
5e7e84
+}
5e7e84
+
5e7e84
 struct sdap_domain *
5e7e84
 sdap_domain_get_by_dn(struct sdap_options *opts,
5e7e84
                       const char *dn)
5e7e84
diff --git a/src/tests/cmocka/test_search_bases.c b/src/tests/cmocka/test_search_bases.c
5e7e84
index 109fa04bf..3276cf118 100644
5e7e84
--- a/src/tests/cmocka/test_search_bases.c
5e7e84
+++ b/src/tests/cmocka/test_search_bases.c
5e7e84
@@ -176,6 +176,51 @@ void test_get_by_dn_fail(void **state)
5e7e84
     do_test_get_by_dn(dn, dns, 1, dns2, 1, DN_NOT_IN_DOMS);
5e7e84
 }
5e7e84
 
5e7e84
+void test_sdap_domain_get_by_name(void **state)
5e7e84
+{
5e7e84
+    struct sdap_options *opts;
5e7e84
+    struct sss_domain_info dom1 = { 0 };
5e7e84
+    dom1.name  = discard_const("dom1");
5e7e84
+    struct sss_domain_info dom2 = { 0 };
5e7e84
+    dom2.name  = discard_const("dom2");
5e7e84
+    struct sss_domain_info dom3 = { 0 };
5e7e84
+    dom3.name  = discard_const("dom3");
5e7e84
+    int ret;
5e7e84
+    struct sdap_domain *sdom;
5e7e84
+
5e7e84
+    opts = talloc_zero(NULL, struct sdap_options);
5e7e84
+    assert_non_null(opts);
5e7e84
+
5e7e84
+    ret = sdap_domain_add(opts, &dom1, NULL);
5e7e84
+    assert_int_equal(ret, EOK);
5e7e84
+
5e7e84
+    ret = sdap_domain_add(opts, &dom2, NULL);
5e7e84
+    assert_int_equal(ret, EOK);
5e7e84
+
5e7e84
+    ret = sdap_domain_add(opts, &dom3, NULL);
5e7e84
+    assert_int_equal(ret, EOK);
5e7e84
+
5e7e84
+    sdom = sdap_domain_get_by_name(opts, NULL);
5e7e84
+    assert_null(sdom);
5e7e84
+
5e7e84
+    sdom = sdap_domain_get_by_name(opts, "abc");
5e7e84
+    assert_null(sdom);
5e7e84
+
5e7e84
+    sdom = sdap_domain_get_by_name(opts, "dom1");
5e7e84
+    assert_non_null(sdom);
5e7e84
+    assert_ptr_equal(sdom->dom, &dom1);
5e7e84
+
5e7e84
+    sdom = sdap_domain_get_by_name(opts, "dom2");
5e7e84
+    assert_non_null(sdom);
5e7e84
+    assert_ptr_equal(sdom->dom, &dom2);
5e7e84
+
5e7e84
+    sdom = sdap_domain_get_by_name(opts, "dom3");
5e7e84
+    assert_non_null(sdom);
5e7e84
+    assert_ptr_equal(sdom->dom, &dom3);
5e7e84
+
5e7e84
+    talloc_free(opts);
5e7e84
+}
5e7e84
+
5e7e84
 int main(void)
5e7e84
 {
5e7e84
     const struct CMUnitTest tests[] = {
5e7e84
@@ -183,7 +228,8 @@ int main(void)
5e7e84
         cmocka_unit_test(test_search_bases_success),
5e7e84
         cmocka_unit_test(test_get_by_dn_fail),
5e7e84
         cmocka_unit_test(test_get_by_dn),
5e7e84
-        cmocka_unit_test(test_get_by_dn2)
5e7e84
+        cmocka_unit_test(test_get_by_dn2),
5e7e84
+        cmocka_unit_test(test_sdap_domain_get_by_name)
5e7e84
      };
5e7e84
 
5e7e84
     return cmocka_run_group_tests(tests, NULL, NULL);
5e7e84
-- 
5e7e84
2.34.3
5e7e84