Internet Explorer is no longer supported. Many things will still work, but your experience will be degraded and some things won't function. Please use a modern browser such as Edge, Chrome, or Firefox.

HOWTO: Create and Upload Nuget Packages to a Private Repository in ProGet

view on GitHub

ProGet let's you set up private NuGet repositories that will allow you to publish, store and share your internal NuGet packages within your organization.

This guide will walk you through the process of setting up a NuGet "Feed" in ProGet as a private, custom repository. We'll also cover how to create, push, and install NuGet packages from this repository.

Step 1: Create and Name a NuGet Feed

Start by creating a NuGet feed to host your internal packages. Navigate to "Feeds" and "Create New Feed". Then select "NuGet (.NET) Packages".

Now select "No Connectors (Private packages only)" as this feed will be intended to host private packages.

From here, we name our feed. For this example, we will call it internal-nuget, and then click "Create Feed".

You'll then see several options related to ProGet's Vulnerability Scanning and Blocking features. These are only for users looking to use third-party OSS packages. Leave these boxes unchecked, and select "Set Feed Features". You will then be directed to the new internal-proget feed, currently empty.

Step 2: Create a NuGet Package

If you are using Visual Studio, you can create a NuGet package by following these steps:

  1. Create a class library project in Visual Studio by selecting the Class Library template, choosing a suitable framework, then building the project to ensure it's set up correctly.
  2. Configure the NuGet package properties by accessing project settings, ensuring the Package ID is unique and other details are filled out.
  3. Use the Pack command in Release configuration to generate a .nupkg file, checking the Output window for its location

For more detail you can read Microsoft's Official Documentation.

In this guide we will cover creating a project in dotnet as it is easier to demonstrate, and also lets us cover the individual files that make up a NuGet package. To start, create the project in dotnet CLI by entering:

$ dotnet new classlib -n MyPackage 
$ cd MyPackage 

In the project folder, create a .nuspec file, that will contain the package metadata. For example:

<?xml version="1.0"?> 
<package > 
  <metadata> 
    <id>MyPackage</id> 
    <version>1.0.0</version> 
    <authors>Your Name</authors> 
    <owners>Your Organization</owners> 
    <description>A simple example NuGet package.</description> 
    <language>en-US</language> 
    <tags>example</tags> 
  </metadata> 
</package> 

Then run the following to create the package:

$ dotnet pack --configuration Release 

Step 3: Adding the Feed to NuGet CLI

To add your internal-nuget feed to either Visual Studio or NuGet CLI, you will need the feed URL. This is found on the top right of the feed page:

Using Visual Studio

To add your feed as a Package Manager in Visual Studio, navigate to "Tools" > "NuGet Package Manager" > "Package Manager Settings". Then uncheck the box to the left of nuget.org

visualstudio-packagesources-highlightednugetorg.png

This prevents Visual Studio from scanning both NuGet.org and ProGet for packages. If you configure Visual Studio to search only ProGet instead of NuGet.org and ProGet, you avoid problems such as bad licenses, vulnerable packages, and dependency confusion in your packages when you use multiple sources.

Now you will need to create a new package source. Click the green + in the top right of the window, and then name the new package source. Then paste in your internal-nuget feed URL.

visualstudio-packagesources-configureproget.png

Now, click the "Update" button, followed by the "OK" button.

visualstudio-packagesources-updateandok.png

Visual Studio and ProGet are now connected.

To confirm the connection in Visual Studio, right-click on a project in the Solution Explorer and select “Manage NuGet Packages…” from the menu. In the Package Manager window under "Browse", your should see a window populated with packages from the internal-nuget feed.

visualstudio-connectedprogetfeed.png

Using NuGet CLI

Then add the feed as a source to your NuGet client by entering:

$ dotnet nuget add source https://«proget-server»/nuget/internal-nuget/v3/index.json --name internal-nuget

Using Other NuGet Clients

ProGet can be added as a source in a number of other popular clients, including VS Code and JetBrains Rider.

In VS Code

To add your internal-nuget feed as a source, add it to a nuget.config in your project. The config could look like this:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <packageSources>
    <add key="internal-nuget" value="https://«proget-server»/nuget/internal-nuget/v3/index.json" />
  </packageSources>
</configuration>

In JetBrains Rider

To add your internal-nuget feed as a source, open "NuGet Settings" by navigating to "File" > "Settings", and then "Build, Execution, Deployment" > "NuGet". Next, under the "Package Sources" tab, click on the + (Add) button to create a new package source.

In the Name field, enter a name for your source (e.g., internal-nuget), and then in the URL field, enter the URL of your internal-nuget feed.

Step 4: Setting Up Authentication to Your NuGet Feed.

To push packages to a feed you will need to configure authentication using a "NuGet API Key". While you can authenticate with a "psedo key" («username»:«password»), we strongly recommend using an API Key for this, with api as the username, and then API Key as the password. To learn more about creating one, read Authenticating to NuGet Feeds.

Step 5: Pushing Your Package to Your NuGet Feed

You can push your NuGet package to your NuGet feed in either Visual Studio or NuGet CLI. First make sure you have added the feed as a source with authentication.

Pushing a Package in Visual Studio

To push your NuGet package using Visual Studio, open the Package Manager Console by navigating to "Tools" > "NuGet Package Manager" > "Package Manager Console". Then. run the following Push command:

$ nuget push «path-to-package» -Source «source-name» -ApiKey api:«apikey»

Example:

Pushing the package MyPackage to a configured source named internal-nuget, you would enter:

$ nuget push bin\Release\MyPackage.1.0.0.nupkg -Source internal-nuget -ApiKey api:abc12345

Pushing a Package with NuGet CLI

To push a NuGet package to ProGet in NuGet CLI, use the dotnet nuget push command:

$ dotnet nuget push «package-name» -Source «source-name»

Examples:

Pushing the package MyPackage to a configured source named internal-nuget, you would enter:

$ dotnet nuget push bin/Release/MyPackage.1.0.0.nupkg -Source internal-nuget

Your package will then be uploaded and appear in your NuGet feed.

(Optional) Repackaging NuGet Packages in CI/CD

After publishing your NuGet packages, you might want to improve your CI/CD workflow by repackaging pre-release versions into production-ready packages. This step allows you to create stable versions while maintaining an audit trail of the original pre-release versions, including details on who performed the operation and when. To learn more about repackaging your NuGet packages you can read Repackaging NuGet Packages