diff options
author | Jeff King <peff@peff.net> | 2024-09-24 23:59:14 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2024-09-25 19:24:55 +0200 |
commit | 3d33e96653fecbc692fa5674b127fd598ad2dbeb (patch) | |
tree | 6dccd0f695124e5d4f7c0ec7589487a4be663f3d | |
parent | transport-helper: fix leak of dummy refs_list (diff) | |
download | git-3d33e96653fecbc692fa5674b127fd598ad2dbeb.tar.xz git-3d33e96653fecbc692fa5674b127fd598ad2dbeb.zip |
http: fix leak when redacting cookies from curl trace
When redacting headers for GIT_TRACE_CURL, we build up a redacted cookie
header in a local strbuf, and then copy it into the output. But we
forget to release the temporary strbuf, leaking it for every cookie
header we show.
The other redacted headers don't run into this problem, since they're
able to work in-place in the output buffer. But the cookie parsing is
too complicated for that, since we redact the cookies individually.
This leak is triggered by the cookie tests in t5551.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rw-r--r-- | http.c | 1 |
1 files changed, 1 insertions, 0 deletions
@@ -800,6 +800,7 @@ static int redact_sensitive_header(struct strbuf *header, size_t offset) strbuf_setlen(header, sensitive_header - header->buf); strbuf_addbuf(header, &redacted_header); + strbuf_release(&redacted_header); ret = 1; } return ret; |