summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJakub Hrozek <jhrozek@redhat.com>2013-01-15 12:35:58 +0100
committerJakub Hrozek <jhrozek@redhat.com>2013-01-15 20:55:50 +0100
commit7435bbb00feef2dde93532e62e40baa694348532 (patch)
tree6380c0768854a1673223e3ab3269f8ae7ed25464
parent53aefebdca2ec9151aff87ae21ee4203eaa9a03a (diff)
downloadsssd-7435bbb00feef2dde93532e62e40baa694348532.tar.gz
sssd-7435bbb00feef2dde93532e62e40baa694348532.tar.xz
sssd-7435bbb00feef2dde93532e62e40baa694348532.zip
TOOLS: Provide a convenience function to refresh a list of groups
-rw-r--r--src/tools/tools_mc_util.c21
-rw-r--r--src/tools/tools_util.h1
2 files changed, 22 insertions, 0 deletions
diff --git a/src/tools/tools_mc_util.c b/src/tools/tools_mc_util.c
index a33dfb97c..45b145d21 100644
--- a/src/tools/tools_mc_util.c
+++ b/src/tools/tools_mc_util.c
@@ -240,3 +240,24 @@ errno_t sss_mc_refresh_group(const char *groupname)
{
return sss_mc_refresh_ent(groupname, SSS_TOOLS_GROUP);
}
+
+errno_t sss_mc_refresh_grouplist(char **groupnames)
+{
+ int i;
+ errno_t ret;
+ bool failed = false;
+
+ if (!groupnames) return EOK;
+
+ for (i = 0; groupnames[i]; i++) {
+ ret = sss_mc_refresh_group(groupnames[i]);
+ if (ret != EOK) {
+ DEBUG(SSSDBG_MINOR_FAILURE,
+ ("Cannot refresh group %s from memory cache\n"));
+ failed = true;
+ continue;
+ }
+ }
+
+ return failed ? EIO : EOK;
+}
diff --git a/src/tools/tools_util.h b/src/tools/tools_util.h
index 0ca52efdf..3554a182d 100644
--- a/src/tools/tools_util.h
+++ b/src/tools/tools_util.h
@@ -111,6 +111,7 @@ errno_t sss_memcache_clear_all(void);
errno_t sss_mc_refresh_user(const char *username);
errno_t sss_mc_refresh_group(const char *groupname);
+errno_t sss_mc_refresh_grouplist(char **groupnames);
/* from files.c */
int remove_tree(const char *root);