Edit

Share via


Use packages from the NuGet Gallery

Azure DevOps Services | Azure DevOps Server | Azure DevOps Server 2022 | Azure DevOps Server 2020

Azure Artifacts upstream sources make it easy for developers to pull packages from public registries like nuget.org and npmjs.com. In this article, you learn how to set up your project and use the command line to consume NuGet packages from the NuGet Gallery.

Prerequisites

Product Requirements
Azure DevOps - An Azure DevOps organization.
- An Azure DevOps project.
- An Azure Artifacts feed.
- Download and install the Azure Artifacts Credential Provider.
- Install the latest NuGet version.

Create a feed and enable upstream sources

If you haven't created a feed yet, follow the steps below to create a new feed and enable upstream sources. If you already have a feed, proceed to the next step to add the NuGet Gallery as an upstream source.

  1. Sign in to your Azure DevOps organization and navigate to your project.

  2. Select Artifacts, and then select Create Feed.

  3. Provide a Name for your feed, select the Visibility option to define who can view your packages, and choose your Scope. Azure Artifacts recommends scoping feeds to a project rather than the entire organization.

  4. Make sure to check the Include packages from common public sources option, as you'll need this to consume packages from public registries such as nuget.org, npmjs.com etc.

  5. Select Create when you're done.

    A screenshot displaying how to create a new feed and enable upstream sources in Azure Artifacts.

If you checked the Upstream sources checkbox when creating your feed (as shown in the previous section), the NuGet Gallery should have been added automatically to your feed’s upstream sources. If you're working with a different feed or forgot to check that option, you can manually add the NuGet Gallery by following these steps:

  1. Sign in to Azure DevOps, and then navigate to your project.

  2. Select Artifacts, and then select your feed from the dropdown menu.

  3. Select the gear icon button gear icon to navigate to your Feed settings.

  1. Select Upstream Sources, and then select Add Upstream.

  2. Select Public source, select NuGet Gallery from the dropdown menu, and then select Add.

  3. Select Save at the top right corner, then select Save again to confirm and apply your changes.

  1. Select Upstream Sources, and then select Add upstream source.

  2. Select Public source, and then select NuGet Gallery from the dropdown menu.

  3. Select Add when you're done.

Connect to your feed

In this section, you learn how to set up your project to authenticate with your Azure Artifacts feed and save packages from upstream sources such as the NuGet Gallery.

  1. Sign in to your Azure DevOps organization, and then navigate to your project.

  2. Select Artifacts, and then select your feed from the dropdown menu.

  3. Select Connect to feed, and then select NuGet.exe.

  4. Make sure you've installed the prerequisites, then add a nuget.config file in the same folder as your .csproj or .sln file.

  5. Paste the XML snippet provided in the Project setup section into your file. Your file should resemble the following:

    • Project-scoped feed:

      <?xml version="1.0" encoding="utf-8"?>
      <configuration>
        <packageSources>
          <clear />
          <add key="<SOURCE_NAME>" value="https://pkgs.dev.azure.com/<ORGANIZATION_NAME>/<PROJECT_NAME>/_packaging/<FEED_NAME>/nuget/v3/index.json" />
        </packageSources>
      </configuration>
      
    • Organization-scoped feed:

      <?xml version="1.0" encoding="utf-8"?>
      <configuration>
        <packageSources>
          <clear />
          <add key="<SOURCE_NAME>" value="https://pkgs.dev.azure.com/<ORGANIZATION_NAME>/_packaging/<FEED_NAME>/nuget/v3/index.json" />
        </packageSources>
      </configuration>
      
  1. Sign in to your Azure DevOps collection, and then navigate to your project.

  2. Select Artifacts, and then select your feed from the dropdown menu.

  3. Select Connect to Feed, and then select NuGet.exe from the left navigation pane.

  4. Follow the instructions in the Project setup section to connect to your feed.

Now that your project is configured to authenticate with your Azure Artifacts feed, you can proceed to install packages from the NuGet Gallery upstream. In this example, you'll install the MCP C# SDK for the Model Context Protocol for .NET applications to interact with MCP clients and servers:

  1. Navigate to the NuGet Gallery at https://www.nuget.org/.

  2. Search for the ModelContextProtocol, then select it to open the details page.

  3. Select the .NET CLI tab, and copy the command. In this example, the command is:

    dotnet add package ModelContextProtocol --version 0.3.0-preview.4
    
  4. Open a command prompt window, navigate to your project directory, then paste your command and press Enter to install the package.

Once installed, a copy of the package will be automatically saved to your feed, ensuring availability if NuGet Gallery is down and protecting your workflow from other corrupted or malicious packages from the public registry.

Note

To save packages from upstreams, you must have the Feed and Upstream Reader (Collaborator) role or higher. See Feed roles and permissions for more details.

View saved packages

  1. Sign in to Azure DevOps, and navigate to your project.

  2. Select Artifacts, then select your feed from the dropdown menu.

  3. Select the NuGet Gallery source from the dropdown menu to filter for packages from this upstream.

  4. The ModelContextProtocol packages, installed in the previous step, is now available in our feed. Azure Artifacts automatically saved a copy to your feed.

    A screenshot displaying the MCP package saved to the feed.