Skip to content

CI/CD Docker Escape

High
robinshine published GHSA-gjq9-4xx9-cr3q Sep 13, 2022

Package

OneDev (standalone application)

Affected versions

< 7.3.0

Patched versions

7.3.0

Description

Observation

When using Docker-based job executors, the Docker socket (e.g. /var/run/docker.sock on Linux) is mounted into each Docker step. Users that can define and trigger CI/CD jobs on a project could use this to control the Docker daemon on the host machine. This is a known dangerous pattern, as it can be used to break out of Docker containers and, in most cases, gain root privileges on the host system.

Impact

This issue allows regular (non-admin) users to potentially take over the build infrastructure of a OneDev instance. Attackers need to have an account (or be able to register one) and need permission to create a project.
Since code.onedev.io has the right preconditions for this to be exploited by remote attackers, it could have been used to hijack builds of OneDev itself, e.g. by injecting malware into the docker images that are built and pushed to Docker Hub. The impact is increased by this as described before.

Patches

7.3.0 or higher. OneDev dogfooding instance is built from scratch with clean code.

Credits

This issue was reported by SonarSource team.

Severity

High

CVE ID

CVE-2022-39206

Weaknesses

No CWEs