GO-2022-0177

Source
https://pkg.go.dev/vuln/GO-2022-0177
Import Source
https://vuln.go.dev/ID/GO-2022-0177.json
Aliases
Published
2022-08-09T17:31:35Z
Modified
2023-11-08T03:58:56.161348Z
Summary
Remote command execution via "go get" in cmd/go
Details

The "go get" command allows remote command execution.

Using custom domains, it is possible to arrange things so that example.com/pkg1 points to a Subversion repository but example.com/pkg1/pkg2 points to a Git repository. If the Subversion repository includes a Git checkout in its pkg2 directory and some other work is done to ensure the proper ordering of operations, "go get" can be tricked into reusing this Git checkout for the fetch of code from pkg2. If the Subversion repository's Git checkout has malicious commands in .git/hooks/, they will execute on the system running "go get".

References

Affected packages

Go / toolchain

Package

Name
toolchain

Affected ranges

Type
SEMVER
Events
Introduced
0The exact introduced commit is unknown
Fixed
1.8.4
Introduced
1.9.0-0
Fixed
1.9.1

Ecosystem specific

{
    "imports": [
        {
            "path": "cmd/go"
        }
    ]
}