CVE-2020-14144
HIGHArbitrary Code Execution in Gitea
EPSS Exploitation Probability
EPSS (Exploit Prediction Scoring System) is a daily probability model maintained by FIRST.org. It estimates the likelihood a CVE will be exploited in production environments within the next 30 days, derived from real-world threat intelligence signals.
Blast Radius
code.gitea.io/giteaReal-time download stats are indexed for npm and PyPI packages. This vulnerability affects Go packages — download data is not available via public APIs for these ecosystems.
Description
The git hook feature in Gitea 1.1.0 through 1.12.5 might allow for authenticated remote code execution in customer environments where the documentation was not understood (e.g., one viewpoint is that the dangerousness of this feature should be documented immediately above the ENABLE_GIT_HOOKS line in the config file). NOTE: The vendor has indicated this is not a vulnerability and states "This is a functionality of the software that is limited to a very limited subset of accounts. If you give someone the privilege to execute arbitrary code on your server, they can execute arbitrary code on your server. We provide very clear warnings to users around this functionality and what it provides.
Affected Packages
| Ecosystem | Package | Vulnerable range | Fix |
|---|---|---|---|
| 🐹Go | code.gitea.io/gitea | ≥ 1.1.0&&< 1.12.6 | 1.12.6 |
Research use only. For defensive security, authorized penetration testing, and academic research only. Never execute exploit code against systems without explicit written authorization.
The git hook feature in Gitea 1.1.0 through 1.12.5 might allow for authe…
The git hook feature in Gitea 1.1.0 through 1.12.5 might allow for authe…
The git hook feature in Gitea 1.1.0 through 1.12.5 might allow for authe…
The git hook feature in Gitea 1.1.0 through 1.12.5 might allow for authe…
The git hook feature in Gitea 1.1.0 through 1.12.5 might allow for authe…
Frequently Asked Questions
Is CVE-2020-14144 in your stack?
O3 detects CVE-2020-14144 across Go dependencies and uses function-level reachability to confirm whether the vulnerable code path is actually reachable — not just present. No false positives.