GHSA-h3gg-7wx2-cq3h

Suggest an improvement
Source
https://github.com/advisories/GHSA-h3gg-7wx2-cq3h
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2021/01/GHSA-h3gg-7wx2-cq3h/GHSA-h3gg-7wx2-cq3h.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-h3gg-7wx2-cq3h
Aliases
Published
2021-01-29T18:13:41Z
Modified
2024-12-02T05:50:14.703790Z
Summary
XSS in Flarum Sticky extension
Details

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.

Database specific
{
    "nvd_published_at": "2021-01-26T21:15:00Z",
    "cwe_ids": [
        "CWE-79"
    ],
    "severity": "MODERATE",
    "github_reviewed": true,
    "github_reviewed_at": "2021-01-26T20:41:58Z"
}
References

Affected packages

Packagist / flarum/sticky

Package

Name
flarum/sticky
Purl
pkg:composer/flarum/sticky

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0.1.0-beta.14
Fixed
0.1.0-beta.15.1

Affected versions

v0.*

v0.1.0-beta.14
v0.1.0-beta.15

Database specific

{
    "last_known_affected_version_range": "<= 0.1.0-beta.15"
}