跳转到帖子

FreeBSD: VID-2FCCA7E4-B1D7-11ED-B0F4-002590F2A714 (CVE-2022-41903): git -- Heap overflow in `git archive`, `git log --format` leading to RCE

recommended_posts

发布于
  • Members

FreeBSD: VID-2FCCA7E4-B1D7-11ED-B0F4-002590F2A714 (CVE-2022-41903): git -- Heap overflow in `git archive`, `git log --format` leading to RCE

Severity
10
CVSS
(AV:N/AC:L/Au:N/C:C/I:C/A:C)
Published
01/17/2023
Created
02/23/2023
Added
02/22/2023
Modified
01/28/2025

Description

Git is distributed revision control system. `git log` can display commits in an arbitrary format using its `--format` specifiers. This functionality is also exposed to `git archive` via the `export-subst` gitattribute. When processing the padding operators, there is a integer overflow in `pretty.c::format_and_pad_commit()` where a `size_t` is stored improperly as an `int`, and then added as an offset to a `memcpy()`. This overflow can be triggered directly by a user running a command which invokes the commit formatting machinery (e.g., `git log --format=...`). It may also be triggered indirectly through git archive via the export-subst mechanism, which expands format specifiers inside of files within the repository during a git archive. This integer overflow can result in arbitrary heap writes, which may result in arbitrary code execution. The problem has been patched in the versions published on 2023-01-17, going back to v2.30.7. Users are advised to upgrade. Users who are unable to upgrade should disable `git archive` in untrusted repositories. If you expose git archive via `git daemon`, disable it by running `git config --global daemon.uploadArch false`.

Solution(s)

  • freebsd-upgrade-package-git

References

  • CVE-2022-41903
  • USN-5810-2
  • 查看数 695
  • 已创建
  • 最后回复

参与讨论

你可立刻发布并稍后注册。 如果你有帐户,立刻登录发布帖子。

游客
回帖…