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.
Problem types
CWE-918: Server-Side Request Forgery (SSRF)
Product status
References
github.com/koel/koel/security/advisories/GHSA-7j2f-6h2r-6cqc
github.com/koel/koel/security/advisories/GHSA-7j2f-6h2r-6cqc
github.com/...ommit/8708f077efd7d8a332b32e954d65bc837f3a413a