Blame SOURCES/0008-RESPONDER-Fix-client-ID-tracking.patch

c29843
From e6d450d4f67c3c639a6ab7e891adccc361d80ecd Mon Sep 17 00:00:00 2001
c29843
From: Justin Stephenson <jstephen@redhat.com>
c29843
Date: Fri, 19 Aug 2022 09:50:22 -0400
c29843
Subject: [PATCH 8/9] RESPONDER: Fix client ID tracking
c29843
MIME-Version: 1.0
c29843
Content-Type: text/plain; charset=UTF-8
c29843
Content-Transfer-Encoding: 8bit
c29843
c29843
Client ID is not stored properly to match requests
c29843
when parallel requests are made to client SSSD
c29843
c29843
Resolves: https://github.com/SSSD/sssd/issues/6307
c29843
c29843
Reviewed-by: Alexey Tikhonov <atikhono@redhat.com>
c29843
Reviewed-by: Pavel Březina <pbrezina@redhat.com>
c29843
c29843
Reviewed-by: Alexey Tikhonov <atikhono@redhat.com>
c29843
---
c29843
 src/responder/common/cache_req/cache_req.c           |  5 +++--
c29843
 .../plugins/cache_req_autofs_entry_by_name.c         |  3 ++-
c29843
 .../cache_req/plugins/cache_req_autofs_map_by_name.c |  3 ++-
c29843
 .../cache_req/plugins/cache_req_autofs_map_entries.c |  3 ++-
c29843
 .../plugins/cache_req_ssh_host_id_by_name.c          |  3 ++-
c29843
 src/responder/common/responder.h                     |  2 +-
c29843
 src/responder/common/responder_common.c              | 12 +++++++-----
c29843
 src/responder/common/responder_dp.c                  |  5 +++--
c29843
 src/responder/common/responder_get_domains.c         |  3 ++-
c29843
 src/responder/pam/pamsrv_cmd.c                       |  4 ++--
c29843
 10 files changed, 26 insertions(+), 17 deletions(-)
c29843
c29843
diff --git a/src/responder/common/cache_req/cache_req.c b/src/responder/common/cache_req/cache_req.c
c29843
index 4dd45b038..bc65bae71 100644
c29843
--- a/src/responder/common/cache_req/cache_req.c
c29843
+++ b/src/responder/common/cache_req/cache_req.c
c29843
@@ -24,6 +24,7 @@
c29843
 #include <errno.h>
c29843
 
c29843
 #include "util/util.h"
c29843
+#include "util/sss_chain_id.h"
c29843
 #include "responder/common/responder.h"
c29843
 #include "responder/common/cache_req/cache_req_private.h"
c29843
 #include "responder/common/cache_req/cache_req_plugin.h"
c29843
@@ -1124,8 +1125,8 @@ struct tevent_req *cache_req_send(TALLOC_CTX *mem_ctx,
c29843
     }
c29843
     state->first_iteration = true;
c29843
 
c29843
-    SSS_REQ_TRACE_CID_CR(SSSDBG_TRACE_FUNC, cr, "New request [CID #%u] '%s'\n",
c29843
-                         rctx->client_id_num, cr->reqname);
c29843
+    SSS_REQ_TRACE_CID_CR(SSSDBG_TRACE_FUNC, cr, "New request [CID #%lu] '%s'\n",
c29843
+                         sss_chain_id_get(), cr->reqname);
c29843
 
c29843
     ret = cache_req_is_well_known_object(state, cr, &result);
c29843
     if (ret == EOK) {
c29843
diff --git a/src/responder/common/cache_req/plugins/cache_req_autofs_entry_by_name.c b/src/responder/common/cache_req/plugins/cache_req_autofs_entry_by_name.c
c29843
index 788b6708c..b2b0a06eb 100644
c29843
--- a/src/responder/common/cache_req/plugins/cache_req_autofs_entry_by_name.c
c29843
+++ b/src/responder/common/cache_req/plugins/cache_req_autofs_entry_by_name.c
c29843
@@ -24,6 +24,7 @@
c29843
 #include "db/sysdb.h"
c29843
 #include "db/sysdb_autofs.h"
c29843
 #include "util/util.h"
c29843
+#include "util/sss_chain_id.h"
c29843
 #include "providers/data_provider.h"
c29843
 #include "responder/common/cache_req/cache_req_plugin.h"
c29843
 
c29843
@@ -86,7 +87,7 @@ cache_req_autofs_entry_by_name_dp_send(TALLOC_CTX *mem_ctx,
c29843
                                              be_conn->bus_name, SSS_BUS_PATH,
c29843
                                              0, data->name.name,
c29843
                                              data->autofs_entry_name,
c29843
-                                             cr->rctx->client_id_num);
c29843
+                                             sss_chain_id_get());
c29843
 }
