Publish NuGet
ActionsBuild, Pack Publish a NuGet package with dotnet core on project version change
v2.4.0
Tags
(2)GitHub action to build, pack & publish nuget packages automatically when a project version is updated
Create new .github/workflows/publish.yml
file:
name: publish to nuget
on:
push:
branches:
- master # Default release branch
jobs:
publish:
name: build, pack & publish
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
# - name: Setup dotnet
# uses: actions/setup-dotnet@v1
# with:
# dotnet-version: 3.1.200
# Publish
- name: publish on version change
id: publish_nuget
uses: rohith/publish-nuget@v2
with:
# Filepath of the project to be packaged, relative to root of repository
PROJECT_FILE_PATH: Core/Core.csproj
# NuGet package id, used for version detection & defaults to project name
# PACKAGE_NAME: Core
# Filepath with version info, relative to root of repository & defaults to PROJECT_FILE_PATH
# VERSION_FILE_PATH: Directory.Build.props
# Regex pattern to extract version info in a capturing group
# VERSION_REGEX: <Version>(.*)<\/Version>
# Useful with external providers like Nerdbank.GitVersioning, ignores VERSION_FILE_PATH & VERSION_REGEX
# VERSION_STATIC: 1.0.0
# Flag to toggle git tagging, enabled by default
# TAG_COMMIT: true
# Format of the git tag, [*] gets replaced with actual version
# TAG_FORMAT: v*
# API key to authenticate with NuGet server
# NUGET_KEY: ${{secrets.NUGET_API_KEY}}
# API key to authenticate with NuGet symbols server, defaults to NUGET_KEY
# NUGET_SYMBOL_KEY: ${{secrets.NUGET_SYMBOLS_API_KEY}}
# NuGet server uri hosting the packages, defaults to https://api.nuget.org
# NUGET_SOURCE: https://api.nuget.org
# NuGet server uri hosting the symbols, defaults to https://api.nuget.org
# NUGET_SYMBOL_SOURCE: https://api.nuget.org
# Flag to toggle pushing symbols along with nuget package to the server, enabled by default
# INCLUDE_SYMBOLS: true
- Project gets published only if there's a
NUGET_KEY
configured in the repository
Input | Default Value | Description |
---|---|---|
PROJECT_FILE_PATH | Filepath of the project to be packaged, relative to root of repository | |
PACKAGE_NAME | NuGet package id, used for version detection & defaults to project name | |
VERSION_FILE_PATH | [PROJECT_FILE_PATH] |
Filepath with version info, relative to root of repository & defaults to PROJECT_FILE_PATH |
VERSION_REGEX | <Version>(.*)<\/Version> |
Regex pattern to extract version info in a capturing group |
VERSION_STATIC | Useful with external providers like Nerdbank.GitVersioning, ignores VERSION_FILE_PATH & VERSION_REGEX | |
TAG_COMMIT | true |
Flag to toggle git tagging, enabled by default |
TAG_FORMAT | v* |
Format of the git tag, [*] gets replaced with actual version |
NUGET_KEY | API key to authenticate with NuGet server | |
NUGET_SYMBOL_KEY | [NUGET_KEY] |
API key to authenticate with NuGet symbols server, defaults to NUGET_KEY |
NUGET_SOURCE | https://api.nuget.org |
NuGet server uri hosting the packages, defaults to https://api.nuget.org |
NUGET_SYMBOL_SOURCE | https://api.nuget.org |
NuGet server uri hosting the symbols, defaults to https://api.nuget.org |
INCLUDE_SYMBOLS | true |
Flag to toggle pushing symbols along with nuget package to the server, enabled by default |
Output | Description |
---|---|
VERSION | Version of the associated git tag |
PACKAGE_NAME | Name of the NuGet package generated |
PACKAGE_PATH | Path to the generated NuGet package |
SYMBOLS_PACKAGE_NAME | Name of the symbols package generated |
SYMBOLS_PACKAGE_PATH | Path to the generated symbols package |
FYI:
- Outputs may not be set if the action failed
NUGET_SOURCE
must support/v3-flatcontainer/PACKAGE_NAME/index.json
for version change detection to work- Multiple projects can make use of steps to configure each project individually, common inputs between steps can be given as
env
for job / workflow
Publish NuGet is not certified by GitHub. It is provided by a third-party and is governed by separate terms of service, privacy policy, and support documentation.