Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Azure DevOps Services | Azure DevOps Server | Azure DevOps Server 2022 | Azure DevOps Server 2020
Azure Artifacts enables developers to manage their dependencies from a single feed. A feed acts as an organizational space to host various types of packages, giving you control over who can access it, whether it's team members within your organization or even public users.
When creating a new feed in Azure Artifacts, you can choose to scope it to either a project or your organization, depending on your scenario. However, Azure Artifacts recommends scoping new feeds to a project. In this article, you'll learn about the key differences between the two types of feeds.
Create a feed
- Sign in to your Azure DevOps organization and navigate to your project. 
- Select Artifacts, and then select Create Feed. 
- Provide a Name for your feed, choose its Visibility to specify who can view your packages, and check the Include packages from common public sources checkbox if you want to include packages from public sources such as nuget.org. 
- Under Scope, select Project to create a project-scoped feed, or Organization if you want an organization-scoped feed. 
- Select Create when you're done.   
Note
Organization-scoped feeds cannot be converted to project-scoped feeds.
Project-scoped vs organization-scoped feeds
A project-scoped feed is scoped to a project instead of an organization. Here are the main differences between the two types of feeds:
| Category | Project-Scoped Feed | Organization-Scoped Feed | 
|---|---|---|
| Visibility | Inherits the visibility of the project. | Always private by default. | 
| Links | The URL includes the project name. Example: https://pkgs.dev.azure.com/<ORG_NAME>/<PROJECT_NAME>/_packaging/<FEED_NAME>/nuget/v3/index.json | The URL does not include a project. Example: https://pkgs.dev.azure.com/<ORG_NAME>/_packaging/<FEED_NAME>/nuget/v3/index.json | 
| User Interface | Visible only after navigating to the project that hosts the feed. | Always available from the feeds dropdown menu. | 
| Connection | To access a feed from a pipeline running in a different project within the same organization, both the Project Collection Build Service and the project's Build Service of the project running the pipeline must be granted the appropriate role. | Only the Project Collection Build Service needs to be granted the appropriate role. | 
Note
To add a feed from a different organization as an upstream source, the target feed owner must share the target view with All feeds and people in organizations associated with my Microsoft Entra tenant by navigating to Feed Settings > Views > selecting the ellipsis button on the right for the specified view > then selecting Edit.
Tip
If you want to add an extra layer of security to your project-scoped feed and protect your feed's visibility, you can disable the Allow public projects policy from the Organization Policy Settings.
Q&A
Q: How can I share packages with all users in my organization?
A: To make specific packages in your feed accessible to all users in your organization, create or select a view that contains the packages you want to share and set its visibility to People in my organization.
Important
If a user has access to a specific view, they will still be able to view and download packages from that view even without feed-level permissions. If you want to fully restrict access to your packages, ensure permissions are limited for both the feed and its views. See Feeds and views permissions for more details.
Q: How can I access a project-scoped feed in another project from my pipeline?
To allow a pipeline to access a project-scoped feed in a different project, you need to grant access both at the project level (where the feed is hosted) and the feed level.
- Project permissions: Navigate to the project hosting the feed, select Project settings > Permissions and then add your pipeline's project build service to the Readers group. 
- Feed permissions: Navigate to the feed you want to access, select Settings > Feed permissions, and then add your project build service with one of the following roles: - Feed and Upstream Reader (Collaborator): If you want to view or download packages from the feed, or save packages from upstream sources.
- Feed Publisher (Contributor): If you want to publish, promote, or deprecate packages, in addition to viewing or downloading packages from the feed, or save packages from upstream sources.
 
The Project build service identity is formatted as: [Project name] Build Service ([Organization name]). Example: FabrikamFiber Build Service (codesharing-demo).
Q: How can I download a pipeline artifact from another project within the same organization?
A: If your pipeline is failing to download an artifact from another project, ensure the following permissions are set for both the downstream project and the pipeline generating the artifact:
- On the pipeline generating the artifact (upstream project): select the ellipsis for more options > Manage security > search for your downstream project's build service, then allow the following permissions: Update build information, View build pipeline, and View builds. 
- On the downstream project: navigate to Project Settings > Permissions > Users > search for your upstream project's name, then select Expand search > select your upstream project's build service and enable View project-level information. 
Q: If I enable upstream sources in a new feed and set its visibility to 'Members of your Microsoft Entra tenant,' do I still need to add Microsoft Entra users to the Azure DevOps Organization that contains the feed?
A: Yes, adding users to the Azure DevOps organization is still required for them to access the packages in the feed. You can add them as Project Collection Valid Users from Organization Settings > Security > Permissions.