Skip to content

Move to monorepo

Move to monorepo #27

Workflow file for this run

name: Build & Publish Docker Image
# ! Change this back to released
#on:
# release:
# types: [ published ]
on:
pull_request:
types: [ opened, synchronize, reopened ]
jobs:
build-base-js:
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
# This is used to complete the identity challenge
# with sigstore/fulcio when running outside of PRs.
id-token: write
strategy:
matrix:
type: [ "js-build", "js-run" ]
steps:
- name: Checkout
uses: actions/checkout@v3
- uses: ./.github/actions/prepare
id: prepare
with:
service-name: acs-base
token: ${{ secrets.GITHUB_TOKEN }}
- name: Build
id: build-and-push
uses: docker/build-push-action@v5
with:
context: .
platforms: linux/amd64,linux/arm64
file: ./acs-base-images/Dockerfile.${{ matrix.type }}
push: true
tags: ghcr.io/amrc-factoryplus/${{ steps.prepare.outputs.service-name }}-${{ matrix.type }}:${{ steps.prepare.outputs.version }}
build-args: |
base=ghcr.io/amrc-factoryplus/${{ steps.prepare.outputs.service-name }}
version=${{ steps.prepare.outputs.version }}
labels: ${{ steps.prepare.outputs.labels }}
cache-from: type=gha
cache-to: type=gha,mode=max
- uses: ./.github/actions/cleanup
id: cleanup
with:
version: ${{ steps.prepare.outputs.version }}
service-name: ${{ steps.prepare.outputs.service-name }}-${{ matrix.type }}
digest: ${{ steps.build-and-push.outputs.digest }}
build-base-pg-build:
runs-on: ubuntu-latest
needs: build-base-js
permissions:
contents: read
packages: write
# This is used to complete the identity challenge
# with sigstore/fulcio when running outside of PRs.
id-token: write
steps:
- name: Checkout
uses: actions/checkout@v3
- uses: ./.github/actions/prepare
id: prepare
with:
service-name: acs-base
token: ${{ secrets.GITHUB_TOKEN }}
- name: Build
id: build-and-push
uses: docker/build-push-action@v5
with:
context: .
platforms: linux/amd64
file: ./acs-base-images/Dockerfile.pg-build
push: true
tags: ghcr.io/amrc-factoryplus/${{ steps.prepare.outputs.service-name }}-pg-build:${{ steps.prepare.outputs.version }}
build-args: |
base=ghcr.io/amrc-factoryplus/${{ steps.prepare.outputs.service-name }}
version=${{ steps.prepare.outputs.version }}
labels: ${{ steps.prepare.outputs.labels }}
cache-from: type=gha
cache-to: type=gha,mode=max
- uses: ./.github/actions/cleanup
id: cleanup
with:
version: ${{ steps.prepare.outputs.version }}
service-name: ${{ steps.prepare.outputs.service-name }}-pg-build
digest: ${{ steps.build-and-push.outputs.digest }}
build-base-pg-run:
runs-on: ubuntu-latest
needs: build-base-pg-build
permissions:
contents: read
packages: write
# This is used to complete the identity challenge
# with sigstore/fulcio when running outside of PRs.
id-token: write
steps:
- name: Checkout
uses: actions/checkout@v3
- uses: ./.github/actions/prepare
id: prepare
with:
service-name: acs-base
token: ${{ secrets.GITHUB_TOKEN }}
- name: Build
id: build-and-push
uses: docker/build-push-action@v5
with:
context: .
platforms: linux/amd64
file: ./acs-base-images/Dockerfile.pg-run
push: true
tags: ghcr.io/amrc-factoryplus/${{ steps.prepare.outputs.service-name }}-pg-run:${{ steps.prepare.outputs.version }}
build-args: |
base=ghcr.io/amrc-factoryplus/${{ steps.prepare.outputs.service-name }}
version=${{ steps.prepare.outputs.version }}
labels: ${{ steps.prepare.outputs.labels }}
cache-from: type=gha
cache-to: type=gha,mode=max
- uses: ./.github/actions/cleanup
id: cleanup
with:
version: ${{ steps.prepare.outputs.version }}
service-name: ${{ steps.prepare.outputs.service-name }}-pg-run
digest: ${{ steps.build-and-push.outputs.digest }}
build-x86:
needs: [ build-base-js, build-base-pg-build, build-base-pg-run ]
runs-on: ubuntu-latest
strategy:
matrix:
service: [ 'acs-auth', 'acs-directory', 'acs-cluster-manager', 'acs-cmdesc', 'acs-configdb',
'acs-edge-monitor', 'acs-edge-sync', 'acs-git', 'acs-identity', 'acs-krb-keys-operator',
'acs-krb-utils', 'acs-service-setup', 'acs-visualiser' ]
permissions:
contents: read
packages: write
id-token: write
pull-requests: write
steps:
- name: Checkout
uses: actions/checkout@v3
- uses: ./.github/actions/prepare
id: prepare
with:
service-name: ${{ matrix.service }}
token: ${{ secrets.GITHUB_TOKEN }}
- name: Build
uses: docker/build-push-action@v5
id: build-and-push
with:
context: ./${{ steps.prepare.outputs.service-name }}
push: true
tags: ghcr.io/amrc-factoryplus/${{ steps.prepare.outputs.service-name }}:${{ steps.prepare.outputs.version }}
labels: ${{ steps.prepare.outputs.labels }}
cache-from: type=gha
cache-to: type=gha,mode=max
- uses: ./.github/actions/cleanup
id: cleanup
with:
version: ${{ steps.prepare.outputs.version }}
service-name: ${{ steps.prepare.outputs.service-name }}
digest: ${{ steps.build-and-push.outputs.digest }}
build-x86-arm:
needs: [ build-base-js, build-base-pg-build, build-base-pg-run ]
runs-on: ubuntu-latest
strategy:
matrix:
service: [ 'acs-edge' ]
permissions:
contents: read
packages: write
id-token: write
pull-requests: write
steps:
- name: Checkout
uses: actions/checkout@v3
- uses: ./.github/actions/prepare
id: prepare
with:
service-name: ${{ matrix.service }}
token: ${{ secrets.GITHUB_TOKEN }}
- name: Set Git info
run: |
git describe --tags --dirty
git describe --tags --dirty \
| sed -e's/^/export const GIT_VERSION="/;s/$/";/' \
> ./${{ steps.prepare.outputs.service-name }}/lib/git-version.js "
- name: Build
uses: docker/build-push-action@v5
id: build-and-push
with:
context: ./${{ steps.prepare.outputs.service-name }}
platforms: linux/amd64,linux/arm64
push: true
tags: ghcr.io/amrc-factoryplus/${{ steps.prepare.outputs.service-name }}:${{ steps.prepare.outputs.version }}
labels: ${{ steps.prepare.outputs.labels }}
cache-from: type=gha
cache-to: type=gha,mode=max
- uses: ./.github/actions/cleanup
id: cleanup
with:
version: ${{ steps.prepare.outputs.version }}
service-name: ${{ steps.prepare.outputs.service-name }}
digest: ${{ steps.build-and-push.outputs.digest }}
build-manager:
runs-on: ubuntu-latest
steps:
- name: Skip
run: |
echo "Skipping"
build-mqtt:
runs-on: ubuntu-latest
steps:
- name: Skip
run: |
echo "Skipping"
build-helm-chart:
needs: [ 'build-x86', 'build-x86-arm', 'build-manager', 'build-mqtt' ]
runs-on: ubuntu-latest
steps:
- name: Install Helm
run: |
curl https://raw.githubusercontent.com/helm/helm/main/scripts/get-helm-3 | bash
- name: Checkout code
uses: actions/checkout@v3
with:
ref: ${{ github.event.release.tag_name }}
- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Package Helm chart
run: |
TAG=${{ github.event.release.tag_name }}
VERSION=${TAG#v}
helm package -u -d deploy/build --version=$VERSION --app-version=$VERSION .
echo "VERSION=$VERSION" >> $GITHUB_ENV
- uses: actions/upload-artifact@v3
with:
name: new-release
path: build/amrc-connectivity-stack-${{ env.VERSION }}.tgz
# This job checks out the release branch, adds the new release to the /builds folder, builds the index and commits
# the changes, which triggers Github to release it as a new pages repo
# release-helm-chart:
# needs: build-helm-chart
# runs-on: ubuntu-latest
# steps:
# - name: Install Helm
# run: |
# curl https://raw.githubusercontent.com/helm/helm/main/scripts/get-helm-3 | bash
# - name: Checkout code
# uses: actions/checkout@v3
# with:
# ref: release
# - name: add-new-release
# uses: actions/download-artifact@v3
# with:
# name: new-release
# path: deploy/build
# - name: Build index
# run: |
# cd deploy/build
# helm repo index --url https://amrc-factoryplus.github.io/amrc-connectivity-stack/build .
# - name: commit
# uses: stefanzweifel/git-auto-commit-action@v4
# id: auto_commit_action
# with:
# commit_message: Release ${{ github.event.release.tag_name }}
# commit_user_name: GitHub Action
# commit_user_email: [email protected]
# branch: release
# create_branch: true
# push_options: '--force'