diff options
author | Stephen Gallagher <sgallagh@redhat.com> | 2009-04-14 09:24:27 -0400 |
---|---|---|
committer | Simo Sorce <ssorce@redhat.com> | 2009-04-14 13:50:48 -0400 |
commit | ecd411426a6c37d842b6d390c4895f34538130cf (patch) | |
tree | b19e871fe2e90eaf272cf59147f08e9a0f1f03e9 /server | |
parent | d7f0f3d6aaaa687eac388a0b2e0a0175ca50c937 (diff) | |
download | sssd-ecd411426a6c37d842b6d390c4895f34538130cf.tar.gz sssd-ecd411426a6c37d842b6d390c4895f34538130cf.tar.bz2 sssd-ecd411426a6c37d842b6d390c4895f34538130cf.zip |
Add reconnection code between the NSS responder and the Data provider
Diffstat (limited to 'server')
-rw-r--r-- | server/responder/nss/nsssrv.c | 53 |
1 files changed, 52 insertions, 1 deletions
diff --git a/server/responder/nss/nsssrv.c b/server/responder/nss/nsssrv.c index 58b09fb3..8e72a95c 100644 --- a/server/responder/nss/nsssrv.c +++ b/server/responder/nss/nsssrv.c @@ -219,6 +219,41 @@ done: return ret; } +static void nss_shutdown(struct resp_ctx *rctx) +{ + /* TODO: Do clean-up here */ + + /* Nothing left to do but exit() */ + exit(0); +} + + +static void nss_dp_reconnect_init(struct sbus_conn_ctx *sconn, int status, void *pvt) +{ + int ret; + struct resp_ctx *rctx = talloc_get_type(pvt, struct resp_ctx); + + /* Did we reconnect successfully? */ + if (status == SBUS_RECONNECT_SUCCESS) { + /* Add the methods back to the new connection */ + ret = sbus_conn_add_method_ctx(rctx->dp_ctx->scon_ctx, + rctx->dp_ctx->sm_ctx); + if (ret != EOK) { + DEBUG(0, ("Could not re-add methods on reconnection.\n")); + nss_shutdown(rctx); + } + + DEBUG(1, ("Reconnected to the Data Provider.\n")); + return; + } + + /* Handle failure */ + DEBUG(0, ("Could not reconnect to data provider.\n")); + /* Kill the backend and let the monitor restart it */ + nss_shutdown(rctx); +} + + int nss_process_init(TALLOC_CTX *mem_ctx, struct tevent_context *ev, struct confdb_ctx *cdb) @@ -226,7 +261,7 @@ int nss_process_init(TALLOC_CTX *mem_ctx, struct sbus_method *nss_dp_methods; struct sss_cmd_table *nss_cmds; struct nss_ctx *nctx; - int ret; + int ret, max_retries; nctx = talloc_zero(mem_ctx, struct nss_ctx); if (!nctx) { @@ -261,6 +296,22 @@ int nss_process_init(TALLOC_CTX *mem_ctx, return ret; } + /* Enable automatic reconnection to the Data Provider */ + + /* FIXME: "retries" is too generic, either get it from a global config + * or specify these retries are about the sbus connections to DP */ + ret = confdb_get_int(nctx->rctx->cdb, nctx->rctx, + nctx->rctx->confdb_service_path, + "retries", 3, &max_retries); + if (ret != EOK) { + DEBUG(0, ("Failed to set up automatic reconnection\n")); + return ret; + } + + sbus_reconnect_init(nctx->rctx->dp_ctx->scon_ctx, + max_retries, + nss_dp_reconnect_init, nctx->rctx); + DEBUG(1, ("NSS Initialization complete\n")); return EOK; |