PT-2018-2521 · Google+3 · Go+3

Christopher Brown

·

Published

2018-02-07

·

Updated

2025-09-29

·

CVE-2018-6574

CVSS v3.1

7.8

High

VectorAV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H
Name of the Vulnerable Software and Affected Versions Go versions prior to 1.8.7 Go 1.9.x versions prior to 1.9.4 Go 1.10 pre-releases prior to Go 1.10rc2
Description The issue is related to the "go get" command in the Go programming language, which allows remote command execution during source code build. This is possible due to the lack of blocking of the -fplugin= and -plugin= arguments when using the gcc or clang plugin feature. The exploitation of this issue can enable a remote attacker to execute the "go get" command. When cgo is enabled, the build step invokes the host C compiler, adding compiler flags specified in the Go source files. Both gcc and clang support a plugin mechanism, allowing a shared-library plugin to be loaded into the compiler. A Go package repository can contain a malicious plugin file, which can be loaded into the host C compiler during the build, potentially granting unrestricted access to the host system.
Recommendations For Go versions prior to 1.8.7, update to version 1.8.7 or later. For Go 1.9.x versions prior to 1.9.4, update to version 1.9.4 or later. For Go 1.10 pre-releases prior to Go 1.10rc2, update to Go 1.10rc2 or later. As a temporary workaround, consider disabling the cgo feature until a patch is available. Restrict access to the gcc and clang plugins to minimize the risk of exploitation.

Exploit

Fix

Improper Access Control

Code Injection

Found an issue in the description? Have something to add? Feel free to write us 👾

Weakness Enumeration

Related Identifiers

ALSA-2025_16880
ALT-PU-2018-1655
BDU:2019-00903
CESA-2018_0878
CVE-2018-6574
DSA-4380-1
GO-2022-0201
MGASA-2018-0144
OPENSUSE-SU-2018:0588-1
OPENSUSE-SU-2018:0589-1
OPENSUSE-SU-2018:0628-1
OPENSUSE-SU-2018:0629-1
OPENSUSE-SU-2024:10802-1
OPENSUSE-SU-2024:10803-1
OPENSUSE-SU-2024:10804-1
OPENSUSE-SU-2024:10805-1
OPENSUSE-SU-2024:10812-1
RHSA-2018:0878
RHSA-2018:1304
RHSA-2018_0878

Affected Products

Alt Linux
Centos
Go
Red Hat