CVE-2026-31869

MEDIUM

Discourse: Composer mentions endpoint leaks hidden group membership through PM `allowed_names` check

Title source: cna
STIX 2.1

Description

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