Archive::Tar versions before 3.08 for Perl extract...
High severity
Unreviewed
Published
May 26, 2026
to the GitHub Advisory Database
•
Updated May 27, 2026
Description
Published by the National Vulnerability Database
May 26, 2026
Published to the GitHub Advisory Database
May 26, 2026
Last updated
May 27, 2026
Archive::Tar versions before 3.08 for Perl extract hardlinks to attacker controlled paths outside the extraction directory.
_make_special_file() passes the tar header's linkname to link() without validating it against absolute paths or .. segments, creating a hardlink that shares the victim file's inode.
A subsequent write through the extracted name modifies the victim file, and the post-extraction chmod, chown, and utime block in _extract_file() (guarded only against symlinks via -l) applies the tar header's mode, owner, and timestamps to the shared inode during extraction alone.
References