2.2 KiB
title | description |
---|---|
Nuget (.NET) | Nuget (.NET) dependencies support in Renovate |
Nuget
Renovate supports upgrading dependencies in .csproj
, .fsproj
, and .vbproj
files.
Version Support
Only SDK-style .csproj
/.fsproj
/.vbproj
files are currently supported. By default, this includes:
- .NET Core 1.0 and above
- .NET Standard class libraries
- Any
.csproj
/.fsproj
/.vbproj
in the SDK-style syntax
To convert your .NET Framework .csproj
/.fsproj
/.vbproj
into an SDK-style project, one can follow the following guide.
How It Works
- Renovate will search each repository for any files with a
.csproj
,.fsproj
, or.vbproj
extension. - Existing dependencies will be extracted from
<PackageReference>
tags - Renovate will look up the latest version on nuget.org (or on alternate feeds) to determine if any upgrades are available
- If the source package includes a GitHub URL as its source, and has either a "changelog" file or uses GitHub releases, then Release Notes for each version will be embedded in the generated PR.
Alternate feeds
Renovate by default performs all lookups on https://api.nuget.org/v3/index.json
, but it also supports alternative nuget feeds. Alternative feeds can be specified in configuration file:
"nuget": {
"registryUrls": [
"https://api.nuget.org/v3/index.json",
"http://example1.com/nuget/"
"http://example2.com/nuget/v3/index.json"
]
}
If this example we defined 3 nuget feeds. Packages resolving will process feeds consequentially. It means that if package will be resolved in second feed renovate won't look in last one.
Authenticated feeds
Credentials for authenticated/private feeds can be provided via host rules in the configuration options (file or command line parameter).
"hostRules": [
{
"hostType": "nuget",
"endpoint": "http://example1.com/nuget",
"username": "root",
"password": "p4$$w0rd"
}
]
Please note that at the moment only Basic HTTP authentication (via username and password) is supported.
Future work
Contributions and/or feature requests are welcome to support more patterns or additional use cases.