Any user who can edit their own user profile can execute arbitrary script macros including Groovy and Python macros that allow remote code execution including unrestricted read and write access to all wiki contents. This can be reproduced with the following steps:
UIExtensionClass
to your user profile. Set the value "Extension Point ID" to {{/html}}{{async async=false cache=false}}{{groovy}}println("Hello from Groovy!"){{/groovy}}{{/async}}
<xwiki-host>/xwiki/bin/edit/XWiki/<username>?sheet=Menu.UIExtensionSheet
where <xwiki-host>
is the URL of your XWiki installation and <username>
is your user name.If the text Hello from Groovy!" selected="selected">
is displayed in the output, the attack succeeded.
This has been patched in XWiki 14.10.8 and 15.3 RC1 by adding proper escaping.
The patch can be manually applied to the document Menu.UIExtensionSheet
, only three lines need to be changed.
{ "nvd_published_at": "2023-10-25T18:17:28Z", "cwe_ids": [ "CWE-94", "CWE-95" ], "severity": "HIGH", "github_reviewed": true, "github_reviewed_at": "2023-10-25T21:03:11Z" }