Release #300
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: Release | |
on: | |
workflow_dispatch: | |
concurrency: Release | |
jobs: | |
set-release-version: | |
if: github.repository_owner == 'Informatievlaanderen' | |
name: Decide next version | |
runs-on: ubuntu-latest | |
outputs: | |
version: ${{ steps.set-version.outputs.version }} | |
steps: | |
- name: Checkout Code | |
uses: actions/checkout@v4 | |
with: | |
persist-credentials: false | |
- name: Setup Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: '20.x' | |
- name: Node version | |
shell: bash | |
run: node --version | |
- name: Install NPM dependencies | |
shell: bash | |
run: npm ci | |
- name: Run Semantic Release Dry-Run | |
shell: bash | |
run: npx semantic-release --dry-run | |
env: | |
BUILD_DOCKER_REGISTRY: ${{ secrets.VBR_BUILD_DOCKER_REGISTRY_TST }} | |
GITHUB_TOKEN: ${{ secrets.VBR_GIT_RELEASE_TOKEN }} | |
GIT_COMMIT: ${{ github.sha }} | |
GIT_USERNAME: ${{ secrets.VBR_GIT_USER }} | |
GIT_AUTHOR_NAME: ${{ secrets.VBR_GIT_USER }} | |
GIT_COMMITTER_NAME: ${{ secrets.VBR_GIT_USER }} | |
GIT_EMAIL: ${{ secrets.VBR_GIT_EMAIL }} | |
GIT_AUTHOR_EMAIL: ${{ secrets.VBR_GIT_EMAIL }} | |
GIT_COMMITTER_EMAIL: ${{ secrets.VBR_GIT_EMAIL }} | |
- name: Set Release Version | |
id: set-version | |
run: | | |
[ ! -f semver ] && echo none > semver | |
echo $(cat semver) | |
echo ::set-output name=version::$(cat semver) | |
echo RELEASE_VERSION=$(cat semver) >> $GITHUB_ENV | |
shell: bash | |
build-api-backoffice: | |
name: Build Api BackOffice | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/build-image.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
registry: ${{ vars.VBR_DEVOPS_DOCKER_REGISTRY }}/building-registry | |
image-file: br-api-backoffice-image.tar | |
image-name: api-backoffice | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Api.BackOffice | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
build-api-oslo: | |
name: Build Api Oslo | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/build-image.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
registry: ${{ vars.VBR_DEVOPS_DOCKER_REGISTRY }}/building-registry | |
image-file: br-api-oslo-image.tar | |
image-name: api-oslo | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Api.Oslo | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
build-api-extract: | |
name: Build Api Extract | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/build-image.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
registry: ${{ vars.VBR_DEVOPS_DOCKER_REGISTRY }}/building-registry | |
image-file: br-api-extract-image.tar | |
image-name: api-extract | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Api.Extract | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
build-projector: | |
name: Build Projector | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/build-image.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
registry: ${{ vars.VBR_DEVOPS_DOCKER_REGISTRY }}/building-registry | |
image-file: br-projector-image.tar | |
image-name: projector | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Projector | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
build-projections-last-changed-list: | |
name: Build projections last changed list | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/build-image.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
registry: ${{ vars.VBR_DEVOPS_DOCKER_REGISTRY }}/building-registry | |
image-file: br-projections-last-changed-list-console-image.tar | |
image-name: projections-last-changed-list-console | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Projections.LastChangedList.Console | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
build-projections-backoffice: | |
name: Build Projections BackOffice | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/build-image.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
registry: ${{ vars.VBR_DEVOPS_DOCKER_REGISTRY }}/building-registry | |
image-file: br-projections-backoffice-image.tar | |
image-name: projections-backoffice | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Projections.BackOffice | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
build-cache-invalidator: | |
name: Build Cache Invalidator | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/build-image.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
registry: ${{ vars.VBR_DEVOPS_DOCKER_REGISTRY }}/building-registry | |
image-file: br-cache-invalidator-image.tar | |
image-name: cache-invalidator | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Cache.Invalidator | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
build-consumer-address: | |
name: Build Consumer Address | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/build-image.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
registry: ${{ vars.VBR_DEVOPS_DOCKER_REGISTRY }}/building-registry | |
image-file: br-consumer-address-image.tar | |
image-name: consumer-address | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Consumer.Address | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
build-consumer-read-parcel: | |
name: Build Consumer Parcel | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/build-image.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
registry: ${{ vars.VBR_DEVOPS_DOCKER_REGISTRY }}/building-registry | |
image-file: br-consumer-read-parcel-image.tar | |
image-name: consumer-read-parcel | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Consumer.Read.Parcel | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
build-producer: | |
name: Build Producer | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/build-image.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
registry: ${{ vars.VBR_DEVOPS_DOCKER_REGISTRY }}/building-registry | |
image-file: br-producer-image.tar | |
image-name: producer | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Producer | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
build-producer-snapshot-oslo: | |
name: Build Producer Snapshot Oslo | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/build-image.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
registry: ${{ vars.VBR_DEVOPS_DOCKER_REGISTRY }}/building-registry | |
image-file: br-producer-snapshot-oslo-image.tar | |
image-name: producer-snapshot-oslo | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Producer.Snapshot.Oslo | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
build-snapshot-verifier: | |
name: Build Snapshot Verifier | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/build-image.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
registry: ${{ vars.VBR_DEVOPS_DOCKER_REGISTRY }}/building-registry | |
image-file: br-snapshot-verifier-image.tar | |
image-name: snapshot-verifier | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Snapshot.Verifier | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
# If not needed, also clean up csproj and paket.template (also downloads and push below) | |
pack-api-backoffice: | |
name: Pack Api BackOffice | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/pack.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
pack-file: Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.BackOffice | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Api.BackOffice | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
pack-api-backoffice-abstractions: | |
name: Pack Api BackOffice Abstractions | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/pack.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
pack-file: Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.BackOffice.Abstractions | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Api.BackOffice.Abstractions | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
pack-api-oslo: | |
name: Pack Api Oslo | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/pack.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
pack-file: Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.Oslo | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Api.Oslo | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
pack-api-extract: | |
name: Pack Api Extract | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/pack.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
pack-file: Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.Extract | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Api.Extract | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
build-lambda-backoffice: | |
name: Build Lambda | |
uses: Informatievlaanderen/build-pipeline/.github/workflows/build-lambda.yml@main | |
needs: [ set-release-version ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
with: | |
lambda-name: lambda-backoffice | |
test-project: BuildingRegistry.Tests | |
build-project: BuildingRegistry.Api.BackOffice.Handlers.Lambda | |
semver: ${{ needs.set-release-version.outputs.version }} | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
secrets: inherit | |
release: | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
name: Semantic Release | |
runs-on: ubuntu-latest | |
needs: [ set-release-version, | |
pack-api-backoffice, | |
pack-api-backoffice-abstractions, | |
pack-api-oslo, | |
pack-api-extract, | |
build-api-backoffice, | |
build-api-oslo, | |
build-api-extract, | |
build-projector, | |
build-projections-backoffice, | |
build-projections-last-changed-list, | |
build-cache-invalidator, | |
build-consumer-address, | |
build-consumer-read-parcel, | |
build-producer, | |
build-producer-snapshot-oslo, | |
build-lambda-backoffice, | |
build-snapshot-verifier | |
] | |
outputs: | |
version: ${{ steps.set-version.outputs.version }} | |
steps: | |
- name: Checkout Code | |
uses: actions/checkout@v4 | |
with: | |
persist-credentials: false | |
- name: Cache NPM | |
uses: actions/cache@v4 | |
env: | |
cache-name: cache-npm | |
with: | |
path: ~/.npm | |
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }} | |
restore-keys: | | |
${{ runner.os }}-build-${{ env.cache-name }}- | |
- name: Parse repository name | |
run: echo REPOSITORY_NAME=$(echo "$GITHUB_REPOSITORY" | awk -F / '{print $2}' | sed -e "s/:refs//") >> $GITHUB_ENV | |
shell: bash | |
- name: Setup Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: '20.x' | |
- name: Setup Python | |
uses: actions/setup-python@v5 | |
with: | |
python-version: '3.x' | |
- name: Node version | |
shell: bash | |
run: node --version | |
- name: .NET version | |
shell: bash | |
run: dotnet --info | |
- name: Python version | |
shell: bash | |
run: python --version | |
- name: Install NPM dependencies | |
shell: bash | |
run: npm ci | |
- name: Install Python dependencies | |
shell: bash | |
run: | | |
python -m pip install --upgrade pip | |
pip install requests markdown argparse | |
- name: Download NuGet Api BackOffice | |
uses: actions/download-artifact@v4 | |
continue-on-error: false | |
with: | |
name: nuget-Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.BackOffice-${{ needs.set-release-version.outputs.version }} | |
path: dist/nuget/ | |
- name: Download NuGet Api BackOffice Abstractions | |
uses: actions/download-artifact@v4 | |
continue-on-error: false | |
with: | |
name: nuget-Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.BackOffice.Abstractions-${{ needs.set-release-version.outputs.version }} | |
path: dist/nuget/ | |
- name: Download NuGet Api Oslo | |
uses: actions/download-artifact@v4 | |
continue-on-error: false | |
with: | |
name: nuget-Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.Oslo-${{ needs.set-release-version.outputs.version }} | |
path: dist/nuget/ | |
- name: Download NuGet Api Extract | |
uses: actions/download-artifact@v4 | |
continue-on-error: false | |
with: | |
name: nuget-Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.Extract-${{ needs.set-release-version.outputs.version }} | |
path: dist/nuget/ | |
- name: Run Semantic Release | |
shell: bash | |
run: npx semantic-release | |
env: | |
BUILD_DOCKER_REGISTRY: ${{ secrets.VBR_BUILD_DOCKER_REGISTRY_TST }} | |
GITHUB_TOKEN: ${{ secrets.VBR_GIT_RELEASE_TOKEN }} | |
GIT_COMMIT: ${{ github.sha }} | |
GIT_USERNAME: ${{ secrets.VBR_GIT_USER }} | |
GIT_AUTHOR_NAME: ${{ secrets.VBR_GIT_USER }} | |
GIT_COMMITTER_NAME: ${{ secrets.VBR_GIT_USER }} | |
GIT_EMAIL: ${{ secrets.VBR_GIT_EMAIL }} | |
GIT_AUTHOR_EMAIL: ${{ secrets.VBR_GIT_EMAIL }} | |
GIT_COMMITTER_EMAIL: ${{ secrets.VBR_GIT_EMAIL }} | |
- name: Set Release Version | |
id: set-version | |
run: | | |
[ ! -f semver ] && echo none > semver | |
echo $(cat semver) | |
echo ::set-output name=version::$(cat semver) | |
echo RELEASE_VERSION=$(cat semver) >> $GITHUB_ENV | |
shell: bash | |
upload-lambda: | |
name: Upload Lambda | |
needs: [ release ] | |
runs-on: ubuntu-latest | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.release.outputs.version != 'none') }} | |
steps: | |
- name: Download Lambda | |
uses: actions/download-artifact@v4 | |
continue-on-error: false | |
with: | |
name: lambda-backoffice-${{ needs.release.outputs.version }} | |
path: ~/ | |
- name: Configure AWS credentials (DevOps) | |
uses: aws-actions/[email protected] | |
with: | |
aws-access-key-id: ${{ secrets.VBR_AWS_ACCESS_KEY_ID_DEVOPS }} | |
aws-secret-access-key: ${{ secrets.VBR_AWS_SECRET_ACCESS_KEY_DEVOPS }} | |
aws-region: ${{ secrets.VBR_AWS_REGION_PRD }} | |
- name: Push Lambda functions to S3 DevOps | |
shell: bash | |
run: | | |
echo Push Lambda functions to S3 DevOps | |
echo aws s3 cp ~/lambda.zip s3://s3-vbr-lam-br-sqsbackofficefunction-362233117987/$SEMVER/lambda.zip | |
aws s3 cp ~/lambda.zip s3://s3-vbr-lam-br-sqsbackofficefunction-362233117987/$SEMVER/lambda.zip | |
env: | |
SEMVER: ${{ needs.release.outputs.version }} | |
- name: Configure AWS credentials (New Production) | |
uses: aws-actions/[email protected] | |
with: | |
aws-access-key-id: ${{ secrets.VBR_AWS_ACCESS_KEY_ID_NEWPRD }} | |
aws-secret-access-key: ${{ secrets.VBR_AWS_SECRET_ACCESS_KEY_NEWPRD }} | |
aws-region: ${{ secrets.VBR_AWS_REGION_PRD }} | |
- name: Login to Amazon ECR (New Production) | |
uses: aws-actions/amazon-ecr-login@v2 | |
- name: Push Lambda functions to S3 New Production | |
shell: bash | |
run: | | |
echo Push Lambda functions to S3 New Production | |
echo aws s3 cp ~/lambda.zip s3://077849980894-vbr-prd-lam-br-sqsbackoffice/$SEMVER/lambda.zip | |
aws s3 cp ~/lambda.zip s3://077849980894-vbr-prd-lam-br-sqsbackoffice/$SEMVER/lambda.zip | |
env: | |
SEMVER: ${{ needs.release.outputs.version }} | |
publish_to_nuget: | |
needs: [ release ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.release.outputs.version != 'none') }} | |
name: Publish to NuGet | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout Code | |
uses: actions/checkout@v4 | |
- name: Setup .NET Core | |
uses: actions/setup-dotnet@v4 | |
with: | |
dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
- name: .NET version | |
shell: bash | |
run: dotnet --info | |
- name: Download NuGet package api-backoffice | |
uses: actions/download-artifact@v4 | |
with: | |
name: nuget-Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.BackOffice-${{ needs.release.outputs.version }} | |
path: ~/ | |
- name: Download NuGet package api-backoffice-abstractions | |
uses: actions/download-artifact@v4 | |
with: | |
name: nuget-Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.BackOffice.Abstractions-${{ needs.release.outputs.version }} | |
path: ~/ | |
- name: Download NuGet package api-oslo | |
uses: actions/download-artifact@v4 | |
with: | |
name: nuget-Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.Oslo-${{ needs.release.outputs.version }} | |
path: ~/ | |
- name: Download NuGet package api-extract | |
uses: actions/download-artifact@v4 | |
with: | |
name: nuget-Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.Extract-${{ needs.release.outputs.version }} | |
path: ~/ | |
- name: Publish packages to NuGet | |
shell: bash | |
run: | | |
dotnet nuget push ~/Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.BackOffice.$SEMVER.nupkg --source nuget.org --api-key $NUGET_API_KEY | |
dotnet nuget push ~/Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.BackOffice.Abstractions.$SEMVER.nupkg --source nuget.org --api-key $NUGET_API_KEY | |
dotnet nuget push ~/Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.Oslo.$SEMVER.nupkg --source nuget.org --api-key $NUGET_API_KEY | |
dotnet nuget push ~/Be.Vlaanderen.Basisregisters.BuildingRegistry.Api.Extract.$SEMVER.nupkg --source nuget.org --api-key $NUGET_API_KEY | |
env: | |
SEMVER: ${{ needs.release.outputs.version }} | |
WORKSPACE: ${{ github.workspace }} | |
NUGET_API_KEY: ${{ secrets.NUGET_API_KEY }} | |
publish_to_atlassian: | |
needs: [ release ] | |
if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.release.outputs.version != 'none') }} | |
name: Publish to Atlassian | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout Code | |
uses: actions/checkout@v4 | |
- name: Parse repository name | |
run: echo REPOSITORY_NAME=$(echo "$GITHUB_REPOSITORY" | awk -F / '{print $2}' | sed -e "s/:refs//") >> $GITHUB_ENV | |
shell: bash | |
- name: Cache Paket | |
uses: actions/cache@v4 | |
env: | |
cache-name: cache-paket | |
with: | |
path: packages | |
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('paket.lock') }} | |
restore-keys: | | |
${{ runner.os }}-build-${{ env.cache-name }}- | |
- name: Cache Python | |
uses: actions/cache@v4 | |
env: | |
cache-name: cache-pip | |
with: | |
path: ~/.cache/pip | |
key: ${{ runner.os }}-build-${{ env.cache-name }} | |
- name: Setup Python | |
uses: actions/setup-python@v5 | |
with: | |
python-version: '3.x' | |
- name: Install Python dependencies | |
shell: bash | |
run: | | |
python -m pip install --upgrade pip | |
pip install requests markdown argparse | |
- name: Publish to Confluence | |
shell: bash | |
run: ./packages/Be.Vlaanderen.Basisregisters.Build.Pipeline/Content/ci-confluence.sh | |
env: | |
CONFLUENCE_TITLE: ${{ env.REPOSITORY_NAME }} | |
CONFLUENCE_USERNAME: ${{ secrets.VBR_CONFLUENCE_USER }} | |
CONFLUENCE_PASSWORD: ${{ secrets.VBR_CONFLUENCE_PASSWORD }} | |
# - name: Create Jira Release | |
# shell: bash | |
# run: ./packages/Be.Vlaanderen.Basisregisters.Build.Pipeline/Content/ci-jira.sh | |
# env: | |
# CONFLUENCE_TITLE: ${{ env.REPOSITORY_NAME }} | |
# CONFLUENCE_USERNAME: ${{ secrets.VBR_CONFLUENCE_USER }} | |
# CONFLUENCE_PASSWORD: ${{ secrets.VBR_CONFLUENCE_PASSWORD }} | |
# JIRA_PREFIX: Building | |
# JIRA_PROJECT: GAWR | |
# JIRA_VERSION: ${{ needs.release.outputs.version }} | |
push_images: | |
if: needs.release.outputs.version != 'none' | |
needs: [ release ] | |
name: Push images | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
image: [ | |
'api-backoffice', | |
'api-oslo', | |
'api-extract', | |
'projector', | |
'projections-backoffice', | |
'projections-last-changed-list-console', | |
'cache-invalidator', | |
'consumer-address', | |
'consumer-read-parcel', | |
'producer', | |
'producer-snapshot-oslo', | |
'snapshot-verifier' | |
] | |
steps: | |
- name: Configure AWS credentials | |
uses: aws-actions/[email protected] | |
with: | |
aws-access-key-id: ${{ secrets.VBR_AWS_ACCESS_KEY_ID_DEVOPS }} | |
aws-secret-access-key: ${{ secrets.VBR_AWS_SECRET_ACCESS_KEY_DEVOPS }} | |
aws-region: ${{ secrets.VBR_AWS_REGION_PRD }} | |
- name: Login to Amazon ECR | |
uses: aws-actions/amazon-ecr-login@v2 | |
# Download artifact | |
- name: Download artifact | |
uses: actions/download-artifact@v4 | |
continue-on-error: false | |
with: | |
name: ${{ matrix.image }}-${{ needs.release.outputs.version }} | |
path: ~/ | |
# Load artifact | |
- name: Load artifact | |
shell: bash | |
run: | | |
echo br-$IMAGE-image.tar | |
docker image load -i ~/br-$IMAGE-image.tar | |
env: | |
IMAGE: ${{ matrix.image }} | |
- name: Push artifacts to ECR | |
shell: bash | |
run: | | |
echo $IMAGE:$SEMVER | |
docker push $BUILD_DOCKER_REGISTRY/building-registry/$IMAGE:$SEMVER | |
env: | |
BUILD_DOCKER_REGISTRY: ${{ secrets.VBR_DEVOPS_DOCKER_REGISTRY }} | |
IMAGE: ${{ matrix.image }} | |
SEMVER: ${{ needs.release.outputs.version }} | |
WORKSPACE: ${{ github.workspace }} | |
deploy_to_test_start_slack: | |
if: github.repository_owner == 'Informatievlaanderen' | |
needs: [ push_images, upload-lambda ] | |
name: Deploy to test started | |
environment: test | |
runs-on: ubuntu-latest | |
steps: | |
- name: Parse repository name | |
run: echo REPOSITORY_NAME=$(echo ""$GITHUB_REPOSITORY"" | awk -F / '{print $2}' | sed -e ""s/:refs//"") >> $GITHUB_ENV | |
shell: bash | |
- name: Notify deployment started | |
uses: slackapi/[email protected] | |
with: | |
channel-id: '#team-dinosaur-dev' | |
slack-message: Deployment of building-registry to test has started | |
env: | |
SLACK_BOT_TOKEN: ${{ secrets.VBR_SLACK_BOT_TOKEN }} | |
SLACK_CHANNEL: ${{ secrets.VBR_NOTIFIER_CHANNEL_NAME }} | |
REPOSITORY_NAME: ${{ env.REPOSITORY_NAME }} | |
deploy_services_to_test: | |
if: github.repository_owner == 'Informatievlaanderen' | |
needs: [ deploy_to_test_start_slack, release ] | |
name: Deploy to services test | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
services: [ | |
'building-api', | |
'building-backoffice-api', | |
'building-consumer-address', | |
'building-consumer-parcel', | |
'building-producer', | |
'building-producer-snapshot-oslo', | |
'building-projections', | |
'building-projections-backoffice' | |
] | |
steps: | |
- name: Deploy services | |
env: | |
BUILD_URL: ${{ vars.VBR_AWS_BUILD_API_DEVOPS }}/${{matrix.services}} | |
STATUS_URL: ${{ vars.VBR_AWS_BUILD_STATUS_API_DEVOPS }}/${{matrix.services}} | |
uses: informatievlaanderen/awscurl-polling-action/polling-action@main | |
with: | |
environment: tst | |
version: ${{ needs.release.outputs.version }} | |
status-url: $STATUS_URL | |
deploy-url: $BUILD_URL | |
access-key: ${{ secrets.VBR_AWS_ACCESS_KEY_ID_DEVOPS }} | |
secret-key: ${{ secrets.VBR_AWS_SECRET_ACCESS_KEY_DEVOPS }} | |
deploy-target: 'agb_ecs_service' | |
interval: 2 | |
domain: 'basisregisters' | |
project: 'basisregisters' | |
- name: Deploy services output | |
shell: bash | |
run: | | |
echo build-uuid: ${{ steps.awscurl-polling-action.outputs.build-uuid }} | |
echo Status: ${{ steps.awscurl-polling-action.outputs.status }} | |
echo ${{ steps.awscurl-polling-action.outputs.final-message }} | |
deploy_tasks_to_test: | |
if: github.repository_owner == 'Informatievlaanderen' | |
needs: [ deploy_to_test_start_slack, release ] | |
name: Deploy to tasks test | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
services: [ | |
'building-snapshot-verifier', | |
'building-cache-invalidator' | |
] | |
steps: | |
- name: Deploy tasks | |
env: | |
BUILD_URL: ${{ vars.VBR_AWS_BUILD_API_DEVOPS }}/${{matrix.services}} | |
STATUS_URL: ${{ vars.VBR_AWS_BUILD_STATUS_API_DEVOPS }}/${{matrix.services}} | |
uses: informatievlaanderen/awscurl-polling-action/polling-action@main | |
with: | |
environment: tst | |
version: ${{ needs.release.outputs.version }} | |
status-url: $STATUS_URL | |
deploy-url: $BUILD_URL | |
access-key: ${{ secrets.VBR_AWS_ACCESS_KEY_ID_DEVOPS }} | |
secret-key: ${{ secrets.VBR_AWS_SECRET_ACCESS_KEY_DEVOPS }} | |
deploy-target: 'ecs_scheduled_task' | |
interval: 2 | |
domain: 'basisregisters' | |
project: 'basisregisters' | |
- name: Deploy tasks output | |
shell: bash | |
run: | | |
echo build-uuid: ${{ steps.awscurl-polling-action.outputs.build-uuid }} | |
echo Status: ${{ steps.awscurl-polling-action.outputs.status }} | |
echo ${{ steps.awscurl-polling-action.outputs.final-message }} | |
deploy_lambda_to_test: | |
if: github.repository_owner == 'Informatievlaanderen' | |
needs: [ deploy_to_test_start_slack, release ] | |
name: Deploy lambda to test | |
runs-on: ubuntu-latest | |
steps: | |
- name: CD Lambda(s) Configure credentials | |
uses: aws-actions/[email protected] | |
with: | |
aws-access-key-id: ${{ secrets.VBR_AWS_ACCESS_KEY_ID_DEVOPS }} | |
aws-secret-access-key: ${{ secrets.VBR_AWS_SECRET_ACCESS_KEY_DEVOPS }} | |
aws-region: ${{ secrets.VBR_AWS_REGION_PRD }} | |
- name: Promote Lambda(s) | |
uses: Informatievlaanderen/build-pipeline/.github/actions/deploy-lambda@main | |
with: | |
function-name: br-sqsbackofficefunction | |
deploy-url: ${{ vars.VBR_AWS_DEPLOY_LAMBDA_DEVOPS_BASEURL }} | |
access-key-id: ${{ secrets.VBR_AWS_ACCESS_KEY_ID_DEVOPS }} | |
secret-access-key-id: ${{ secrets.VBR_AWS_SECRET_ACCESS_KEY_DEVOPS }} | |
region: ${{ secrets.VBR_AWS_REGION_PRD }} | |
version: ${{ needs.release.outputs.version }} | |
environment: tst | |
deploy_to_test_finish_slack: | |
if: github.repository_owner == 'Informatievlaanderen' | |
needs: [ deploy_lambda_to_test, deploy_services_to_test, deploy_tasks_to_test ] | |
name: Deploy to test finished | |
runs-on: ubuntu-latest | |
steps: | |
- name: Parse repository name | |
run: echo REPOSITORY_NAME=$(echo ""$GITHUB_REPOSITORY"" | awk -F / '{print $2}' | sed -e ""s/:refs//"") >> $GITHUB_ENV | |
shell: bash | |
- name: Notify deployment finished | |
uses: slackapi/[email protected] | |
with: | |
channel-id: '#team-dinosaur-dev' | |
slack-message: Deployment of building-registry to test has finished | |
env: | |
SLACK_BOT_TOKEN: ${{ secrets.VBR_SLACK_BOT_TOKEN }} | |
SLACK_CHANNEL: ${{ secrets.VBR_NOTIFIER_CHANNEL_NAME }} | |
REPOSITORY_NAME: ${{ env.REPOSITORY_NAME }} | |
deploy_to_new_staging_start_slack: | |
if: github.repository_owner == 'Informatievlaanderen' | |
needs: [ deploy_to_test_finish_slack ] | |
name: Deploy to new staging started | |
environment: stg | |
runs-on: ubuntu-latest | |
steps: | |
- name: Parse repository name | |
run: echo REPOSITORY_NAME=$(echo ""$GITHUB_REPOSITORY"" | awk -F / '{print $2}' | sed -e ""s/:refs//"") >> $GITHUB_ENV | |
shell: bash | |
- name: Notify deployment started | |
uses: slackapi/[email protected] | |
with: | |
channel-id: '#team-dinosaur-dev' | |
slack-message: Deployment of building-registry to staging has started | |
env: | |
SLACK_BOT_TOKEN: ${{ secrets.VBR_SLACK_BOT_TOKEN }} | |
SLACK_CHANNEL: ${{ secrets.VBR_NOTIFIER_CHANNEL_NAME }} | |
REPOSITORY_NAME: ${{ env.REPOSITORY_NAME }} | |
deploy_services_to_new_staging: | |
if: github.repository_owner == 'Informatievlaanderen' | |
needs: [ deploy_to_new_staging_start_slack, release ] | |
name: Deploy to services new staging | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
services: [ | |
'building-api', | |
'building-backoffice-api', | |
'building-consumer-address', | |
'building-consumer-parcel', | |
'building-producer', | |
'building-producer-snapshot-oslo', | |
'building-projections', | |
'building-projections-backoffice' | |
] | |
steps: | |
- name: Deploy services | |
env: | |
BUILD_URL: ${{ vars.VBR_AWS_BUILD_API_DEVOPS }}/${{matrix.services}} | |
STATUS_URL: ${{ vars.VBR_AWS_BUILD_STATUS_API_DEVOPS }}/${{matrix.services}} | |
uses: informatievlaanderen/awscurl-polling-action/polling-action@main | |
with: | |
environment: stg | |
version: ${{ needs.release.outputs.version }} | |
status-url: $STATUS_URL | |
deploy-url: $BUILD_URL | |
access-key: ${{ secrets.VBR_AWS_ACCESS_KEY_ID_DEVOPS }} | |
secret-key: ${{ secrets.VBR_AWS_SECRET_ACCESS_KEY_DEVOPS }} | |
deploy-target: 'agb_ecs_service' | |
interval: 2 | |
domain: 'basisregisters' | |
project: 'basisregisters' | |
- name: Deploy services output | |
shell: bash | |
run: | | |
echo build-uuid: ${{ steps.awscurl-polling-action.outputs.build-uuid }} | |
echo Status: ${{ steps.awscurl-polling-action.outputs.status }} | |
echo ${{ steps.awscurl-polling-action.outputs.final-message }} | |
deploy_tasks_to_new_staging: | |
if: github.repository_owner == 'Informatievlaanderen' | |
needs: [ deploy_to_new_staging_start_slack, release ] | |
name: Deploy to tasks new staging | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
services: [ | |
'building-cache-invalidator', | |
'building-snapshot-verifier' | |
] | |
steps: | |
- name: Deploy tasks | |
env: | |
BUILD_URL: ${{ vars.VBR_AWS_BUILD_API_DEVOPS }}/${{matrix.services}} | |
STATUS_URL: ${{ vars.VBR_AWS_BUILD_STATUS_API_DEVOPS }}/${{matrix.services}} | |
uses: informatievlaanderen/awscurl-polling-action/polling-action@main | |
with: | |
environment: stg | |
version: ${{ needs.release.outputs.version }} | |
status-url: $STATUS_URL | |
deploy-url: $BUILD_URL | |
access-key: ${{ secrets.VBR_AWS_ACCESS_KEY_ID_DEVOPS }} | |
secret-key: ${{ secrets.VBR_AWS_SECRET_ACCESS_KEY_DEVOPS }} | |
deploy-target: 'ecs_scheduled_task' | |
interval: 2 | |
domain: 'basisregisters' | |
project: 'basisregisters' | |
- name: Deploy tasks output | |
shell: bash | |
run: | | |
echo build-uuid: ${{ steps.awscurl-polling-action.outputs.build-uuid }} | |
echo Status: ${{ steps.awscurl-polling-action.outputs.status }} | |
echo ${{ steps.awscurl-polling-action.outputs.final-message }} | |
deploy_lambda_to_new_staging: | |
if: github.repository_owner == 'Informatievlaanderen' | |
needs: [ deploy_tasks_to_new_staging, deploy_services_to_new_staging, release ] | |
name: Deploy lambda to new staging | |
runs-on: ubuntu-latest | |
steps: | |
- name: CD Lambda(s) Configure credentials | |
uses: aws-actions/[email protected] | |
with: | |
aws-access-key-id: ${{ secrets.VBR_AWS_ACCESS_KEY_ID_DEVOPS }} | |
aws-secret-access-key: ${{ secrets.VBR_AWS_SECRET_ACCESS_KEY_DEVOPS }} | |
aws-region: ${{ secrets.VBR_AWS_REGION_PRD }} | |
- name: Promote Lambda(s) | |
uses: Informatievlaanderen/build-pipeline/.github/actions/deploy-lambda@main | |
with: | |
function-name: br-sqsbackofficefunction | |
deploy-url: ${{ vars.VBR_AWS_DEPLOY_LAMBDA_DEVOPS_BASEURL }} | |
access-key-id: ${{ secrets.VBR_AWS_ACCESS_KEY_ID_DEVOPS }} | |
secret-access-key-id: ${{ secrets.VBR_AWS_SECRET_ACCESS_KEY_DEVOPS }} | |
region: ${{ secrets.VBR_AWS_REGION_PRD }} | |
version: ${{ needs.release.outputs.version }} | |
environment: stg | |
deploy_to_new_staging_finish_slack: | |
if: github.repository_owner == 'Informatievlaanderen' | |
needs: [ deploy_lambda_to_new_staging ] | |
name: Deploy to new staging finished | |
runs-on: ubuntu-latest | |
steps: | |
- name: Parse repository name | |
run: echo REPOSITORY_NAME=$(echo ""$GITHUB_REPOSITORY"" | awk -F / '{print $2}' | sed -e ""s/:refs//"") >> $GITHUB_ENV | |
shell: bash | |
- name: Notify deployment finished | |
uses: slackapi/[email protected] | |
with: | |
channel-id: '#team-dinosaur-dev' | |
slack-message: Deployment of building-registry to new staging has finished | |
env: | |
SLACK_BOT_TOKEN: ${{ secrets.VBR_SLACK_BOT_TOKEN }} | |
SLACK_CHANNEL: ${{ secrets.VBR_NOTIFIER_CHANNEL_NAME }} | |
REPOSITORY_NAME: ${{ env.REPOSITORY_NAME }} |