c29843
 
c29843
 bool
c29843
diff --git a/src/responder/common/cache_req/plugins/cache_req_autofs_map_by_name.c b/src/responder/common/cache_req/plugins/cache_req_autofs_map_by_name.c
c29843
index 5d82641cc..23b11b1cd 100644
c29843
--- a/src/responder/common/cache_req/plugins/cache_req_autofs_map_by_name.c
c29843
+++ b/src/responder/common/cache_req/plugins/cache_req_autofs_map_by_name.c
c29843
@@ -24,6 +24,7 @@
c29843
 #include "db/sysdb.h"
c29843
 #include "db/sysdb_autofs.h"
c29843
 #include "util/util.h"
c29843
+#include "util/sss_chain_id.h"
c29843
 #include "providers/data_provider.h"
c29843
 #include "responder/common/cache_req/cache_req_plugin.h"
c29843
 
c29843
@@ -82,7 +83,7 @@ cache_req_autofs_map_by_name_dp_send(TALLOC_CTX *mem_ctx,
c29843
     return sbus_call_dp_autofs_GetMap_send(mem_ctx, be_conn->conn,
c29843
                                            be_conn->bus_name, SSS_BUS_PATH,
c29843
                                            0, data->name.name,
c29843
-                                           cr->rctx->client_id_num);
c29843
+                                           sss_chain_id_get());
c29843
 }
c29843
 
c29843
 bool
c29843
diff --git a/src/responder/common/cache_req/plugins/cache_req_autofs_map_entries.c b/src/responder/common/cache_req/plugins/cache_req_autofs_map_entries.c
c29843
index 29f289723..18c08ca39 100644
c29843
--- a/src/responder/common/cache_req/plugins/cache_req_autofs_map_entries.c
c29843
+++ b/src/responder/common/cache_req/plugins/cache_req_autofs_map_entries.c
c29843
@@ -24,6 +24,7 @@
c29843
 #include "db/sysdb.h"
c29843
 #include "db/sysdb_autofs.h"
c29843
 #include "util/util.h"
c29843
+#include "util/sss_chain_id.h"
c29843
 #include "providers/data_provider.h"
c29843
 #include "responder/common/cache_req/cache_req_plugin.h"
c29843
 
c29843
@@ -114,7 +115,7 @@ cache_req_autofs_map_entries_dp_send(TALLOC_CTX *mem_ctx,
c29843
     return sbus_call_dp_autofs_Enumerate_send(mem_ctx, be_conn->conn,
c29843
                                               be_conn->bus_name, SSS_BUS_PATH,
c29843
                                               0, data->name.name,
c29843
-                                              cr->rctx->client_id_num);
c29843
+                                              sss_chain_id_get());
c29843
 }
c29843
 
c29843
 bool
c29843
diff --git a/src/responder/common/cache_req/plugins/cache_req_ssh_host_id_by_name.c b/src/responder/common/cache_req/plugins/cache_req_ssh_host_id_by_name.c
c29843
index a8b8f47a8..29f52f10d 100644
c29843
--- a/src/responder/common/cache_req/plugins/cache_req_ssh_host_id_by_name.c
c29843
+++ b/src/responder/common/cache_req/plugins/cache_req_ssh_host_id_by_name.c
c29843
@@ -23,6 +23,7 @@
c29843
 
c29843
 #include "db/sysdb_ssh.h"
c29843
 #include "util/util.h"
c29843
+#include "util/sss_chain_id.h"
c29843
 #include "providers/data_provider.h"
c29843
 #include "responder/common/cache_req/cache_req_plugin.h"
c29843
 
c29843
@@ -86,7 +87,7 @@ cache_req_host_by_name_dp_send(TALLOC_CTX *mem_ctx,
c29843
     return sbus_call_dp_dp_hostHandler_send(mem_ctx, be_conn->conn,
c29843
                                             be_conn->bus_name, SSS_BUS_PATH,
c29843
                                             0, data->name.name, data->alias,
c29843
-                                            cr->rctx->client_id_num);
c29843
+                                            sss_chain_id_get());
c29843
 }
c29843
 
c29843
 static bool
