CVE-2026-31869
MEDIUMDiscourse: Composer mentions endpoint leaks hidden group membership through PM `allowed_names` check
Title source: cnaDescription
Discourse is an open-source discussion platform. Prior to versions 2026.3.0-latest.1, 2026.2.1, and 2026.1.2, the ComposerController#mentions endpoint reveals hidden group membership to any authenticated user who can message the group. By supplying allowed_names referencing a hidden-membership group and probing arbitrary usernames, an attacker can infer membership based on whether user_reasons returns "private" for a given user. This bypasses group member-visibility controls. Versions 2026.3.0-latest.1, 2026.2.1, and 2026.1.2 contain a patch. To work around this issue, restrict the messageable policy of any hidden-membership group to staff or group members only, so untrusted users cannot reach the vulnerable code path.
Scores
CVSS v3
4.3
EPSS
0.0004
EPSS Percentile
10.6%
Attack Vector
NETWORK
CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:L/I:N/A:N
CISA SSVC
Vulnrichment
Exploitation
none
Automatable
no
Technical Impact
partial
Details
CWE
CWE-200
CWE-285
CWE-639
Status
published
Products (5)
discourse/discourse
2026.3.0
discourse/discourse
2026.1.0 - 2026.1.2
discourse/discourse
= 2026.3.0-latest
discourse/discourse
>= 2026.1.0-latest, < 2026.1.2
discourse/discourse
>= 2026.2.0-latest, < 2026.2.1
Published
Mar 20, 2026
Tracked Since
Mar 20, 2026