1
0
Fork 0
mirror of https://github.com/sdr-enthusiasts/docker-adsb-ultrafeeder.git synced 2024-12-27 06:42:00 +00:00

Update deploy.yml

This commit is contained in:
Fred Clausen 2023-07-29 14:55:51 -06:00
parent 50510a3320
commit 6651974bb8

View file

@ -6,26 +6,32 @@ on:
inputs: inputs:
reason: reason:
required: false required: false
description: 'Reason for running this workflow' description: "Reason for running this workflow"
use_test_image:
required: false
type: boolean
description: "Use base image testpr"
default: false
push: push:
branches: branches:
- main - main
# Don't trigger if it's just a documentation update # Don't trigger if it's just a documentation update
paths-ignore: paths-ignore:
- '**.md' - "**.md"
- '**.MD' - "**.MD"
- '**.yml' - "**.yml"
- 'LICENSE' - "LICENSE"
- '.gitattributes' - ".gitattributes"
- '.gitignore' - ".gitignore"
- '.dockerignore' - ".dockerignore"
# Set workflow-wide environment variables # Set workflow-wide environment variables
# - REPO: repo name on dockerhub # - REPO: repo name on dockerhub
# - IMAGE: image name on dockerhub # - IMAGE: image name on dockerhub
env: env:
# DOCKERHUB_REPO: sdr-enthusiasts # DOCKERHUB_REPO: sdr-enthusiasts
# DOCKERHUB_IMAGE: vrs # DOCKERHUB_IMAGE: vrs
GHCR_IMAGE: sdr-enthusiasts/docker-adsb-ultrafeeder GHCR_IMAGE: sdr-enthusiasts/docker-adsb-ultrafeeder
GHCR_REGISTRY: ghcr.io GHCR_REGISTRY: ghcr.io
GH_LABEL: main GH_LABEL: main
@ -44,8 +50,10 @@ jobs:
- name: Log dispatch reason - name: Log dispatch reason
env: env:
INPUTS_REASON: ${{ github.event.inputs.reason }} INPUTS_REASON: ${{ github.event.inputs.reason }}
INPUTS_USE_TEST_IMAGE: ${{ github.event.inputs.use_test_image }}
run: | run: |
echo "Workflow dispatch reason: $INPUTS_REASON" echo "Workflow dispatch reason: $INPUTS_REASON"
echo "Use test image: $INPUTS_USE_TEST_IMAGE"
hadolint: hadolint:
name: Run hadolint against docker files name: Run hadolint against docker files
@ -57,227 +65,47 @@ jobs:
- name: Run hadolint against Dockerfiles - name: Run hadolint against Dockerfiles
run: docker run --rm -i -v "$PWD":/workdir --workdir /workdir --entrypoint hadolint hadolint/hadolint --ignore DL3015 --ignore DL3003 --ignore DL3006 --ignore DL3010 --ignore DL4001 --ignore DL3007 --ignore DL3008 --ignore SC2068 --ignore DL3007 --ignore SC1091 --ignore DL3013 --ignore DL3010 $(find . -type f -iname "Dockerfile*") run: docker run --rm -i -v "$PWD":/workdir --workdir /workdir --entrypoint hadolint hadolint/hadolint --ignore DL3015 --ignore DL3003 --ignore DL3006 --ignore DL3010 --ignore DL4001 --ignore DL3007 --ignore DL3008 --ignore SC2068 --ignore DL3007 --ignore SC1091 --ignore DL3013 --ignore DL3010 $(find . -type f -iname "Dockerfile*")
deploy_ghcr_multiarch_latest: deploy:
name: Deploy latest to ghcr.io (Multi-Arch) name: Deploy without telegraf
needs: [hadolint] uses: sdr-enthusiasts/common-github-workflows/.github/workflows/build_and_push_image.yml@main
runs-on: ubuntu-latest
permissions:
packages: write
steps:
# Check out our code
- name: Checkout
uses: actions/checkout@v3
with: with:
fetch-depth: 0 push_enabled: true
ref: ${{ env.GH_LABEL }} push_destinations: ghcr.io
ghcr_repo_owner: ${{ github.repository_owner }}
ghcr_repo: ${{ github.repository }}
get_version_method: file_in_container:file=/CONTAINER_VERSION
# set build_latest to true if github.event.inputs.use_test_image is false
build_latest: ${{ github.event.inputs.use_test_image == 'false' }}
build_baseimage_test: ${{ github.event.inputs.use_test_image == 'true' }}
# only build the entire stack if we are not using the test image
build_version_specific: false
build_platform_specific: false
build_nohealthcheck: false
build_baseimage_url: docker-tar1090:latest/docker-tar1090:baseimage_test
secrets:
ghcr_token: ${{ secrets.GITHUB_TOKEN }}
# Log into ghcr (so we can push images) # unfortunately we can't use build_and_push_image.yml to build the telegraf label because
- name: Login to ghcr.io # that GH Action doesn't have the capability to build specific custom-named labels
uses: docker/login-action@v2
deploy_with_telegraf:
name: Deploy with telegraf and healthcheck
uses: sdr-enthusiasts/common-github-workflows/.github/workflows/build_and_push_image.yml@main
with: with:
registry: ${{ env.GHCR_REGISTRY }} push_enabled: true
username: ${{ github.repository_owner }} push_destinations: ghcr.io
password: ${{ secrets.GITHUB_TOKEN }} ghcr_repo_owner: ${{ github.repository_owner }}
ghcr_repo: ${{ github.repository }}
get_version_method: file_in_container:file=/CONTAINER_VERSION
# set build_latest to true if github.event.inputs.use_test_image is false
build_latest: ${{ github.event.inputs.use_test_image == 'false' }}
build_baseimage_test: ${{ github.event.inputs.use_test_image == 'true' }}
build_baseimage_url: docker-tar1090:latest/docker-tar1090:telegraf_baseimage_test
# only build the entire stack if we are not using the test image
build_version_specific: false
build_platform_specific: false
build_nohealthcheck: false
docker_latest_tag: telegraf
# Get metadata from repo secrets:
- name: Extract metadata (tags, labels) for Docker ghcr_token: ${{ secrets.GITHUB_TOKEN }}
id: meta
uses: docker/metadata-action@v4
with:
images: ${{ env.GHCR_REGISTRY }}/${{ env.IMAGE_NAME }}
# Set up QEMU for multi-arch builds
- name: Set up QEMU
uses: docker/setup-qemu-action@v2
# Set up buildx for multi platform builds
- name: Set up Docker Buildx
id: buildx
uses: docker/setup-buildx-action@v2
with:
driver-opts: image=moby/buildkit:v0.10.6
# Build "latest"
- name: Build & Push - latest
uses: docker/build-push-action@v3
with:
context: .
file: ./Dockerfile
no-cache: true
platforms: linux/amd64,linux/arm/v7,linux/arm64
push: true
tags: ghcr.io/${{ env.GHCR_IMAGE }}:${{ env.GHCR_TAG }}
labels: ${{ steps.meta.outputs.labels }}
# ------------------------------------------------------------------------------------------------------------------------
deploy_ghcr_multiarch_latest_nohealthcheck:
name: Deploy latest_nohealthcheck to ghcr.io (Multi-Arch)
needs: [hadolint]
runs-on: ubuntu-latest
permissions:
packages: write
steps:
# Check out our code
- name: Checkout
uses: actions/checkout@v3
with:
fetch-depth: 0
ref: ${{ env.GH_LABEL }}
# Log into ghcr (so we can push images)
- name: Login to ghcr.io
uses: docker/login-action@v2
with:
registry: ${{ env.GHCR_REGISTRY }}
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
# Get metadata from repo
- name: Extract metadata (tags, labels) for Docker
id: meta
uses: docker/metadata-action@v4
with:
images: ${{ env.GHCR_REGISTRY }}/${{ env.IMAGE_NAME }}
# Set up QEMU for multi-arch builds
- name: Set up QEMU
uses: docker/setup-qemu-action@v2
# Set up buildx for multi platform builds
- name: Set up Docker Buildx
id: buildx
uses: docker/setup-buildx-action@v2
with:
driver-opts: image=moby/buildkit:v0.10.6
# Change Dockerfile to use latest_nohealthcheck tag of build image:
- name: change build image to use latest_nohealthcheck tag of docker-docker-tar1090
run: |
sed -i "s|FROM ghcr.io/sdr-enthusiasts/docker-tar1090:latest|FROM ghcr.io/sdr-enthusiasts/docker-tar1090:latest_nohealthcheck|g" ./Dockerfile
# Build "latest_nohealthcheck"
- name: Build & Push - latest_nohealthcheck
uses: docker/build-push-action@v3
with:
context: .
file: ./Dockerfile
no-cache: true
platforms: linux/amd64,linux/arm/v7,linux/arm64
push: true
tags: ghcr.io/${{ env.GHCR_IMAGE }}:latest_nohealthcheck
labels: ${{ steps.meta.outputs.labels }}
# ------------------------------------------------------------------------------------------------------------------------
deploy_ghcr_multiarch_telegraf:
name: Deploy telegraf to ghcr.io (Multi-Arch)
needs: [hadolint]
runs-on: ubuntu-latest
permissions:
packages: write
steps:
# Check out our code
- name: Checkout
uses: actions/checkout@v3
with:
fetch-depth: 0
ref: ${{ env.GH_LABEL }}
# Log into ghcr (so we can push images)
- name: Login to ghcr.io
uses: docker/login-action@v2
with:
registry: ${{ env.GHCR_REGISTRY }}
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
# Get metadata from repo
- name: Extract metadata (tags, labels) for Docker
id: meta
uses: docker/metadata-action@v4
with:
images: ${{ env.GHCR_REGISTRY }}/${{ env.IMAGE_NAME }}
# Set up QEMU for multi-arch builds
- name: Set up QEMU
uses: docker/setup-qemu-action@v2
# Set up buildx for multi platform builds
- name: Set up Docker Buildx
id: buildx
uses: docker/setup-buildx-action@v2
with:
driver-opts: image=moby/buildkit:v0.10.6
# Change Dockerfile to use telegraf tag of build image:
- name: change build image to use telegraf tag of docker-docker-tar1090
run: |
sed -i "s|FROM ghcr.io/sdr-enthusiasts/docker-tar1090:latest|FROM ghcr.io/sdr-enthusiasts/docker-tar1090:telegraf|g" ./Dockerfile
# Build "telegraf"
- name: Build & Push - telegraf
uses: docker/build-push-action@v3
with:
context: .
file: ./Dockerfile
no-cache: true
platforms: linux/amd64,linux/arm/v7,linux/arm64
push: true
tags: ghcr.io/${{ env.GHCR_IMAGE }}:telegraf
labels: ${{ steps.meta.outputs.labels }}
# ------------------------------------------------------------------------------------------------------------------------
deploy_ghcr_multiarch_telegraf_nohealthcheck:
name: Deploy telegraf_nohealthcheck to ghcr.io (Multi-Arch)
needs: [hadolint]
runs-on: ubuntu-latest
permissions:
packages: write
steps:
# Check out our code
- name: Checkout
uses: actions/checkout@v3
with:
fetch-depth: 0
ref: ${{ env.GH_LABEL }}
# Log into ghcr (so we can push images)
- name: Login to ghcr.io
uses: docker/login-action@v2
with:
registry: ${{ env.GHCR_REGISTRY }}
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
# Get metadata from repo
- name: Extract metadata (tags, labels) for Docker
id: meta
uses: docker/metadata-action@v4
with:
images: ${{ env.GHCR_REGISTRY }}/${{ env.IMAGE_NAME }}
# Set up QEMU for multi-arch builds
- name: Set up QEMU
uses: docker/setup-qemu-action@v2
# Set up buildx for multi platform builds
- name: Set up Docker Buildx
id: buildx
uses: docker/setup-buildx-action@v2
with:
driver-opts: image=moby/buildkit:v0.10.6
# Change Dockerfile to use telegraf_nohealthcheck tag of build image:
- name: change build image to use telegraf_nohealthcheck tag of docker-docker-tar1090
run: |
sed -i "s|FROM ghcr.io/sdr-enthusiasts/docker-tar1090:latest|FROM ghcr.io/sdr-enthusiasts/docker-tar1090:telegraf_nohealthcheck|g" ./Dockerfile
# Build "telegraf_nohealthcheck"
- name: Build & Push - telegraf_nohealthcheck
uses: docker/build-push-action@v3
with:
context: .
file: ./Dockerfile
no-cache: true
platforms: linux/amd64,linux/arm/v7,linux/arm64
push: true
tags: ghcr.io/${{ env.GHCR_IMAGE }}:telegraf_nohealthcheck
labels: ${{ steps.meta.outputs.labels }}