diff options
-rw-r--r-- | src/responder/nss/nsssrv_cmd.c | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/src/responder/nss/nsssrv_cmd.c b/src/responder/nss/nsssrv_cmd.c index b163d6d57..012946730 100644 --- a/src/responder/nss/nsssrv_cmd.c +++ b/src/responder/nss/nsssrv_cmd.c @@ -168,6 +168,13 @@ void nss_update_pw_memcache(struct nss_ctx *nctx) "Internal failure in memory cache code: %d [%s]\n", ret, strerror(ret)); } + + ret = sss_mmap_cache_pw_invalidate(nctx->initgr_mc_ctx, &key); + if (ret != EOK && ret != ENOENT) { + DEBUG(SSSDBG_CRIT_FAILURE, + "Internal failure in memory cache code: %d [%s]\n", + ret, strerror(ret)); + } } talloc_zfree(res); @@ -798,6 +805,15 @@ static int delete_entry_from_memcache(struct sss_domain_info *dom, char *name, goto done; } break; + case SSS_MC_INITGROUPS: + ret = sss_mmap_cache_initgr_invalidate(mc_ctx, &delete_name); + if (ret != EOK && ret != ENOENT) { + DEBUG(SSSDBG_CRIT_FAILURE, + "Internal failure in memory cache code: %d [%s]\n", + ret, strerror(ret)); + goto done; + } + break; default: ret = EINVAL; goto done; @@ -967,6 +983,14 @@ static int nss_cmd_getpwnam_search(struct nss_dom_ctx *dctx) "Deleting user from memcache failed.\n"); } + ret = delete_entry_from_memcache(dctx->domain, name, + nctx->initgr_mc_ctx, + SSS_MC_INITGROUPS); + if (ret != EOK) { + DEBUG(SSSDBG_MINOR_FAILURE, + "Deleting user from memcache failed.\n"); + } + return ENOENT; } @@ -3871,6 +3895,14 @@ void nss_update_initgr_memcache(struct nss_ctx *nctx, ret, strerror(ret)); } + ret = sss_mmap_cache_initgr_invalidate(nctx->initgr_mc_ctx, + &delete_name); + if (ret != EOK && ret != ENOENT) { + DEBUG(SSSDBG_CRIT_FAILURE, + "Internal failure in memory cache code: %d [%s]\n", + ret, strerror(ret)); + } + /* Also invalidate his groups */ changed = true; } else { |