CVE-2026-35187 PUBLISHED

pyLoad has SSRF in parse_urls API endpoint via unvalidated URL parameter

Assigner: GitHub_M
Reserved: 01.04.2026 Published: 06.04.2026 Updated: 07.04.2026

pyLoad is a free and open-source download manager written in Python. In 0.5.0b3.dev96 and earlier, the parse_urls API function in src/pyload/core/api/init.py fetches arbitrary URLs server-side via get_url(url) (pycurl) without any URL validation, protocol restriction, or IP blacklist. An authenticated user with ADD permission can make HTTP/HTTPS requests to internal network resources and cloud metadata endpoints, read local files via file:// protocol (pycurl reads the file server-side), interact with internal services via gopher:// and dict:// protocols, and enumerate file existence via error-based oracle (error 37 vs empty response).

Metrics

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

Product Status

Vendor pyload
Product pyload
Versions
  • Version <= 0.5.0b3.dev96 is affected

References

Problem Types

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