summaryrefslogtreecommitdiffstats
path: root/src/tools/sssctl/sssctl_data.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/tools/sssctl/sssctl_data.c')
-rw-r--r--src/tools/sssctl/sssctl_data.c30
1 files changed, 30 insertions, 0 deletions
diff --git a/src/tools/sssctl/sssctl_data.c b/src/tools/sssctl/sssctl_data.c
index f1162da4e..3ab2ddf20 100644
--- a/src/tools/sssctl/sssctl_data.c
+++ b/src/tools/sssctl/sssctl_data.c
@@ -22,7 +22,9 @@
#include <stdio.h>
#include "util/util.h"
+#include "db/sysdb.h"
#include "tools/common/sss_tools.h"
+#include "tools/common/sss_process.h"
#include "tools/sssctl/sssctl.h"
#define CACHE_FILE(db) " " DB_PATH "/" db
@@ -256,3 +258,31 @@ errno_t sssctl_remove_cache(struct sss_cmdline *cmdline,
return EOK;
}
+
+errno_t sssctl_upgrade_cache(struct sss_cmdline *cmdline,
+ struct sss_tool_ctx *tool_ctx,
+ void *pvt)
+{
+ struct sysdb_upgrade_ctx db_up_ctx;
+ errno_t ret;
+
+ if (sss_deamon_running()) {
+ return ERR_SSSD_RUNNING;
+ }
+
+ ret = confdb_get_domains(tool_ctx->confdb, &tool_ctx->domains);
+ if (ret != EOK) {
+ DEBUG(SSSDBG_FATAL_FAILURE, "No domains configured.\n");
+ return ret;
+ }
+
+ db_up_ctx.cdb = tool_ctx->confdb;
+ ret = sysdb_init_ext(tool_ctx, tool_ctx->domains, &db_up_ctx,
+ true, 0, 0);
+ if (ret != EOK) {
+ SYSDB_VERSION_ERROR_DAEMON(ret);
+ return ret;
+ }
+
+ return EOK;
+}