Home

Description

Koel is a free, open-source music streaming solution. Prior to version 9.3.5, Koel validates the podcast feed URL via the SafeUrl rule (DNS resolution + public IP check), but the individual episode <enclosure url="..."> values extracted from the RSS XML are stored directly into the database without any SSRF validation. When a user plays an episode, the server downloads the full HTTP response from the unvalidated enclosure URL via Http::sink()->get() and streams it back to the user, enabling full-read SSRF against internal services. This issue has been patched in version 9.3.5.

PUBLISHED Reserved 2026-05-18 | Published 2026-06-12 | Updated 2026-06-13 | Assigner GitHub_M




HIGH: 7.7CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:C/C:H/I:N/A:N

Problem types

CWE-918: Server-Side Request Forgery (SSRF)

Product status

< 9.3.5
affected

References

github.com/koel/koel/security/advisories/GHSA-7j2f-6h2r-6cqc exploit

github.com/koel/koel/security/advisories/GHSA-7j2f-6h2r-6cqc

github.com/...ommit/8708f077efd7d8a332b32e954d65bc837f3a413a

cve.org (CVE-2026-47260)

nvd.nist.gov (CVE-2026-47260)

Download JSON