afb-stub-ws: Fix a session leak bug
[src/app-framework-binder.git] / src / afb-stub-ws.c
index d5355ff..48ce9e0 100644 (file)
@@ -485,7 +485,7 @@ static void record_session(struct afb_stub_ws *stubws, struct afb_session *sessi
                        prv = &s->next;
                else {
                        *prv = s->next;
-                       afb_session_addref(s->session);
+                       afb_session_unref(s->session);
                        free(s);
                }
        }
@@ -533,6 +533,8 @@ static void on_call(void *closure, struct afb_proto_ws_call *call, const char *v
                goto unconnected;
        wreq->xreq.context.validated = 1;
        record_session(stubws, wreq->xreq.context.session);
+       if (wreq->xreq.context.created)
+               afb_session_set_autoclose(wreq->xreq.context.session, 1);
 
        /* makes the call */
        wreq->xreq.cred = afb_cred_addref(stubws->cred);