Move to monorepo #27
Workflow file for this run
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: 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' |