GHSA-32gq-x56h-299c

Suggest an improvement
Source
https://github.com/advisories/GHSA-32gq-x56h-299c
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2024/12/GHSA-32gq-x56h-299c/GHSA-32gq-x56h-299c.json
JSON Data
https://api.test.osv.dev/v1/vulns/GHSA-32gq-x56h-299c
Aliases
Related
Published
2024-12-18T18:23:06Z
Modified
2024-12-20T21:41:09Z
Summary
age vulnerable to malicious plugin names, recipients, or identities causing arbitrary binary execution
Details

A plugin name containing a path separator may allow an attacker to execute an arbitrary binary.

Such a plugin name can be provided to the age CLI through an attacker-controlled recipient or identity string, or to the plugin.NewIdentity, plugin.NewIdentityWithoutData, or plugin.NewRecipient APIs.

On UNIX systems, a directory matching ${TMPDIR:-/tmp}/age-plugin-* needs to exist for the attack to succeed.

The binary is executed with a single flag, either --age-plugin=recipient-v1 or --age-plugin=identity-v1. The standard input includes the recipient or identity string, and the random file key (if encrypting) or the header of the file (if decrypting). The format is constrained by the age-plugin protocol.

An equivalent issue was fixed by the rage project, see advisory GHSA-4fg7-vxc8-qx5w.

Thanks to ⬡-49016 for reporting this.

Database specific
{
    "nvd_published_at": null,
    "cwe_ids": [
        "CWE-25"
    ],
    "severity": "MODERATE",
    "github_reviewed": true,
    "github_reviewed_at": "2024-12-18T18:23:06Z"
}
References

Affected packages

Go / filippo.io/age

Package

Name
filippo.io/age
View open source insights on deps.dev
Purl
pkg:golang/filippo.io/age

Affected ranges

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