BUG/MINOR: spoe: Don't report error on applet release if filter is in DONE state
authorChristopher Faulet <cfaulet@haproxy.com>
Tue, 13 May 2025 15:45:18 +0000 (17:45 +0200)
committerWilly Tarreau <w@1wt.eu>
Thu, 15 May 2025 15:01:43 +0000 (17:01 +0200)
When the SPOE applet was released, if a SPOE filter context was still
attached to it, an error was reported to the filter. However, there is no
reason to report an error if the ACK message was already received. Because
of this bug, if the ACK message is received and the SPOE connection is
immediately closed, this prevents the ACK message to be processed.

This patch should be backported to 3.1.

(cherry picked from commit 1cd30c998bce72166855d6b83a8e6865c33095a1)
Signed-off-by: Willy Tarreau <w@1wt.eu>

src/flt_spoe.c

index 686188e..3905562 100644 (file)
@@ -439,8 +439,10 @@ static void spoe_release_appctx(struct appctx *appctx)
        if (spoe_appctx->spoe_ctx)  {
                /* Report an error to stream */
                spoe_appctx->spoe_ctx->spoe_appctx = NULL;
-               spoe_appctx->spoe_ctx->state = SPOE_CTX_ST_ERROR;
-               spoe_appctx->spoe_ctx->status_code = (spoe_appctx->status_code + 0x100);
+               if (spoe_appctx->spoe_ctx->state != SPOE_CTX_ST_DONE) {
+                       spoe_appctx->spoe_ctx->state = SPOE_CTX_ST_ERROR;
+                       spoe_appctx->spoe_ctx->status_code = (spoe_appctx->status_code + 0x100);
+               }
                task_wakeup(spoe_appctx->spoe_ctx->strm->task, TASK_WOKEN_MSG);
        }