Описание
Improper input validation in umoci
Impact
umoci 0.4.6 and earlier can be tricked into modifying host files by creating a malicious layer that has a symlink with the name "." (or "/"). Because umoci deletes inodes if they change types, this results in the rootfs directory being replaced with an attacker-controlled symlink. Subsequent image layers will then be applied on top of the target of the symlink (which could be any directory on the host filesystem the user running umoci has access to).
While umoci does have defences against symlink-based attacks, they are all implemented by resolving things relative to the rootfs directory -- if the rootfs itself is a symlink, umoci resolves it first.
This vulnerability affects both "umoci unpack" and "umoci raw unpack".
Patches
This issue has been patched in umoci 0.4.7, see the references section for the specific commit which fixed this vulnerability.
Workarounds
Note that if you use umoci as an unprivileged user (using the --rootless flag) then umoci will not be able to overwrite any files that your user doesn't have access to. Other possible mitigations are to run umoci under an LSM profile such as AppArmor or SELinux to restrict the level of access it has outside of container image directories.
References
Credits
Thanks to Robin Peraglie from Cure53 for discovering and reporting this vulnerability.
For more information
If you have any questions or comments about this advisory
- Open an issue in https://github.com/opencontainers/umoci.
- Email us at security@opencontainers.org.
Пакеты
github.com/opencontainers/umoci
< 0.4.7
0.4.7
Связанные уязвимости
Open Container Initiative umoci before 0.4.7 allows attackers to overwrite arbitrary host paths via a crafted image that causes symlink traversal when "umoci unpack" or "umoci raw unpack" is used.
Open Container Initiative umoci before 0.4.7 allows attackers to overwrite arbitrary host paths via a crafted image that causes symlink traversal when "umoci unpack" or "umoci raw unpack" is used.
Open Container Initiative umoci before 0.4.7 allows attackers to overw ...