Skip to content

Commit 30c91f7

Browse files
1 parent 0856ce6 commit 30c91f7

1 file changed

Lines changed: 77 additions & 0 deletions

File tree

Lines changed: 77 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,77 @@
1+
{
2+
"schema_version": "1.4.0",
3+
"id": "GHSA-gfhq-7499-f3f2",
4+
"modified": "2026-03-27T15:37:10Z",
5+
"published": "2026-03-27T15:37:10Z",
6+
"aliases": [
7+
"CVE-2026-29788"
8+
],
9+
"summary": "TSPortal: Any user can forge self-deletion requests for any account",
10+
"details": "### Summary\nConversion of empty strings to null allows disguising DPA reports as genuine self-deletion reports.\n\n### Details\nCreating a DPA report about another user and leaving the evidence field empty causes that report to look like the reported user self-requested deletion of their data. Ingenuine report is not distinguishable from a genuine one.\n\nThis can be prevented by disabling [convertEmptyStringsToNull](https://api.laravel.com/docs/12.x/Illuminate/Foundation/Configuration/Middleware.html#method_convertEmptyStringsToNull) in the middleware, or by validating `evidence` in Http/Controllers/DPAController::store() to not be empty.\n\n### PoC\nNew DPA report -> Select \"...someone who I suspect is under the age of 13\" for the \"The above username is...\" field -> Add nothing to the \"Evidence\" field -> Submit\n\n### Impact\nPotential unauthorized deletion of any arbitrary user's data both in the current system (TSPortal) and subsequent systems if actioned.",
11+
"severity": [
12+
{
13+
"type": "CVSS_V3",
14+
"score": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:H/A:N"
15+
},
16+
{
17+
"type": "CVSS_V4",
18+
"score": "CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:P/VC:N/VI:L/VA:H/SC:N/SI:L/SA:H"
19+
}
20+
],
21+
"affected": [
22+
{
23+
"package": {
24+
"ecosystem": "Packagist",
25+
"name": "miraheze/ts-portal"
26+
},
27+
"ranges": [
28+
{
29+
"type": "ECOSYSTEM",
30+
"events": [
31+
{
32+
"introduced": "0"
33+
},
34+
{
35+
"fixed": "30"
36+
}
37+
]
38+
}
39+
],
40+
"database_specific": {
41+
"last_known_affected_version_range": "<= 29"
42+
}
43+
}
44+
],
45+
"references": [
46+
{
47+
"type": "WEB",
48+
"url": "https://github.com/miraheze/TSPortal/security/advisories/GHSA-gfhq-7499-f3f2"
49+
},
50+
{
51+
"type": "ADVISORY",
52+
"url": "https://nvd.nist.gov/vuln/detail/CVE-2026-29788"
53+
},
54+
{
55+
"type": "WEB",
56+
"url": "https://api.laravel.com/docs/12.x/Illuminate/Foundation/Configuration/Middleware.html#method_convertEmptyStringsToNull"
57+
},
58+
{
59+
"type": "PACKAGE",
60+
"url": "https://github.com/miraheze/TSPortal"
61+
},
62+
{
63+
"type": "WEB",
64+
"url": "https://issue-tracker.miraheze.org/T15053"
65+
}
66+
],
67+
"database_specific": {
68+
"cwe_ids": [
69+
"CWE-283",
70+
"CWE-1287"
71+
],
72+
"severity": "HIGH",
73+
"github_reviewed": true,
74+
"github_reviewed_at": "2026-03-27T15:37:10Z",
75+
"nvd_published_at": "2026-03-06T21:16:15Z"
76+
}
77+
}

0 commit comments

Comments
 (0)