Skip to content

NuGet Client Remote Code Execution Vulnerability

High severity GitHub Reviewed Published Jun 13, 2023 in NuGet/NuGet.Client • Updated Jun 3, 2024

Package

nuget Microsoft.Build.NuGetSdkResolver (NuGet)

Affected versions

= 5.9.0-rc.7122
= 5.10.0-rc.7240
= 5.11.0-rc.10

Patched versions

None
nuget NuGet.CommandLine (NuGet)
>= 6.2.0, < 6.2.4
>= 6.3.0, < 6.3.3
>= 6.4.0, < 6.4.2
= 6.5.0
= 6.6.0
>= 6.0.0, < 6.0.5
>= 4.6.0, < 5.11.5
6.2.4
6.3.3
6.4.2
6.5.1
6.6.1
6.0.5
5.11.5
nuget NuGet.Commands (NuGet)
>= 6.2.0, < 6.2.4
>= 6.3.0, < 6.3.3
>= 6.4.0, < 6.4.2
= 6.5.0
= 6.6.0
>= 6.0.0, < 6.0.5
>= 4.6.0, < 5.11.5
6.2.4
6.3.3
6.4.2
6.5.1
6.6.1
6.0.5
5.11.5
nuget NuGet.Common (NuGet)
>= 6.2.0, < 6.2.4
>= 6.3.0, < 6.3.3
>= 6.4.0, < 6.4.2
= 6.5.0
= 6.6.0
>= 6.0.0, < 6.0.5
>= 4.6.0, < 5.11.5
6.2.4
6.3.3
6.4.2
6.5.1
6.6.1
6.0.5
5.11.5
nuget NuGet.PackageManagement (NuGet)
>= 6.2.0, < 6.2.4
>= 6.3.0, < 6.3.3
>= 6.4.0, < 6.4.2
= 6.5.0
= 6.6.0
>= 6.0.0, < 6.0.5
>= 4.6.0, < 5.11.5
6.2.4
6.3.3
6.4.2
6.5.1
6.6.1
6.0.5
5.11.5
nuget NuGet.Protocol (NuGet)
>= 6.2.0, < 6.2.4
>= 6.3.0, < 6.3.3
>= 6.4.0, < 6.4.2
= 6.5.0
= 6.6.0
>= 6.0.0, < 6.0.5
>= 4.7.0, < 5.11.5
6.2.4
6.3.3
6.4.2
6.5.1
6.6.1
6.0.5
5.11.5

Description

Description

Microsoft is releasing this security advisory to provide information about a vulnerability in .NET and NuGet on Linux. This advisory also provides guidance on what developers can do to update their applications to remove this vulnerability.

A vulnerability exists in .NET 6.0, .NET 7.0 and NuGet(nuget.exe, NuGet.Protocol, NuGet.Common, NuGet.CommandLine, NuGet.Commands, Microsoft.Build.NuGetSdkResolver, NuGet.PackageManagement) where a potential race condition that can lead to a symlink attack on Linux. Non-Linux platforms are not affected.

Affected software

This issue only affects Linux systems.

NuGet & NuGet Packages

  • Any NuGet.exe, NuGet.Protocol, NuGet.Common, NuGet.CommandLine, NuGet.Commands, Microsoft.Build.NuGetSdkResolver, NuGet.PackageManagement 6.6.0 version or earlier.
  • Any NuGet.exe, NuGet.Protocol, NuGet.Common, NuGet.CommandLine, NuGet.Commands, Microsoft.Build.NuGetSdkResolver, NuGet.PackageManagement 6.5.0 version or earlier.
  • Any NuGet.exe, NuGet.Protocol, NuGet.Common, NuGet.CommandLine, NuGet.Commands, Microsoft.Build.NuGetSdkResolver, NuGet.PackageManagement 6.4.1 version or earlier.
  • Any NuGet.exe, NuGet.Protocol, NuGet.Common, NuGet.CommandLine, NuGet.Commands, Microsoft.Build.NuGetSdkResolver, NuGet.PackageManagement 6.3.2 version or earlier.
  • Any NuGet.exe, NuGet.Protocol, NuGet.Common, NuGet.CommandLine, NuGet.Commands, Microsoft.Build.NuGetSdkResolver, NuGet.PackageManagement 6.2.3 version or earlier.
  • Any NuGet.exe, NuGet.Protocol, NuGet.Common, NuGet.CommandLine, NuGet.Commands, Microsoft.Build.NuGetSdkResolver, NuGet.PackageManagement 6.0.4 version or earlier.
  • Any NuGet.exe, NuGet.Protocol, NuGet.Common, NuGet.CommandLine, NuGet.Commands, Microsoft.Build.NuGetSdkResolver, NuGet.PackageManagement 5.11.4

.NET SDK(s)

  • Any .NET SDK 7.0.106 or earlier, or 7.0.303 or earlier
  • Any .NET SDK 6.0.117 or earlier, or 6.0.312 or earlier, or 6.0.409 or earlier.

Patches

To fix the issue, please install the latest version of .NET 6.0 or .NET 7.0 and NuGet (NuGet.exe, NuGet.Protocol, NuGet.Common, NuGet.CommandLine, NuGet.Commands, NuGet.PackageManagement versions). If you have installed one or more .NET SDKs through Visual Studio, Visual Studio will prompt you to update Visual Studio, which will also update your .NET SDKs.

Other details

Announcement for this issue can be found at NuGet/Announcements#69

MSRC details for this can be found at https://msrc.microsoft.com/update-guide/vulnerability/CVE-2023-29337

References

@heng-liu heng-liu published to NuGet/NuGet.Client Jun 13, 2023
Published by the National Vulnerability Database Jun 14, 2023
Published to the GitHub Advisory Database Jun 14, 2023
Reviewed Jun 14, 2023
Last updated Jun 3, 2024

Severity

High

CVSS overall score

This score calculates overall vulnerability severity from 0 to 10 and is based on the Common Vulnerability Scoring System (CVSS).
/ 10

CVSS v3 base metrics

Attack vector
Network
Attack complexity
High
Privileges required
Low
User interaction
Required
Scope
Unchanged
Confidentiality
High
Integrity
High
Availability
High

CVSS v3 base metrics

Attack vector: More severe the more the remote (logically and physically) an attacker can be in order to exploit the vulnerability.
Attack complexity: More severe for the least complex attacks.
Privileges required: More severe if no privileges are required.
User interaction: More severe when no user interaction is required.
Scope: More severe when a scope change occurs, e.g. one vulnerable component impacts resources in components beyond its security scope.
Confidentiality: More severe when loss of data confidentiality is highest, measuring the level of data access available to an unauthorized user.
Integrity: More severe when loss of data integrity is the highest, measuring the consequence of data modification possible by an unauthorized user.
Availability: More severe when the loss of impacted component availability is highest.
CVSS:3.1/AV:N/AC:H/PR:L/UI:R/S:U/C:H/I:H/A:H

EPSS score

1.142%
(85th percentile)

Weaknesses

CVE ID

CVE-2023-29337

GHSA ID

GHSA-6qmf-mmc7-6c2p

Source code

Loading Checking history
See something to contribute? Suggest improvements for this vulnerability.