Description
Nix is a package manager for Linux and other Unix systems. A bug in the fix for CVE-2024-27297 allowed for arbitrary overwrites of files writable by the Nix process orchestrating the builds (typically the Nix daemon running as root in multi-user installations) by following symlinks during fixed-output derivation output registration. This affects sandboxed Linux builds - sandboxed macOS builds are unaffected. The location of the temporary output used for the output copy was located inside the build chroot. A symlink, pointing to an arbitrary location in the filesystem, could be created by the derivation builder at that path. During output registration, the Nix process (running in the host mount namespace) would follow that symlink and overwrite the destination with the derivation's output contents. In multi-user installations, this allows all users able to submit builds to the Nix daemon (allowed-users - defaulting to all users) to gain root privileges by modifying sensitive files. This vulnerability is fixed in 2.34.5, 2.33.4, 2.32.7, 2.31.4, 2.30.4, 2.29.3, and 2.28.6.
Problem types
CWE-61: UNIX Symbolic Link (Symlink) Following
Product status
>= 2.29.0, < 2.29.3
>= 2.30.0, < 2.30.4
>= 2.31.0, < 2.31.4
>= 2.32.0, < 2.32.7
>= 2.33.0, < 2.33.4
>= 2.34.0, < 2.34.5
>= 2.20.5, <= 2.20.9
>= 2.19.4, <= 2.19.7
>= 2.18.2, <= 2.18.9
References
github.com/NixOS/nix/security/advisories/GHSA-g3g9-5vj6-r3gj
github.com/NixOS/nix/pull/10178
github.com/...ommit/244f3eee0bbc7f11e9b383a15ed7368e2c4becc9
github.com/...ommit/4bc5a3510fa3735798f9ed3a2a30a3ea7b32343a
github.com/...ommit/7794354a982449927ee7401cdeb573ddd16c4688
github.com/...ommit/a3163b9eabb952b4aa96e376dea95ebcca97b31a