GPG Data Container Image Builds #100
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: GPG Data Container Image Builds | |
on: | |
push: | |
branches: [ main ] | |
tags: ["v*"] | |
path: | |
- gpg-data/* | |
- .github/workflows/container-gpg-data.yml | |
pull_request: | |
branches: [ main ] | |
path: | |
- gpg-data/* | |
- .github/workflows/container-gpg-data.yml | |
workflow_dispatch: | |
schedule: | |
# rebuild image every sunday | |
- cron: "0 0 * * 0" | |
jobs: | |
gpg-data-images: | |
name: Build and upload container images with gpg data | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Login to Docker Registry | |
uses: docker/login-action@v3 | |
if: github.event_name != 'pull_request' | |
with: | |
username: ${{ secrets.DOCKERHUB_USERNAME }} | |
password: ${{ secrets.DOCKERHUB_TOKEN }} | |
- name: Setup container meta information | |
id: meta | |
uses: docker/metadata-action@v5 | |
with: | |
images: greenbone/gpg-data | |
labels: | | |
org.opencontainers.image.vendor=Greenbone | |
org.opencontainers.image.documentation=https://greenbone.github.io/docs/ | |
org.opencontainers.image.base.name=busybox:stable | |
flavor: latest=false # no latest container tag for git tags | |
tags: | | |
# create container tag for git tags | |
type=ref,event=tag | |
type=ref,event=pr | |
# set latest for main branch pushes | |
type=raw,value=latest,enable={{is_default_branch}} | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@v3 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Build and push Container image | |
uses: docker/build-push-action@v5 | |
with: | |
context: gpg-data | |
push: ${{ github.event_name != 'pull_request' }} | |
file: gpg-data/Dockerfile | |
platforms: linux/amd64,linux/arm64 | |
labels: ${{ steps.meta.outputs.labels }} | |
tags: ${{ steps.meta.outputs.tags }} |