Onedev is an open source, self-hosted Git Server with CI/CD and Kanban. In versions of Onedev prior to 7.3.0 unauthenticated users can take over a OneDev instance if there is no properly configured reverse proxy. The /git-prereceive-callback endpoint is used by the pre-receive git hook on the server to check for branch protections during a push event. It is only intended to be accessed from localhost, but the check relies on the X-Forwarded-For header. Invoking this endpoint leads to the execution of one of various git commands. The environment variables of this command execution can be controlled via query parameters. This allows attackers to write to arbitrary files, which can in turn lead to the execution of arbitrary code. Such an attack would be very hard to detect, which increases the potential impact even more. Users are advised to upgrade. There are no known workarounds for this issue.
References
Link | Resource |
---|---|
https://blog.sonarsource.com/onedev-remote-code-execution/ | Exploit Third Party Advisory |
https://github.com/theonedev/onedev/commit/f1e97688e4e19d6de1dfa1d00e04655209d39f8e | Patch Third Party Advisory |
https://github.com/theonedev/onedev/releases/tag/v7.3.0 | Release Notes Third Party Advisory |
https://github.com/theonedev/onedev/security/advisories/GHSA-4f9h-h82c-4xm2 | Third Party Advisory |
Configurations
History
No history.
Information
Published : 2022-09-13 19:15
Updated : 2024-02-28 19:29
NVD link : CVE-2022-39205
Mitre link : CVE-2022-39205
CVE.ORG link : CVE-2022-39205
JSON object : View
Products Affected
onedev_project
- onedev
CWE
CWE-287
Improper Authentication