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:
parent
50510a3320
commit
6651974bb8
1 changed files with 59 additions and 231 deletions
290
.github/workflows/deploy.yml
vendored
290
.github/workflows/deploy.yml
vendored
|
@ -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
|
with:
|
||||||
permissions:
|
push_enabled: true
|
||||||
packages: write
|
push_destinations: ghcr.io
|
||||||
steps:
|
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 }}
|
||||||
|
|
||||||
# Check out our code
|
# unfortunately we can't use build_and_push_image.yml to build the telegraf label because
|
||||||
- name: Checkout
|
# that GH Action doesn't have the capability to build specific custom-named labels
|
||||||
uses: actions/checkout@v3
|
|
||||||
with:
|
|
||||||
fetch-depth: 0
|
|
||||||
ref: ${{ env.GH_LABEL }}
|
|
||||||
|
|
||||||
# Log into ghcr (so we can push images)
|
deploy_with_telegraf:
|
||||||
- name: Login to ghcr.io
|
name: Deploy with telegraf and healthcheck
|
||||||
uses: docker/login-action@v2
|
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 }}
|
|
||||||
|
|
Loading…
Reference in a new issue