Skip to content

Latest commit

 

History

History
30 lines (17 loc) · 1.32 KB

README.md

File metadata and controls

30 lines (17 loc) · 1.32 KB

About

If you need to find a transitive nuget dependency in a .net project by name and version you can use this approach.

If you are using DependencyTrack or a similar tool to find nugets with critical CVE in a .net C# application, there is no automatic way (in VS or nuget) to track down the inclusion path of the nuget introducing the vulnerability.

After several hours of internet research without success I decided to write this. A powershell script + the same implementation in python as platform agnostic approach.

Prerequisite

How does it work

It calls nuget-deps-tree stores the resulting dependency tree. Then it tries to find the given nuget in the tree. To do so it traverses the dependencies and logs the path to shell, when the desired nuget was found.

Runit

  • (There must be a dotnet build or at least a dotnet restore to update the local nuget caches)

powershell

  • Don't forget to unblock the nailDownNuget.ps1
  • Run it in powershell nailDownNuget.ps1 [path to sln] [name of the nuget] [version of the nuget]

python

  • py .\nailDownNuget.py [path to sln], [name of the nuget], [version of the nuget]