VDB
KO
CRITICAL 9.0

GHSA-wfqx-gjrf-g28r

Crossplane: Signature verification TOCTOU allows installing unverified package content via mutable tag

Details

## Summary

Crossplane allows package signature verification to be configured via the `ImageConfig` mechanism. When enabled, the package manager uses cosign to verify that packages are correctly signed before pulling and installing them.

When a package is installed using a tag reference (e.g., a semantic version), a malicious OCI registry could serve a correctly signed image for verification, then subsequently serve an unsigned image for installation. This is possible because Crossplane resolves the tag reference separately for each step.

This vulnerability is relevant only for users who do all three of the following:

1. Configure signature verification for packages, 2. Install packages using tag references rather than digests, and 3. Install packages from registries they do not control.

## Mitigation

Installing packages by image digest rather than using tags avoids this issue.

## Fix

The package manager has been updated to resolve tag references once and use the resulting digest for both signature verification and image fetching. This ensures that Crossplane pulls the same content that had its signature verified. The fix has been applied to Crossplane's `main` branch and backported to the v2.3 and v2.2 release branches; it will be released in v2.3.3 and v2.2.3.

## Credits

This issue was reported, independently, by @bugbunny-research and @tonghuaroot.

Are you affected?

Enter the version of the package you're using.

Affected packages

Go / github.com/crossplane/crossplane/v2
Introduced in: 2.3.0-rc.0

No fixed version published yet for github.com/crossplane/crossplane/v2 (go modules). Pin to a known-safe version or switch to an alternative.

Go / github.com/crossplane/crossplane/v2
Introduced in: 0

No fixed version published yet for github.com/crossplane/crossplane/v2 (go modules). Pin to a known-safe version or switch to an alternative.

Go / github.com/crossplane/crossplane
Introduced in: 0

No fixed version published yet for github.com/crossplane/crossplane (go modules). Pin to a known-safe version or switch to an alternative.

References