Blame SOURCES/0001-NSS-Move-memcache-setup-to-separate-function.patch

9f2ebf
From 82d52dbfd51330cd1fda4734b9e901431e137211 Mon Sep 17 00:00:00 2001
9f2ebf
From: =?UTF-8?q?Michal=20=C5=BDidek?= <mzidek@redhat.com>
9f2ebf
Date: Thu, 19 Oct 2017 16:39:27 +0200
9f2ebf
Subject: [PATCH 01/21] NSS: Move memcache setup to separate function
9f2ebf
MIME-Version: 1.0
9f2ebf
Content-Type: text/plain; charset=UTF-8
9f2ebf
Content-Transfer-Encoding: 8bit
9f2ebf
9f2ebf
Related:
9f2ebf
https://pagure.io/SSSD/sssd/issue/3496
9f2ebf
9f2ebf
Reviewed-by: Sumit Bose <sbose@redhat.com>
9f2ebf
Reviewed-by: Pavel Březina <pbrezina@redhat.com>
9f2ebf
Reviewed-by: Fabiano Fidêncio <fidencio@redhat.com>
9f2ebf
Reviewed-by: Jakub Hrozek <jhrozek@redhat.com>
9f2ebf
(cherry picked from commit 878b0d42aca5839fdc1d97a68ce181e280f1ed7b)
9f2ebf
---
9f2ebf
 src/responder/nss/nsssrv.c | 91 ++++++++++++++++++++++++++--------------------
9f2ebf
 1 file changed, 51 insertions(+), 40 deletions(-)
9f2ebf
9f2ebf
diff --git a/src/responder/nss/nsssrv.c b/src/responder/nss/nsssrv.c
9f2ebf
index d67b9fac8d770d113560e41b259e2d5edd219343..21dd198226da6cf14d7db4941806048662970fed 100644
9f2ebf
--- a/src/responder/nss/nsssrv.c
9f2ebf
+++ b/src/responder/nss/nsssrv.c
9f2ebf
@@ -252,6 +252,56 @@ static void nss_dp_reconnect_init(struct sbus_connection *conn,
9f2ebf
     /* nss_shutdown(rctx); */
9f2ebf
 }
9f2ebf
 
9f2ebf
+static int setup_memcaches(struct nss_ctx *nctx)
9f2ebf
+{
9f2ebf
+    int ret;
9f2ebf
+    int memcache_timeout;
9f2ebf
+
9f2ebf
+    /* Remove the CLEAR_MC_FLAG file if exists. */
9f2ebf
+    ret = unlink(SSS_NSS_MCACHE_DIR"/"CLEAR_MC_FLAG);
9f2ebf
+    if (ret != 0 && errno != ENOENT) {
9f2ebf
+        ret = errno;
9f2ebf
+        DEBUG(SSSDBG_CRIT_FAILURE,
9f2ebf
+              "Failed to unlink file [%s]. This can cause memory cache to "
9f2ebf
+               "be purged when next log rotation is requested. %d: %s\n",
9f2ebf
+               SSS_NSS_MCACHE_DIR"/"CLEAR_MC_FLAG, ret, strerror(ret));
9f2ebf
+    }
9f2ebf
+
9f2ebf
+    ret = confdb_get_int(nctx->rctx->cdb,
9f2ebf
+                         CONFDB_NSS_CONF_ENTRY,
9f2ebf
+                         CONFDB_MEMCACHE_TIMEOUT,
9f2ebf
+                         300, &memcache_timeout);
9f2ebf
+    if (ret != EOK) {
9f2ebf
+        DEBUG(SSSDBG_FATAL_FAILURE,
9f2ebf
+              "Failed to get 'memcache_timeout' option from confdb.\n");
9f2ebf
+        return ret;
9f2ebf
+    }
9f2ebf
+
9f2ebf
+    /* TODO: read cache sizes from configuration */
9f2ebf
+    ret = sss_mmap_cache_init(nctx, "passwd", SSS_MC_PASSWD,
9f2ebf
+                              SSS_MC_CACHE_ELEMENTS, (time_t)memcache_timeout,
9f2ebf
+                              &nctx->pwd_mc_ctx);
9f2ebf
+    if (ret) {
9f2ebf
+        DEBUG(SSSDBG_CRIT_FAILURE, "passwd mmap cache is DISABLED\n");
9f2ebf
+    }
9f2ebf
+
9f2ebf
+    ret = sss_mmap_cache_init(nctx, "group", SSS_MC_GROUP,
9f2ebf
+                              SSS_MC_CACHE_ELEMENTS, (time_t)memcache_timeout,
9f2ebf
+                              &nctx->grp_mc_ctx);
9f2ebf
+    if (ret) {
9f2ebf
+        DEBUG(SSSDBG_CRIT_FAILURE, "group mmap cache is DISABLED\n");
9f2ebf
+    }
9f2ebf
+
9f2ebf
+    ret = sss_mmap_cache_init(nctx, "initgroups", SSS_MC_INITGROUPS,
9f2ebf
+                              SSS_MC_CACHE_ELEMENTS, (time_t)memcache_timeout,
9f2ebf
+                              &nctx->initgr_mc_ctx);
9f2ebf
+    if (ret) {
9f2ebf
+        DEBUG(SSSDBG_CRIT_FAILURE, "initgroups mmap cache is DISABLED\n");
9f2ebf
+    }
9f2ebf
+
9f2ebf
+    return EOK;
9f2ebf
+}
9f2ebf
+
9f2ebf
 int nss_process_init(TALLOC_CTX *mem_ctx,
9f2ebf
                      struct tevent_context *ev,
9f2ebf
                      struct confdb_ctx *cdb)
