summaryrefslogtreecommitdiffstats
path: root/meta-oe/recipes-support/libsoup/libsoup-2.4/CVE-2024-52531-1.patch
blob: 9de0310c8d2cfaf8d6f6bf56217eabc25e029f59 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
From 8331e681c85c3b1893d8d5193783f631bfc07acb Mon Sep 17 00:00:00 2001
From: Changqing Li <changqing.li@windriver.com>
Date: Fri, 16 May 2025 13:42:08 +0800
Subject: [PATCH] tests: Add test for passing invalid UTF-8 to
 soup_header_parse_semi_param_list()

CVE: CVE-2024-52531
Upstream-Status: Backport [https://gitlab.gnome.org/GNOME/libsoup/-/merge_requests/407/diffs?commit_id=825fda3425546847b42ad5270544e9388ff349fe]

Signed-off-by: Changqing Li <changqing.li@windriver.com>
---
 tests/header-parsing-test.c | 11 +++++++++++
 1 file changed, 11 insertions(+)

diff --git a/tests/header-parsing-test.c b/tests/header-parsing-test.c
index b811115..cfcc003 100644
--- a/tests/header-parsing-test.c
+++ b/tests/header-parsing-test.c
@@ -836,6 +836,17 @@ static struct ParamListTest {
 	    { "filename", "t\xC3\xA9st.txt" },
 	  },
 	},
+
+/* This tests invalid UTF-8 data which *should* never be passed here but it was designed to be robust against it. */
+	{ TRUE,
+	  "invalid*=\x69\x27\x27\x93\x93\x93\x93\xff\x61\x61\x61\x61\x61\x61\x61\x62\x63\x64\x65\x0a; filename*=iso-8859-1''\x69\x27\x27\x93\x93\x93\x93\xff\x61\x61\x61\x61\x61\x61\x61\x62\x63\x64\x65\x0a; foo",
+	   {
+		{ "filename", "i''\302\223\302\223\302\223\302\223\303\277aaaaaaabcde" },
+		{ "invalid", "\302\223\302\223\302\223\302\223\303\277aaaaaaabcde" },
+		{ "foo", NULL },
+	   },
+	}
+
 };
 static const int num_paramlisttests = G_N_ELEMENTS (paramlisttests);
 
-- 
2.34.1