Headline
GHSA-v2rr-xw95-wcjx: Privilege escalation (PR)/remote code execution from account through Menu.UIExtensionSheet
Impact
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:
- As an advanced user, use the object editor to add an object of type
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}}
- Open
<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.
Patches
This has been patched in XWiki 14.10.8 and 15.3 RC1 by adding proper escaping.
Workarounds
The patch can be manually applied to the document Menu.UIExtensionSheet
, only three lines need to be changed.
References
- https://jira.xwiki.org/browse/XWIKI-20746
- https://github.com/xwiki/xwiki-platform/commit/9e8f080094333dec63a8583229a3799208d773be
- GitHub Advisory Database
- GitHub Reviewed
- CVE-2023-37909
Privilege escalation (PR)/remote code execution from account through Menu.UIExtensionSheet
Critical severity GitHub Reviewed Published Oct 25, 2023 in xwiki/xwiki-platform • Updated Oct 25, 2023
Package
maven org.xwiki.platform:xwiki-platform-menu (Maven)
Affected versions
>= 5.1-rc-1, < 14.10.8
maven org.xwiki.platform:xwiki-platform-menu-ui (Maven)
>= 5.1-rc-1, < 14.10.8
>= 15.0-rc-1, < 15.3-rc-1
Impact
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:
- As an advanced user, use the object editor to add an object of type 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}}
- Open <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.
Patches
This has been patched in XWiki 14.10.8 and 15.3 RC1 by adding proper escaping.
Workarounds
The patch can be manually applied to the document Menu.UIExtensionSheet, only three lines need to be changed.
References
- https://jira.xwiki.org/browse/XWIKI-20746
- xwiki/xwiki-platform@9e8f080
References
- GHSA-v2rr-xw95-wcjx
- https://nvd.nist.gov/vuln/detail/CVE-2023-37909
- xwiki/xwiki-platform@9e8f080
- https://jira.xwiki.org/browse/XWIKI-20746
Published to the GitHub Advisory Database
Oct 25, 2023
Last updated
Oct 25, 2023
Related news
XWiki Platform is a generic wiki platform offering runtime services for applications built on top of it. Starting in version 5.1-rc-1 and prior to versions 14.10.8 and 15.3-rc-1, 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 has been patched in XWiki 14.10.8 and 15.3-rc-1 by adding proper escaping. As a workaround, the patch can be manually applied to the document `Menu.UIExtensionSheet`; only three lines need to be changed.