GO-2021-0412

See a problem?
Source
https://pkg.go.dev/vuln/GO-2021-0412
Import Source
https://vuln.go.dev/ID/GO-2021-0412.json
JSON Data
https://api.osv.dev/v1/vulns/GO-2021-0412
Aliases
Published
2022-04-28T23:35:11Z
Modified
2024-05-20T16:03:47Z
Summary
Incorrect authorization in github.com/containerd/imgcrypt
Details

The imgcrypt library provides API extensions for containerd to support encrypted container images and implements the ctd-decoder command line tool for use by containerd to decrypt encrypted container images. The imgcrypt function CheckAuthorization is supposed to check whether the current used is authorized to access an encrypted image and prevent the user from running an image that another user previously decrypted on the same system. In versions prior to 1.1.4, a failure occurs when an image with a ManifestList is used and the architecture of the local host is not the first one in the ManifestList. Only the first architecture in the list was tested, which may not have its layers available locally since it could not be run on the host architecture. Therefore, the verdict on unavailable layers was that the image could be run anticipating that image run failure would occur later due to the layers not being available. However, this verdict to allow the image to run enabled other architectures in the ManifestList to run an image without providing keys if that image had previously been decrypted. A patch has been applied to imgcrypt 1.1.4. Workarounds may include usage of different namespaces for each remote user.

References
Credits
    • @dimitar-dimitrow

Affected packages

Go / github.com/containerd/imgcrypt

Package

Name
github.com/containerd/imgcrypt
View open source insights on deps.dev
Purl
pkg:golang/github.com/containerd/imgcrypt

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
1.1.4

Ecosystem specific

{
    "imports": [
        {
            "path": "github.com/containerd/imgcrypt/images/encryption",
            "symbols": [
                "CheckAuthorization",
                "DecryptImage",
                "EncryptImage",
                "cryptManifestList"
            ]
        }
    ]
}