Generate Runtime Packages From NuGet #10
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Generate Runtime Packages From NuGet | |
# Controls when the workflow will run | |
on: | |
workflow_dispatch: | |
inputs: | |
nuGetServerUrl: | |
description: NuGet server URL (leave empty to use RUNTIMENUGETSERVERURL variable) | |
required: false | |
default: '' | |
nuGetToken: | |
description: NuGet auth token (leave empty to use RUNTIMENUGETTOKEN or NUGETTOKEN secret) | |
required: false | |
default: '' | |
fromNugetServerUrl: | |
description: NuGet server URL | |
required: false | |
default: '' | |
fromNugetToken: | |
description: NuGet auth token | |
required: false | |
default: '' | |
fromApps: | |
description: Comma separated list of nuget package names | |
required: false | |
default: '' | |
fromDependencies: | |
description: Comma separated list of nuget package names | |
required: false | |
default: '' | |
country: | |
description: Country for the main runtime version (leave empty to use COUNTRY variable, default is w1) | |
required: false | |
default: '' | |
additionalCountries: | |
description: Comma separated list of additional countries (leave empty to use ADDITIONALCOUNTRIES variable, default is none) | |
required: false | |
default: '' | |
# artifactVersion: | |
# description: Business Central artifacts version range (leave empty to use ARTIFACTVERSION variable, default is to auto-calculate needed artifacts) | |
# required: false | |
# default: '' | |
# artifactType: | |
# description: Type of Business Central artifacts to use, onprem or sandbox (leave empty to use ARTIFACTTYPE variable, default is sandbox) | |
# required: false | |
# default: '' | |
licenseFileUrl: | |
description: License File URL to use for versions before 22.0 (leave empty to use LICENSEFILEURL secret) | |
required: false | |
default: '' | |
# run-name: | |
# description: Name of the run (leave empty to use the default name) | |
# required: false | |
# default: '' | |
run-name: ${{ github.event.inputs.run-name != '' && github.event.inputs.run-name || github.workflow }} | |
concurrency: | |
group: ${{ github.event.inputs.run-name != '' && github.event.inputs.run-name || github.workflow }} | |
cancel-in-progress: false | |
jobs: | |
DetermineArtifacts: | |
name: Determine Business Central Artifacts | |
runs-on: [ ubuntu-latest ] | |
permissions: | |
contents: read | |
outputs: | |
artifactVersions: ${{ steps.determineArtifacts.outputs.ArtifactVersions }} | |
artifactVersionCount: ${{ steps.determineArtifacts.outputs.ArtifactVersionCount }} | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- name: Mask input | |
shell: pwsh | |
env: | |
secrets: ${{ toJson(secrets) }} | |
run: | | |
. (Join-Path $env:GITHUB_WORKSPACE "MaskInput.ps1") | |
- name: Determine Artifacts | |
id: determineArtifacts | |
shell: pwsh | |
env: | |
nuGetToken: ${{ github.event.inputs.nuGetToken != '' && github.event.inputs.nuGetToken || (secrets.RUNTIMENUGETTOKEN != '' && secrets.RUNTIMENUGETTOKEN || secrets.NUGETTOKEN) }} | |
nuGetServerUrl: ${{ github.event.inputs.nuGetServerUrl != '' && github.event.inputs.nuGetServerUrl || vars.RUNTIMENUGETSERVERURL }} | |
fromNugetServerUrl: ${{ github.event.inputs.fromNugetServerUrl }} | |
fromNugetToken: ${{ github.event.inputs.fromNugetToken }} | |
fromApps: ${{ github.event.inputs.fromApps }} | |
apps: '' | |
country: ${{ github.event.inputs.country != '' && github.event.inputs.country || vars.COUNTRY }} | |
artifactVersion: '' | |
artifactType: ${{ github.event.inputs.artifactType != '' && github.event.inputs.artifactType || vars.ARTIFACTTYPE }} | |
run: | | |
. (Join-Path $env:GITHUB_WORKSPACE "DetermineArtifacts.ps1") | |
GenerateRuntimeNuGetPackages: | |
needs: [ DetermineArtifacts ] | |
if: needs.DetermineArtifacts.outputs.artifactVersionCount > 0 | |
runs-on: [ windows-latest ] | |
strategy: | |
matrix: | |
include: ${{ fromJson(needs.DetermineArtifacts.outputs.artifactVersions) }} | |
fail-fast: false | |
max-parallel: 12 | |
name: Runtime ${{ matrix.artifactVersion }} | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- name: Mask input | |
shell: pwsh | |
env: | |
secrets: ${{ toJson(secrets) }} | |
run: | | |
. (Join-Path $env:GITHUB_WORKSPACE "MaskInput.ps1") | |
- name: Generate Runtime NuGet Packages | |
shell: pwsh | |
env: | |
nuGetToken: ${{ github.event.inputs.nuGetToken != '' && github.event.inputs.nuGetToken || (secrets.RUNTIMENUGETTOKEN != '' && secrets.RUNTIMENUGETTOKEN || secrets.NUGETTOKEN) }} | |
nuGetServerUrl: ${{ github.event.inputs.nuGetServerUrl != '' && github.event.inputs.nuGetServerUrl || (vars.RUNTIMENUGETSERVERURL != '' && vars.RUNTIMENUGETSERVERURL || vars.NUGETSERVERURL) }} | |
fromApps: ${{ github.event.inputs.fromApps }} | |
fromNugetServerUrl: ${{ github.event.inputs.fromNugetServerUrl }} | |
fromNugetToken: ${{ github.event.inputs.fromNugetToken }} | |
apps: '' | |
fromDependencies: ${{ github.event.inputs.fromDependencies }} | |
dependencies: '' | |
country: ${{ github.event.inputs.country != '' && github.event.inputs.country || vars.COUNTRY }} | |
additionalCountries: ${{ github.event.inputs.additionalCountries != '' && github.event.inputs.additionalCountries || vars.ADDITIONALCOUNTRIES }} | |
artifactType: ${{ github.event.inputs.artifactType != '' && github.event.inputs.artifactType || vars.ARTIFACTTYPE }} | |
licenseFileUrl: ${{ github.event.inputs.licenseFileUrl != '' && github.event.inputs.licenseFileUrl || secrets.LICENSEFILEURL }} | |
artifactVersion: ${{ matrix.artifactVersion }} | |
incompatibleArtifactVersion: ${{ matrix.incompatibleArtifactVersion }} | |
run: | | |
. (Join-Path $env:GITHUB_WORKSPACE "GenerateRuntimeNuGetPackages.ps1") | |
GenerateIndirectNuGetPackage: | |
name: Generate Indirect NuGet Package | |
needs: [ DetermineArtifacts, GenerateRuntimeNuGetPackages ] | |
if: needs.DetermineArtifacts.outputs.artifactVersionCount > 0 | |
runs-on: [ ubuntu-latest ] | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- name: Mask input | |
shell: pwsh | |
env: | |
secrets: ${{ toJson(secrets) }} | |
run: | | |
. (Join-Path $env:GITHUB_WORKSPACE "MaskInput.ps1") | |
- name: Generate Indirect NuGet Package | |
shell: pwsh | |
env: | |
nuGetToken: ${{ github.event.inputs.nuGetToken != '' && github.event.inputs.nuGetToken || (secrets.RUNTIMENUGETTOKEN != '' && secrets.RUNTIMENUGETTOKEN || secrets.NUGETTOKEN) }} | |
nuGetServerUrl: ${{ github.event.inputs.nuGetServerUrl != '' && github.event.inputs.nuGetServerUrl || (vars.RUNTIMENUGETSERVERURL != '' && vars.RUNTIMENUGETSERVERURL || vars.NUGETSERVERURL) }} | |
fromNugetServerUrl: ${{ github.event.inputs.fromNugetServerUrl }} | |
fromNugetToken: ${{ github.event.inputs.fromNugetToken }} | |
fromApps: ${{ github.event.inputs.fromApps }} | |
apps: '' | |
run: | | |
. (Join-Path $env:GITHUB_WORKSPACE "GenerateIndirectPackage.ps1") |