|
|
bb7cd1 |
From 9b9d3e2817fdcf16f2949641d4130b39856a4bf6 Mon Sep 17 00:00:00 2001
|
|
|
bb7cd1 |
From: =?UTF-8?q?Michal=20=C5=BDidek?= <mzidek@redhat.com>
|
|
|
bb7cd1 |
Date: Fri, 28 Apr 2017 20:49:56 +0200
|
|
|
bb7cd1 |
Subject: [PATCH 127/127] SERVER_MODE: Update sdap lists for each ad_ctx
|
|
|
bb7cd1 |
|
|
|
bb7cd1 |
We use separate AD context for each subdomain in the server mode.
|
|
|
bb7cd1 |
Every such context has it's own sdap_domain list witch represents
|
|
|
bb7cd1 |
sdap options such as filter and search bases for every domain.
|
|
|
bb7cd1 |
|
|
|
bb7cd1 |
However AD context can only fully initialize sdap_domain structure
|
|
|
bb7cd1 |
for the same domain for which the whole context was created, which
|
|
|
bb7cd1 |
resulted in the other sdap_domain structures to be have automaticily
|
|
|
bb7cd1 |
detected settings. This can cause problems if user is member of
|
|
|
bb7cd1 |
groups from multiple domains.
|
|
|
bb7cd1 |
|
|
|
bb7cd1 |
Resolves:
|
|
|
bb7cd1 |
https://pagure.io/SSSD/sssd/issue/3381
|
|
|
bb7cd1 |
|
|
|
bb7cd1 |
Reviewed-by: Jakub Hrozek <jhrozek@redhat.com>
|
|
|
bb7cd1 |
(cherry picked from commit 21f3d6124ea28218d02e1e345d38e2b948e4ec23)
|
|
|
bb7cd1 |
---
|
|
|
bb7cd1 |
src/providers/ipa/ipa_subdomains_server.c | 36 +++++++++++++++++++++++++++++++
|
|
|
bb7cd1 |
1 file changed, 36 insertions(+)
|
|
|
bb7cd1 |
|
|
|
bb7cd1 |
diff --git a/src/providers/ipa/ipa_subdomains_server.c b/src/providers/ipa/ipa_subdomains_server.c
|
|
|
bb7cd1 |
index b02ea67af964a03e5466067cdb2b3ba4498120eb..443d83824f329b9d8c3d8e820113e1029f832240 100644
|
|
|
bb7cd1 |
--- a/src/providers/ipa/ipa_subdomains_server.c
|
|
|
bb7cd1 |
+++ b/src/providers/ipa/ipa_subdomains_server.c
|
|
|
bb7cd1 |
@@ -870,6 +870,7 @@ static errno_t ipa_server_create_trusts_step(struct tevent_req *req)
|
|
|
bb7cd1 |
{
|
|
|
bb7cd1 |
struct tevent_req *subreq = NULL;
|
|
|
bb7cd1 |
struct ipa_ad_server_ctx *trust_iter;
|
|
|
bb7cd1 |
+ struct ipa_ad_server_ctx *trust_i;
|
|
|
bb7cd1 |
struct ipa_server_create_trusts_state *state = NULL;
|
|
|
bb7cd1 |
|
|
|
bb7cd1 |
state = tevent_req_data(req, struct ipa_server_create_trusts_state);
|
|
|
bb7cd1 |
@@ -900,6 +901,41 @@ static errno_t ipa_server_create_trusts_step(struct tevent_req *req)
|
|
|
bb7cd1 |
}
|
|
|
bb7cd1 |
}
|
|
|
bb7cd1 |
|
|
|
bb7cd1 |
+ /* Refresh all sdap_dom lists in all ipa_ad_server_ctx contexts */
|
|
|
bb7cd1 |
+ DLIST_FOR_EACH(trust_iter, state->id_ctx->server_mode->trusts) {
|
|
|
bb7cd1 |
+ struct sdap_domain *sdom_a;
|
|
|
bb7cd1 |
+
|
|
|
bb7cd1 |
+ sdom_a = sdap_domain_get(trust_iter->ad_id_ctx->sdap_id_ctx->opts,
|
|
|
bb7cd1 |
+ trust_iter->dom);
|
|
|
bb7cd1 |
+ if (sdom_a == NULL) {
|
|
|
bb7cd1 |
+ continue;
|
|
|
bb7cd1 |
+ }
|
|
|
bb7cd1 |
+
|
|
|
bb7cd1 |
+ DLIST_FOR_EACH(trust_i, state->id_ctx->server_mode->trusts) {
|
|
|
bb7cd1 |
+ struct sdap_domain *sdom_b;
|
|
|
bb7cd1 |
+
|
|
|
bb7cd1 |
+ if (strcmp(trust_iter->dom->name, trust_i->dom->name) == 0) {
|
|
|
bb7cd1 |
+ continue;
|
|
|
bb7cd1 |
+ }
|
|
|
bb7cd1 |
+
|
|
|
bb7cd1 |
+ sdom_b = sdap_domain_get(trust_i->ad_id_ctx->sdap_id_ctx->opts,
|
|
|
bb7cd1 |
+ sdom_a->dom);
|
|
|
bb7cd1 |
+ if (sdom_b == NULL) {
|
|
|
bb7cd1 |
+ continue;
|
|
|
bb7cd1 |
+ }
|
|
|
bb7cd1 |
+
|
|
|
bb7cd1 |
+ /* Replace basedn and search bases from sdom_b with values
|
|
|
bb7cd1 |
+ * from sdom_a */
|
|
|
bb7cd1 |
+ sdom_b->search_bases = sdom_a->search_bases;
|
|
|
bb7cd1 |
+ sdom_b->user_search_bases = sdom_a->user_search_bases;
|
|
|
bb7cd1 |
+ sdom_b->group_search_bases = sdom_a->group_search_bases;
|
|
|
bb7cd1 |
+ sdom_b->netgroup_search_bases = sdom_a->netgroup_search_bases;
|
|
|
bb7cd1 |
+ sdom_b->sudo_search_bases = sdom_a->sudo_search_bases;
|
|
|
bb7cd1 |
+ sdom_b->service_search_bases = sdom_a->service_search_bases;
|
|
|
bb7cd1 |
+ sdom_b->autofs_search_bases = sdom_a->autofs_search_bases;
|
|
|
bb7cd1 |
+ }
|
|
|
bb7cd1 |
+ }
|
|
|
bb7cd1 |
+
|
|
|
bb7cd1 |
return EOK;
|
|
|
bb7cd1 |
}
|
|
|
bb7cd1 |
|
|
|
bb7cd1 |
--
|
|
|
bb7cd1 |
2.9.3
|
|
|
bb7cd1 |
|