Skip to content

Privilege escalation (PR)/remote code execution from account through Menu.UIExtensionSheet

High severity GitHub Reviewed Published Oct 25, 2023 in xwiki/xwiki-platform • Updated Nov 10, 2023

Package

maven org.xwiki.platform:xwiki-platform-menu (Maven)

Affected versions

>= 5.1-rc-1, < 14.10.8

Patched versions

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
14.10.8
15.3-rc-1

Description

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:

  1. 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}}
  2. 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

References

@michitux michitux published to xwiki/xwiki-platform Oct 25, 2023
Published by the National Vulnerability Database Oct 25, 2023
Published to the GitHub Advisory Database Oct 25, 2023
Reviewed Oct 25, 2023
Last updated Nov 10, 2023

Severity

High
8.8
/ 10

CVSS base metrics

Attack vector
Network
Attack complexity
Low
Privileges required
Low
User interaction
None
Scope
Unchanged
Confidentiality
High
Integrity
High
Availability
High
CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H

CVE ID

CVE-2023-37909

GHSA ID

GHSA-v2rr-xw95-wcjx

Source code

Checking history
See something to contribute? Suggest improvements for this vulnerability.