WGet.NET 2.0.2

There is a newer version of this package available.
See the version list below for details.
dotnet add package WGet.NET --version 2.0.2                
NuGet\Install-Package WGet.NET -Version 2.0.2                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="WGet.NET" Version="2.0.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add WGet.NET --version 2.0.2                
#r "nuget: WGet.NET, 2.0.2"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install WGet.NET as a Cake Addin
#addin nuget:?package=WGet.NET&version=2.0.2

// Install WGet.NET as a Cake Tool
#tool nuget:?package=WGet.NET&version=2.0.2                

WGet.NET

Version NuGet

Main Develop
CodeQL_main CodeQL_develop

❓ What is WGet.NET

WGet.NET is a WinGet wrapper library for .Net.

I created it for another project and then made a library out of it in hope it might be usefull to someone else too.
If you tried this library, please give me some feedback. And if you miss a feature, you can create an issue to let me know.

🎈 Version 2.0

Version 2.0 is out now, with big changes, improvements and new features.
But before updating to the new version, read the changelog first, because version 2.0 is not compatible with older versions of this library.

You can finde the changelog here: https://github.com/basicx-StrgV/WGet.NET/releases/tag/2.0.0

⚑ Features

  • Get a list of installed packages
  • Search packages
  • Install packages
  • Uninstall packages
  • Upgrade packages
  • Get a list of upgradeable packages
  • Export and Import packages
  • Check if WinGet is installed
  • Get the WinGet version number
  • Get installed sources
  • Add sources
  • Remove sources
  • Update sources
  • Export sources
  • Reset sources

πŸ“¦ NuGet Package

You can get the NuGet package here: https://www.nuget.org/packages/WGet.NET/

❗ Requirements

WinGet needs to be installed on the system.

If WinGet is not installed on your system you can get it here: https://github.com/microsoft/winget-cli

πŸ’‘ Getting started

The needed namespace is WGetNET (using WGetNET;).
This namespace contains the three classes, that are used to perform actions or get information with winget.

WinGetInfo:

The WinGetInfo class can be used to get information about WinGet itself.
This class is inherited by the WinGetPackageManager and WinGetSourceManager class.

USing this class to check if winget is installed could look like this:

WinGetInfo wingetInfo = new WinGetInfo();
if (wingetInfo.WinGetInstalled)
{
     Console.WriteLine("WinGet is installed.");
}
else
{
     Console.WriteLine("WinGet is NOT installed.");
}

WinGetPackageManager:

The WinGetPackageManager class is used for everything that has to do with packages.
It can install, remove, upgrade, search, list, export and import packages.

The code for installing a package could look like this:

WinGetPackageManager packageManager = new WinGetPackageManager();
packageManager.InstallPackage("Git.Git");

WinGetSourceManager:

The WinGetSourceManager class is used for everything that has to do with sources.
It can list, add, update, export, reset and remove sources.

To use the add, remove and reset functions, the process needs to have administrator privileges.
(WinGet can’t perform these actions without administrator privileges)

The code for adding a source could look like this:

WinGetSourceManager sourceManager = new WinGetSourceManager();
sourceManager.AddSource("msstore", "https://storeedgefd.dsx.mp.microsoft.com/v9.0", "Microsoft.Rest");
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
.NET Core netcoreapp3.1 is compatible. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories (2)

Showing the top 2 popular GitHub repositories that depend on WGet.NET:

Repository Stars
nkdAgility/azure-devops-migration-tools
Azure DevOps Migration Tools allow you to migrate Teams, Backlogs, Work Items, Tasks, Test Cases, and Plans & Suits from one Project to another in Azure DevOps / TFS both within the same Organisation, and between Organisations.
yoshiask/FluentStore
A unifying frontend for Windows app stores and package managers