c29843
diff --git a/src/responder/common/responder.h b/src/responder/common/responder.h
c29843
index 5cb79e3e6..259b3ff13 100644
c29843
--- a/src/responder/common/responder.h
c29843
+++ b/src/responder/common/responder.h
c29843
@@ -165,13 +165,13 @@ struct cli_ctx {
c29843
 
c29843
     struct cli_creds *creds;
c29843
     char *cmd_line;
c29843
-    uint64_t old_chain_id;
c29843
 
c29843
     void *protocol_ctx;
c29843
     void *state_ctx;
c29843
 
c29843
     struct tevent_timer *idle;
c29843
     time_t last_request_time;
c29843
+    uint32_t client_id_num;
c29843
 };
c29843
 
c29843
 struct sss_cmd_table {
c29843
diff --git a/src/responder/common/responder_common.c b/src/responder/common/responder_common.c
c29843
index 6e3b61ef0..a4ba8ea71 100644
c29843
--- a/src/responder/common/responder_common.c
c29843
+++ b/src/responder/common/responder_common.c
c29843
@@ -87,8 +87,6 @@ static void client_close_fn(struct tevent_context *ev,
c29843
               "Failed to close fd [%d]: [%s]\n",
c29843
                ctx->cfd, strerror(ret));
c29843
     }
c29843
-    /* Restore the original chain id  */
c29843
-    sss_chain_id_set(ctx->old_chain_id);
c29843
 
