diff options
author | Pavel Březina <[email protected]> | 2017-10-19 10:39:21 +0200 |
---|---|---|
committer | Pavel Březina <[email protected]> | 2017-11-06 12:10:44 +0100 |
commit | 2c0a0f2babecc3438734cff7bd01362723c59331 (patch) | |
tree | 39fd030e326ccaef9a7f47b41bd4c8b9604c2835 | |
parent | 3542fe821765cad1f25f6c2a077b55fc1d7d0553 (diff) | |
download | sssd-sudo1-13.tar.gz sssd-sudo1-13.tar.xz sssd-sudo1-13.zip |
sudo: always use srv_opts from id contextsudo1-13
Prior this patch, we remember id_ctx->srv_opts in sudo request to switch
the latest usn values. This works fine most of the time but it may cause
a crash.
If we have two concurrent sudo refresh and one of these fails, it causes
failover to try the next server and possibly replacing the old srv_opts
with new one and it causes an access after free in the other refresh.
-rw-r--r-- | src/providers/ldap/sdap_async_sudo.c | 6 |
1 files changed, 1 insertions, 5 deletions
diff --git a/src/providers/ldap/sdap_async_sudo.c b/src/providers/ldap/sdap_async_sudo.c index e3f3da186..5909e4dbf 100644 --- a/src/providers/ldap/sdap_async_sudo.c +++ b/src/providers/ldap/sdap_async_sudo.c @@ -279,7 +279,6 @@ done: struct sdap_sudo_refresh_state { struct sdap_sudo_ctx *sudo_ctx; struct tevent_context *ev; - struct sdap_server_opts *srv_opts; struct sdap_options *opts; struct sdap_id_op *sdap_op; struct sysdb_ctx *sysdb; @@ -405,9 +404,6 @@ static void sdap_sudo_refresh_connect_done(struct tevent_req *subreq) DEBUG(SSSDBG_TRACE_FUNC, "SUDO LDAP connection successful\n"); - /* Obtain srv_opts here in case of first connection. */ - state->srv_opts = state->sudo_ctx->id_ctx->srv_opts; - /* Renew host information if needed. */ if (state->sudo_ctx->run_hostinfo) { subreq = sdap_sudo_get_hostinfo_send(state, state->opts, @@ -559,7 +555,7 @@ static void sdap_sudo_refresh_done(struct tevent_req *subreq) /* remember new usn */ ret = sysdb_get_highest_usn(state, rules, rules_count, &usn); if (ret == EOK) { - sdap_sudo_set_usn(state->srv_opts, usn); + sdap_sudo_set_usn(state->sudo_ctx->id_ctx->srv_opts, usn); } else { DEBUG(SSSDBG_MINOR_FAILURE, "Unable to get highest USN [%d]: %s\n", ret, sss_strerror(ret)); |