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

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