The go command may execute arbitrary code at build time...
Critical severity
Unreviewed
Published
Jun 8, 2023
to the GitHub Advisory Database
•
Updated Dec 6, 2024
Description
Published by the National Vulnerability Database
Jun 8, 2023
Published to the GitHub Advisory Database
Jun 8, 2023
Last updated
Dec 6, 2024
The go command may execute arbitrary code at build time when using cgo. This may occur when running "go get" on a malicious module, or when running any other command which builds untrusted code. This is can by triggered by linker flags, specified via a "#cgo LDFLAGS" directive. Flags containing embedded spaces are mishandled, allowing disallowed flags to be smuggled through the LDFLAGS sanitization by including them in the argument of another flag. This only affects usage of the gccgo compiler.
References