|
|
8d3578 |
From efe44597a3f1181fe60771c0efbfcab54585dc42 Mon Sep 17 00:00:00 2001
|
|
|
8d3578 |
From: =?UTF-8?q?Pavel=20B=C5=99ezina?= <pbrezina@redhat.com>
|
|
|
8d3578 |
Date: Thu, 15 Aug 2019 14:20:26 +0200
|
|
|
8d3578 |
Subject: [PATCH 72/90] sysdb: store original dn in autofs map
|
|
|
8d3578 |
MIME-Version: 1.0
|
|
|
8d3578 |
Content-Type: text/plain; charset=UTF-8
|
|
|
8d3578 |
Content-Transfer-Encoding: 8bit
|
|
|
8d3578 |
|
|
|
8d3578 |
This will be used later when fetching single entry.
|
|
|
8d3578 |
|
|
|
8d3578 |
Resolves:
|
|
|
8d3578 |
https://pagure.io/SSSD/sssd/issue/2607
|
|
|
8d3578 |
|
|
|
8d3578 |
Reviewed-by: Tomáš Halman <thalman@redhat.com>
|
|
|
8d3578 |
---
|
|
|
8d3578 |
src/db/sysdb_autofs.c | 9 +++++++++
|
|
|
8d3578 |
src/db/sysdb_autofs.h | 1 +
|
|
|
8d3578 |
src/providers/ldap/sdap_async_autofs.c | 10 +++++++++-
|
|
|
8d3578 |
src/tests/sysdb-tests.c | 6 +++++-
|
|
|
8d3578 |
4 files changed, 24 insertions(+), 2 deletions(-)
|
|
|
8d3578 |
|
|
|
8d3578 |
diff --git a/src/db/sysdb_autofs.c b/src/db/sysdb_autofs.c
|
|
|
8d3578 |
index dc1ea5586..971abafa3 100644
|
|
|
8d3578 |
--- a/src/db/sysdb_autofs.c
|
|
|
8d3578 |
+++ b/src/db/sysdb_autofs.c
|
|
|
8d3578 |
@@ -99,6 +99,7 @@ errno_t
|
|
|
8d3578 |
sysdb_save_autofsmap(struct sss_domain_info *domain,
|
|
|
8d3578 |
const char *name,
|
|
|
8d3578 |
const char *autofsmapname,
|
|
|
8d3578 |
+ const char *origdn,
|
|
|
8d3578 |
struct sysdb_attrs *attrs,
|
|
|
8d3578 |
int cache_timeout,
|
|
|
8d3578 |
time_t now,
|
|
|
8d3578 |
@@ -138,6 +139,13 @@ sysdb_save_autofsmap(struct sss_domain_info *domain,
|
|
|
8d3578 |
goto done;
|
|
|
8d3578 |
}
|
|
|
8d3578 |
|
|
|
8d3578 |
+ ret = sysdb_attrs_add_string(attrs, SYSDB_ORIG_DN, origdn);
|
|
|
8d3578 |
+ if (ret != EOK) {
|
|
|
8d3578 |
+ DEBUG(SSSDBG_OP_FAILURE, "Could not set origdn [%d]: %s\n",
|
|
|
8d3578 |
+ ret, strerror(ret));
|
|
|
8d3578 |
+ goto done;
|
|
|
8d3578 |
+ }
|
|
|
8d3578 |
+
|
|
|
8d3578 |
ret = sysdb_attrs_add_string(attrs, SYSDB_NAME, name);
|
|
|
8d3578 |
if (ret != EOK) {
|
|
|
8d3578 |
DEBUG(SSSDBG_OP_FAILURE, "Could not set name attribute [%d]: %s\n",
|
|
|
8d3578 |
@@ -202,6 +210,7 @@ sysdb_get_map_byname(TALLOC_CTX *mem_ctx,
|
|
|
8d3578 |
size_t count;
|
|
|
8d3578 |
struct ldb_message **msgs;
|
|
|
8d3578 |
const char *attrs[] = { SYSDB_OBJECTCLASS,
|
|
|
8d3578 |
+ SYSDB_ORIG_DN,
|
|
|
8d3578 |
SYSDB_CACHE_EXPIRE,
|
|
|
8d3578 |
SYSDB_LAST_UPDATE,
|
|
|
8d3578 |
SYSDB_AUTOFS_MAP_NAME,
|
|
|
8d3578 |
diff --git a/src/db/sysdb_autofs.h b/src/db/sysdb_autofs.h
|
|
|
8d3578 |
index 7170334c6..79ecbd94e 100644
|
|
|
8d3578 |
--- a/src/db/sysdb_autofs.h
|
|
|
8d3578 |
+++ b/src/db/sysdb_autofs.h
|
|
|
8d3578 |
@@ -39,6 +39,7 @@ errno_t
|
|
|
8d3578 |
sysdb_save_autofsmap(struct sss_domain_info *domain,
|
|
|
8d3578 |
const char *name,
|
|
|
8d3578 |
const char *autofsmapname,
|
|
|
8d3578 |
+ const char *origdn,
|
|
|
8d3578 |
struct sysdb_attrs *attrs,
|
|
|
8d3578 |
int cache_timeout,
|
|
|
8d3578 |
time_t now,
|
|
|
8d3578 |
diff --git a/src/providers/ldap/sdap_async_autofs.c b/src/providers/ldap/sdap_async_autofs.c
|
|
|
8d3578 |
index 453e95f7b..7548d4a67 100644
|
|
|
8d3578 |
--- a/src/providers/ldap/sdap_async_autofs.c
|
|
|
8d3578 |
+++ b/src/providers/ldap/sdap_async_autofs.c
|
|
|
8d3578 |
@@ -193,15 +193,23 @@ save_autofs_map(struct sss_domain_info *dom,
|
|
|
8d3578 |
bool enumerated)
|
|
|
8d3578 |
{
|
|
|
8d3578 |
const char *mapname;
|
|
|
8d3578 |
+ const char *origdn;
|
|
|
8d3578 |
errno_t ret;
|
|
|
8d3578 |
time_t now;
|
|
|
8d3578 |
|
|
|
8d3578 |
mapname = get_autofs_map_name(map, opts);
|
|
|
8d3578 |
if (!mapname) return EINVAL;
|
|
|
8d3578 |
|
|
|
8d3578 |
+ ret = sysdb_attrs_get_string(map, SYSDB_ORIG_DN, &origdn);
|
|
|
8d3578 |
+ if (ret != EOK) {
|
|
|
8d3578 |
+ DEBUG(SSSDBG_CRIT_FAILURE, "Unable to get original dn [%d]: %s\n",
|
|
|
8d3578 |
+ ret, sss_strerror(ret));
|
|
|
8d3578 |
+ return ret;
|
|
|
8d3578 |
+ }
|
|
|
8d3578 |
+
|
|
|
8d3578 |
now = time(NULL);
|
|
|
8d3578 |
|
|
|
8d3578 |
- ret = sysdb_save_autofsmap(dom, mapname, mapname,
|
|
|
8d3578 |
+ ret = sysdb_save_autofsmap(dom, mapname, mapname, origdn,
|
|
|
8d3578 |
NULL, dom->autofsmap_timeout, now, enumerated);
|
|
|
8d3578 |
if (ret != EOK) {
|
|
|
8d3578 |
return ret;
|
|
|
8d3578 |
diff --git a/src/tests/sysdb-tests.c b/src/tests/sysdb-tests.c
|
|
|
8d3578 |
index 108ef8943..22460d9db 100644
|
|
|
8d3578 |
--- a/src/tests/sysdb-tests.c
|
|
|
8d3578 |
+++ b/src/tests/sysdb-tests.c
|
|
|
8d3578 |
@@ -6365,6 +6365,7 @@ START_TEST(test_autofs_create_map)
|
|
|
8d3578 |
{
|
|
|
8d3578 |
struct sysdb_test_ctx *test_ctx;
|
|
|
8d3578 |
const char *autofsmapname;
|
|
|
8d3578 |
+ const char *origdn;
|
|
|
8d3578 |
errno_t ret;
|
|
|
8d3578 |
|
|
|
8d3578 |
ret = setup_sysdb_tests(&test_ctx);
|
|
|
8d3578 |
@@ -6373,8 +6374,11 @@ START_TEST(test_autofs_create_map)
|
|
|
8d3578 |
autofsmapname = talloc_asprintf(test_ctx, "testmap%d", _i);
|
|
|
8d3578 |
fail_if(autofsmapname == NULL, "Out of memory\n");
|
|
|
8d3578 |
|
|
|
8d3578 |
+ origdn = talloc_asprintf(test_ctx, "cn=testmap%d,dc=test", _i);
|
|
|
8d3578 |
+ fail_if(origdn == NULL, "Out of memory\n");
|
|
|
8d3578 |
+
|
|
|
8d3578 |
ret = sysdb_save_autofsmap(test_ctx->domain, autofsmapname,
|
|
|
8d3578 |
- autofsmapname, NULL, 0, 0, false);
|
|
|
8d3578 |
+ autofsmapname, origdn, NULL, 0, 0, false);
|
|
|
8d3578 |
fail_if(ret != EOK, "Could not store autofs map %s", autofsmapname);
|
|
|
8d3578 |
talloc_free(test_ctx);
|
|
|
8d3578 |
}
|
|
|
8d3578 |
--
|
|
|
8d3578 |
2.20.1
|
|
|
8d3578 |
|