Loading HuntDB...

GHSA-vhr5-g3pm-49fm

GitHub Security Advisory

matrix-js-sdk will freeze when a user sets a room with itself as a its predecessor

✓ GitHub Reviewed MODERATE Has CVE

Advisory Details

### Impact
A malicious homeserver can craft a room or room structure such that the predecessors form a cycle. The matrix-js-sdk's `getRoomUpgradeHistory` function will infinitely recurse in this case, causing the code to hang. This method is public but also called by the 'leaveRoomChain()' method, so leaving a room will also trigger the bug.

Even if the CVSS score would be 4.1 ([AV:N/AC:L/PR:L/UI:R/S:C/C:N/I:N/A:L](https://nvd.nist.gov/vuln-metrics/cvss/v3-calculator?vector=AV:N/AC:L/PR:L/UI:R/S:C/C:N/I:N/A:L&version=3.1)) we classify this as High severity issue.

### Patches
This was patched in matrix-js-sdk 34.3.1.

### Workarounds
Sanity check rooms before passing them to the matrix-js-sdk or avoid calling either `getRoomUpgradeHistory` or `leaveRoomChain`.

### References
N/A.

Affected Packages

npm matrix-js-sdk
Affected versions: 0 (fixed in 34.3.1)

Related CVEs

Key Information

GHSA ID
GHSA-vhr5-g3pm-49fm
Published
August 20, 2024 6:35 PM
Last Modified
August 20, 2024 6:35 PM
CVSS Score
5.0 /10
Primary Ecosystem
npm
Primary Package
matrix-js-sdk
GitHub Reviewed
✓ Yes

Dataset

Last updated: September 13, 2025 6:30 AM

Data from GitHub Advisory Database. This information is provided for research and educational purposes.