Home

Description

tar-rs is a tar archive reading/writing library for Rust. In versions 0.4.44 and below, when unpacking a tar archive, the tar crate's unpack_dir function uses fs::metadata() to check whether a path that already exists is a directory. Because fs::metadata() follows symbolic links, a crafted tarball containing a symlink entry followed by a directory entry with the same name causes the crate to treat the symlink target as a valid existing directory — and subsequently apply chmod to it. This allows an attacker to modify the permissions of arbitrary directories outside the extraction root. This issue has been fixed in version 0.4.45.

PUBLISHED Reserved 2026-03-17 | Published 2026-03-20 | Updated 2026-03-20 | Assigner GitHub_M




MEDIUM: 5.1CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:A/VC:N/VI:L/VA:N/SC:N/SI:N/SA:N

Problem types

CWE-61: UNIX Symbolic Link (Symlink) Following

Product status

< 0.4.45
affected

References

github.com/...tar-rs/security/advisories/GHSA-j4xf-2g29-59ph

github.com/...ommit/17b1fd84e632071cb8eef9d3709bf347bd266446

cve.org (CVE-2026-33056)

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

Download JSON