c29843
     DEBUG(SSSDBG_TRACE_INTERNAL,
c29843
           "Terminated client [%p][%d]\n",
c29843
@@ -526,7 +524,6 @@ static void accept_fd_handler(struct tevent_context *ev,
c29843
     int fd = accept_ctx->is_private ? rctx->priv_lfd : rctx->lfd;
c29843
 
c29843
     rctx->client_id_num++;
c29843
-
c29843
     if (accept_ctx->is_private) {
c29843
         ret = stat(rctx->priv_sock_name, &stat_buf);
c29843
         if (ret == -1) {
c29843
@@ -557,6 +554,8 @@ static void accept_fd_handler(struct tevent_context *ev,
c29843
 
c29843
     talloc_set_destructor(cctx, cli_ctx_destructor);
c29843
 
c29843
+    cctx->client_id_num = rctx->client_id_num;
c29843
+
c29843
     len = sizeof(cctx->addr);
c29843
     cctx->cfd = accept(fd, (struct sockaddr *)&cctx->addr, &len;;
c29843
     if (cctx->cfd == -1) {
c29843
@@ -645,7 +644,7 @@ static void accept_fd_handler(struct tevent_context *ev,
c29843
 
c29843
     DEBUG(SSSDBG_TRACE_FUNC,
c29843
           "[CID#%u] Client [cmd %s][uid %u][%p][%d] connected%s!\n",
c29843
-          rctx->client_id_num, cctx->cmd_line, cli_creds_get_uid(cctx->creds),
c29843
+          cctx->client_id_num, cctx->cmd_line, cli_creds_get_uid(cctx->creds),
c29843
           cctx, cctx->cfd, accept_ctx->is_private ? " to privileged pipe" : "");
c29843
 
c29843
     return;
c29843
@@ -1090,6 +1089,7 @@ void sss_client_fd_handler(void *ptr,
c29843
                            uint16_t flags)
c29843
 {
c29843
     errno_t ret;
c29843
+    uint64_t old_chain_id;
c29843
     struct cli_ctx *cctx = talloc_get_type(ptr, struct cli_ctx);
c29843
 
c29843
     /* Always reset the responder idle timer on any activity */
c29843
@@ -1105,7 +1105,7 @@ void sss_client_fd_handler(void *ptr,
c29843
     }
c29843
 
c29843
     /* Set the chain id */
c29843
-    cctx->old_chain_id = sss_chain_id_set(cctx->rctx->client_id_num);
c29843
+    old_chain_id = sss_chain_id_set(cctx->client_id_num);
c29843
 
c29843
     if (flags & TEVENT_FD_READ) {
c29843
         recv_fn(cctx);
c29843
@@ -1116,6 +1116,8 @@ void sss_client_fd_handler(void *ptr,
c29843
         send_fn(cctx);
c29843
         return;
c29843
     }
c29843
+    /* Restore the original chain id  */
c29843
+    sss_chain_id_set(old_chain_id);
c29843
 }
c29843
 
c29843
 int sss_connection_setup(struct cli_ctx *cctx)
c29843
diff --git a/src/responder/common/responder_dp.c b/src/responder/common/responder_dp.c
c29843
index d549e02d3..4b4770da1 100644
c29843
--- a/src/responder/common/responder_dp.c
c29843
+++ b/src/responder/common/responder_dp.c
c29843
@@ -23,6 +23,7 @@
c29843
 #include <sys/time.h>
c29843
 #include <time.h>
c29843
 #include "util/util.h"
c29843
+#include "util/sss_chain_id.h"
c29843
 #include "responder/common/responder_packet.h"
c29843
 #include "responder/common/responder.h"
c29843
 #include "providers/data_provider.h"
c29843
@@ -276,7 +277,7 @@ sss_dp_get_account_send(TALLOC_CTX *mem_ctx,
c29843
     subreq = sbus_call_dp_dp_getAccountInfo_send(state, be_conn->conn,
c29843
                  be_conn->bus_name, SSS_BUS_PATH, dp_flags,
c29843
                  entry_type, filter, dom->name, extra,
c29843
-                 rctx->client_id_num);
c29843
+                 sss_chain_id_get());
c29843
     if (subreq == NULL) {
c29843
         DEBUG(SSSDBG_CRIT_FAILURE, "Unable to create subrequest!\n");
c29843
         ret = ENOMEM;
c29843
@@ -406,7 +407,7 @@ sss_dp_resolver_get_send(TALLOC_CTX *mem_ctx,
c29843
                                                   SSS_BUS_PATH,
c29843
                                                   dp_flags, entry_type,
c29843
                                                   filter_type, filter_value,
c29843
-                                                  rctx->client_id_num);
c29843
+                                                  sss_chain_id_get());
c29843
     if (subreq == NULL) {
c29843
         DEBUG(SSSDBG_CRIT_FAILURE, "Unable to create subrequest!\n");
c29843
         ret = ENOMEM;
c29843
diff --git a/src/responder/common/responder_get_domains.c b/src/responder/common/responder_get_domains.c
c29843
index 918124756..aeff28d73 100644
c29843
--- a/src/responder/common/responder_get_domains.c
c29843
+++ b/src/responder/common/responder_get_domains.c
c29843
@@ -19,6 +19,7 @@
c29843
 */
c29843
 
c29843
 #include "util/util.h"
c29843
+#include "util/sss_chain_id.h"
c29843
 #include "responder/common/responder.h"
c29843
 #include "providers/data_provider.h"
c29843
 #include "db/sysdb.h"
c29843
@@ -751,7 +752,7 @@ sss_dp_get_account_domain_send(TALLOC_CTX *mem_ctx,
c29843
                                                    be_conn->bus_name,
c29843
                                                    SSS_BUS_PATH, dp_flags,
c29843
                                                    entry_type, filter,
c29843
-                                                   rctx->client_id_num);
c29843
+                                                   sss_chain_id_get());
c29843
     if (subreq == NULL) {
c29843
         DEBUG(SSSDBG_CRIT_FAILURE, "Unable to create subrequest!\n");
c29843
         ret = ENOMEM;
c29843
diff --git a/src/responder/pam/pamsrv_cmd.c b/src/responder/pam/pamsrv_cmd.c
c29843
index cb0e1b82f..1695554fc 100644
c29843
--- a/src/responder/pam/pamsrv_cmd.c
c29843
+++ b/src/responder/pam/pamsrv_cmd.c
c29843
@@ -1492,7 +1492,7 @@ static int pam_forwarder(struct cli_ctx *cctx, int pam_cmd)
c29843
     }
c29843
     preq->cctx = cctx;
c29843
     preq->cert_auth_local = false;
c29843
-    preq->client_id_num = pctx->rctx->client_id_num;
c29843
+    preq->client_id_num = cctx->client_id_num;
c29843
 
c29843
     preq->pd = create_pam_data(preq);
c29843
     if (!preq->pd) {
c29843
@@ -1513,7 +1513,7 @@ static int pam_forwarder(struct cli_ctx *cctx, int pam_cmd)
c29843
 
c29843
     pd->cmd = pam_cmd;
c29843
     pd->priv = cctx->priv;
c29843
-    pd->client_id_num = pctx->rctx->client_id_num;
c29843
+    pd->client_id_num = cctx->client_id_num;
c29843
 
c29843
     ret = pam_forwarder_parse_data(cctx, pd);
c29843
     if (ret == EAGAIN) {
c29843
-- 
c29843
2.37.1
c29843