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/[email protected]
# - name: Setup dotnet
# uses: actions/setup-dotnet@v1
# with:
# dotnet-version: 3.1.200
# Publish
- name: publish on version change
id: publish_nuget
uses: Elskom/publish-nuget@main
with:
# Filepath of the project to be packaged, relative to root of repository
PROJECT_FILE_PATH: '**/*.csproj'
# Path to store all generated nuget packages, relative to root of repository
PACKAGE_PATH: artifacts/
# 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: ^\s*<Version>(.*)<\/Version>\s*$
# 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, or a token, issued for GITHUB_USER if you use GPR
# NUGET_KEY: ${{secrets.NUGET_API_KEY}}
# NuGet server uri hosting the packages, defaults to https://api.nuget.org
# NUGET_SOURCE: https://api.nuget.org
# Flag to throw an error when trying to publish an existing version of a package
# THOW_ERROR_IF_VERSION_EXISTS: false
- 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 or a glob of projects in the form of **/*.csproj, relative to root of repository | |
PACKAGE_PATH | Path to store all generated nuget packages, 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 | ^\s*<Version>(.*)<\/Version>\s*$ |
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 |
GITHUB_USER | [GITHUB_ACTOR] |
Required for packages pushed to Github Package Registry. User allowed to push to repository, defaults to GITHUB_ACTOR (user that triggered the action) |
NUGET_KEY | API key to authenticate with NuGet server, or a token, issued for GITHUB_USER if you use GPR | |
NUGET_SOURCE | https://api.nuget.org |
NuGet server uri hosting the packages, defaults to https://api.nuget.org |
THOW_ERROR_IF_VERSION_EXISTS | false |
Flag to throw an error when trying to publish an existing version of a package |
Output | Description |
---|---|
VERSION | Version of the associated git tag |
FYI:
- Outputs may or may not be set depending on the action inputs or if the action failed
NUGET_SOURCE
must support/v3-flatcontainer/PACKAGE_NAME/index.json
for version change detection to work when not using GPR- Multiple projects can use file globbing to package each of them up and push them.