In addition to running containers as build steps, BuildKit also provides APIs for running interactive containers based on built images. It was possible to use these APIs to ask BuildKit to run a container with elevated privileges. Normally, running such containers is only allowed if special security.insecure entitlement is enabled both by buildkitd configuration and allowed by the user initializing the build request.
The issue has been fixed in v0.12.5 .
Avoid using BuildKit frontends from untrusted sources. A frontend image is usually specified as the #syntax line on your Dockerfile, or with --frontend flag when using buildctl build command.
{
"github_reviewed_at": "2024-01-31T22:43:20Z",
"severity": "CRITICAL",
"github_reviewed": true,
"cwe_ids": [
"CWE-863"
],
"nvd_published_at": "2024-01-31T22:15:54Z"
}