2022-06-15 04:50:46 -04:00
|
|
|
name: Build micro-service Manual
|
|
|
|
|
|
|
|
on:
|
|
|
|
workflow_dispatch:
|
|
|
|
inputs:
|
|
|
|
microService:
|
2022-09-14 09:14:26 -04:00
|
|
|
description: "Name of the micro-service image to build"
|
2022-06-15 04:50:46 -04:00
|
|
|
type: choice
|
|
|
|
options:
|
2022-09-14 09:14:26 -04:00
|
|
|
- "join-service"
|
|
|
|
- "kmsserver"
|
|
|
|
- "verification-service"
|
2022-11-30 05:45:40 -05:00
|
|
|
- "qemu-metadata-api"
|
2022-12-05 04:59:51 -05:00
|
|
|
- "filebeat-debugd"
|
|
|
|
- "logstash-debugd"
|
2022-06-15 04:50:46 -04:00
|
|
|
required: true
|
2022-11-11 02:44:36 -05:00
|
|
|
default: "join-service"
|
2022-06-15 04:50:46 -04:00
|
|
|
imageTag:
|
2022-09-14 09:14:26 -04:00
|
|
|
description: "Container image tag"
|
2022-06-15 04:50:46 -04:00
|
|
|
required: true
|
2022-09-14 09:14:26 -04:00
|
|
|
default: "manual-build"
|
2022-06-15 05:15:33 -04:00
|
|
|
version:
|
2022-09-14 09:14:26 -04:00
|
|
|
description: "Version of the image to build"
|
2022-06-15 05:15:33 -04:00
|
|
|
required: true
|
2022-09-14 09:14:26 -04:00
|
|
|
default: "0.0.0"
|
2022-06-15 04:50:46 -04:00
|
|
|
|
|
|
|
jobs:
|
|
|
|
build-micro-service:
|
2022-11-10 10:55:24 -05:00
|
|
|
runs-on: ubuntu-22.04
|
2022-06-15 04:50:46 -04:00
|
|
|
permissions:
|
|
|
|
contents: read
|
|
|
|
packages: write
|
|
|
|
steps:
|
|
|
|
- name: Check out repository
|
|
|
|
id: checkout
|
2023-01-05 10:17:51 -05:00
|
|
|
uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3.3.0
|
2022-11-10 11:22:26 -05:00
|
|
|
with:
|
2022-12-19 09:21:28 -05:00
|
|
|
ref: ${{ !github.event.pull_request.head.repo.fork && github.head_ref || '' }}
|
2022-06-15 04:50:46 -04:00
|
|
|
|
2022-09-14 09:14:26 -04:00
|
|
|
- name: Setup Go environment
|
2022-12-14 08:55:14 -05:00
|
|
|
uses: actions/setup-go@6edd4406fa81c3da01a34fa6f6343087c207a568 # v3.5.0
|
2022-09-14 09:14:26 -04:00
|
|
|
with:
|
2022-12-07 08:27:43 -05:00
|
|
|
go-version: "1.19.4"
|
2022-09-14 09:14:26 -04:00
|
|
|
|
2022-06-15 04:50:46 -04:00
|
|
|
# choose the correct Dockerfile depending on what micro-service is being build
|
|
|
|
- name: Set Dockerfile variable
|
|
|
|
id: set-variable
|
|
|
|
run: |
|
2022-06-15 05:15:33 -04:00
|
|
|
case "${{ inputs.microService }}" in
|
2022-07-05 08:13:19 -04:00
|
|
|
"join-service" )
|
2022-11-11 08:49:16 -05:00
|
|
|
echo "microServiceDockerfile=joinservice/Dockerfile" >> "$GITHUB_ENV" ;;
|
2022-06-15 04:50:46 -04:00
|
|
|
"kmsserver" )
|
2022-11-11 08:49:16 -05:00
|
|
|
echo "microServiceDockerfile=kms/Dockerfile" >> "$GITHUB_ENV" ;;
|
2022-06-28 11:03:28 -04:00
|
|
|
"verification-service" )
|
2022-11-11 08:49:16 -05:00
|
|
|
echo "microServiceDockerfile=verify/Dockerfile" >> "$GITHUB_ENV" ;;
|
2022-11-30 05:45:40 -05:00
|
|
|
"qemu-metadata-api" )
|
|
|
|
echo "microServiceDockerfile=hack/qemu-metadata-api/Dockerfile" >> "$GITHUB_ENV" ;;
|
2022-12-05 04:59:51 -05:00
|
|
|
"filebeat-debugd" )
|
2022-11-30 11:20:16 -05:00
|
|
|
echo "microServiceDockerfile=debugd/internal/debugd/logcollector/filebeat/Dockerfile" >> "$GITHUB_ENV" ;;
|
2022-12-05 04:59:51 -05:00
|
|
|
"logstash-debugd" )
|
2022-11-30 11:20:16 -05:00
|
|
|
echo "microServiceDockerfile=debugd/internal/debugd/logcollector/logstash/Dockerfile" >> "$GITHUB_ENV" ;;
|
2022-06-15 04:50:46 -04:00
|
|
|
esac
|
|
|
|
|
2022-07-14 09:45:04 -04:00
|
|
|
- name: Build and upload container image
|
2022-06-15 04:50:46 -04:00
|
|
|
id: build-and-upload
|
2022-07-13 08:04:46 -04:00
|
|
|
uses: ./.github/actions/build_micro_service
|
2022-06-15 04:50:46 -04:00
|
|
|
with:
|
2022-06-15 05:00:15 -04:00
|
|
|
name: ${{ inputs.microService }}
|
2022-06-28 11:03:28 -04:00
|
|
|
projectVersion: ${{ inputs.version }}
|
2022-06-15 04:50:46 -04:00
|
|
|
dockerfile: ${{ env.microServiceDockerfile }}
|
2022-06-15 05:15:33 -04:00
|
|
|
pushTag: ${{ inputs.imageTag }}
|
|
|
|
githubToken: ${{ secrets.GITHUB_TOKEN }}
|
2022-10-21 09:19:51 -04:00
|
|
|
cosignPublicKey: ${{ startsWith(github.ref, 'refs/heads/release/v') && secrets.COSIGN_PUBLIC_KEY || secrets.COSIGN_DEV_PUBLIC_KEY }}
|
|
|
|
cosignPrivateKey: ${{ startsWith(github.ref, 'refs/heads/release/v') && secrets.COSIGN_PRIVATE_KEY || secrets.COSIGN_DEV_PRIVATE_KEY }}
|
|
|
|
cosignPassword: ${{ startsWith(github.ref, 'refs/heads/release/v') && secrets.COSIGN_PASSWORD || secrets.COSIGN_DEV_PASSWORD }}
|