Vulnerability description

Improper Limitation of a Pathname to a Restricted Directory ('Path Traversal') vulnerability in Erlang OTP (stdlib modules) allows Absolute Path Traversal, File Manipulation.

This vulnerability is associated with program files lib/stdlib/src/zip.erl and program routines zip:unzip/1, zip:unzip/2, zip:extract/1, zip:extract/2 unless the memory option is passed.

This issue affects OTP from OTP 17.0 until OTP 28.0.1, OTP 27.3.4.1 and OTP 26.2.5.13, corresponding to stdlib from 2.0 until 7.0.1, 6.2.2.1 and 5.2.3.4.

Affected

pkg:otp/stdlib

Module Source File Routine
stdlib lib/stdlib/src/zip.erl zip:unzip/1
zip:unzip/2
zip:extract/1
zip:extract/2
Status Type Version Changes / Fixed in
affected otp 2.0
  • unaffected at 7.0.1
  • unaffected at 6.2.2.1
  • unaffected at 5.2.3.4

pkg:github/erlang/otp

Module Source File Routine
stdlib lib/stdlib/src/zip.erl zip:unzip/1
zip:unzip/2
zip:extract/1
zip:extract/2
Status Type Version Changes / Fixed in
affected otp 17.0
affected git 07b8f441ca

Workarounds

You can use zip:list_dir/1 on the archive and verify that no files contain absolute paths before extracting the archive to disk.

References

Credits

  • Finder: Wander Nauta
  • Remediation developer: Lukas Backström
  • Remediation reviewer: Björn Gustavsson

CVE record as JSON:  GET /cves/CVE-2025-4748.json
OSV record as JSON:  GET /osv/EEF-CVE-2025-4748.json