Skip to content

XSS in Flarum Sticky extension

Moderate severity GitHub Reviewed Published Jan 26, 2021 in flarum/sticky • Updated Feb 1, 2023

Package

composer flarum/sticky (Composer)

Affected versions

>= 0.1.0-beta.14, <= 0.1.0-beta.15

Patched versions

0.1.0-beta.15.1

Description

Impact

A change in release beta 14 of the Sticky extension caused the plain text content of the first post of a pinned discussion to be injected as HTML on the discussion list. The issue was discovered following an internal audit.

Any HTML would be injected through Mithril's m.trust() helper. This resulted in an HTML injection where <script> tags would not be executed. However it was possible to run javascript from other HTML attributes, enabling a cross-site scripting (XSS) attack to be performed.

Since the exploit only happens with the first post of a pinned discussion, an attacker would need the ability to pin their own discussion, or be able to edit a discussion that was previously pinned.

On forums where all pinned posts are authored by your staff, you can be relatively certain the vulnerability has not been exploited.

Forums where some user-created discussions were pinned can look at the first post edit date to find whether the vulnerability might have been exploited. Because Flarum doesn't store the post content history, you cannot be certain if a malicious edit was reverted.

Patches

The fix will be available in version v0.1.0-beta.16 with Flarum beta 16. The fix has already been back-ported to Flarum beta 15 as version v0.1.0-beta.15.1 of the Sticky extension.

Workarounds

Forum administrators can disable the Sticky extension until they are able to apply the update. The vulnerability cannot be exploited while the extension is disabled.

References

For more information

If you have any questions or comments about this advisory, please start a new discussion on our support forum.

If you discover a security vulnerability within Flarum, please send an e-mail to security@flarum.org. All security vulnerabilities will be promptly addressed. More details can be found in our security policy.

References

@clarkwinkelmann clarkwinkelmann published to flarum/sticky Jan 26, 2021
Reviewed Jan 26, 2021
Published by the National Vulnerability Database Jan 26, 2021
Published to the GitHub Advisory Database Jan 29, 2021
Last updated Feb 1, 2023

Severity

Moderate

EPSS score

0.531%
(78th percentile)

Weaknesses

CVE ID

CVE-2021-21283

GHSA ID

GHSA-h3gg-7wx2-cq3h

Source code

No known source code
Loading Checking history
See something to contribute? Suggest improvements for this vulnerability.