9f2ebf
@@ -260,7 +310,6 @@ int nss_process_init(TALLOC_CTX *mem_ctx,
9f2ebf
     struct sss_cmd_table *nss_cmds;
9f2ebf
     struct be_conn *iter;
9f2ebf
     struct nss_ctx *nctx;
9f2ebf
-    int memcache_timeout;
9f2ebf
     int ret, max_retries;
9f2ebf
     enum idmap_error_code err;
9f2ebf
     int fd_limit;
9f2ebf
@@ -330,49 +379,11 @@ int nss_process_init(TALLOC_CTX *mem_ctx,
9f2ebf
         goto fail;
9f2ebf
     }
9f2ebf
 
9f2ebf
-    /* create mmap caches */
9f2ebf
-    /* Remove the CLEAR_MC_FLAG file if exists. */
9f2ebf
-    ret = unlink(SSS_NSS_MCACHE_DIR"/"CLEAR_MC_FLAG);
9f2ebf
-    if (ret != 0 && errno != ENOENT) {
9f2ebf
-        ret = errno;
9f2ebf
-        DEBUG(SSSDBG_CRIT_FAILURE,
9f2ebf
-              "Failed to unlink file [%s]. This can cause memory cache to "
9f2ebf
-               "be purged when next log rotation is requested. %d: %s\n",
9f2ebf
-               SSS_NSS_MCACHE_DIR"/"CLEAR_MC_FLAG, ret, strerror(ret));
9f2ebf
-    }
9f2ebf
-
9f2ebf
-    ret = confdb_get_int(nctx->rctx->cdb,
9f2ebf
-                         CONFDB_NSS_CONF_ENTRY,
9f2ebf
-                         CONFDB_MEMCACHE_TIMEOUT,
9f2ebf
-                         300, &memcache_timeout);
9f2ebf
+    ret = setup_memcaches(nctx);
9f2ebf
     if (ret != EOK) {
9f2ebf
-        DEBUG(SSSDBG_FATAL_FAILURE,
9f2ebf
-              "Failed to get 'memcache_timeout' option from confdb.\n");
9f2ebf
         goto fail;
9f2ebf
     }
9f2ebf
 
9f2ebf
-    /* TODO: read cache sizes from configuration */
9f2ebf
-    ret = sss_mmap_cache_init(nctx, "passwd", SSS_MC_PASSWD,
9f2ebf
-                              SSS_MC_CACHE_ELEMENTS, (time_t)memcache_timeout,
9f2ebf
-                              &nctx->pwd_mc_ctx);
9f2ebf
-    if (ret) {
9f2ebf
-        DEBUG(SSSDBG_CRIT_FAILURE, "passwd mmap cache is DISABLED\n");
9f2ebf
-    }
9f2ebf
-
9f2ebf
-    ret = sss_mmap_cache_init(nctx, "group", SSS_MC_GROUP,
9f2ebf
-                              SSS_MC_CACHE_ELEMENTS, (time_t)memcache_timeout,
9f2ebf
-                              &nctx->grp_mc_ctx);
9f2ebf
-    if (ret) {
9f2ebf
-        DEBUG(SSSDBG_CRIT_FAILURE, "group mmap cache is DISABLED\n");
9f2ebf
-    }
9f2ebf
-
9f2ebf
-    ret = sss_mmap_cache_init(nctx, "initgroups", SSS_MC_INITGROUPS,
9f2ebf
-                              SSS_MC_CACHE_ELEMENTS, (time_t)memcache_timeout,
9f2ebf
-                              &nctx->initgr_mc_ctx);
9f2ebf
-    if (ret) {
9f2ebf
-        DEBUG(SSSDBG_CRIT_FAILURE, "initgroups mmap cache is DISABLED\n");
9f2ebf
-    }
9f2ebf
-
9f2ebf
     /* Set up file descriptor limits */
9f2ebf
     ret = confdb_get_int(nctx->rctx->cdb,
9f2ebf
                          CONFDB_NSS_CONF_ENTRY,
9f2ebf
-- 
9f2ebf
2.13.5
9f2ebf