Use a docker build action that supports proper tagging.

This commit is contained in:
Jan Böhmer 2021-03-14 19:51:47 +01:00
parent 4c46b983a8
commit 04c9700056

View file

@ -1,7 +1,14 @@
name: Docker Image Build name: Docker Image Build
on: on:
schedule:
- cron: '0 10 * * *' # everyday at 10am
push: push:
branches:
- '**'
tags:
- 'v*.*.*'
pull_request:
branches: branches:
- 'master' - 'master'
@ -9,6 +16,20 @@ jobs:
docker: docker:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
-
name: Checkout
uses: actions/checkout@v2
-
name: Docker meta
id: docker_meta
uses: crazy-max/ghaction-docker-meta@v1
with:
# list of Docker images to use as base name for tags
images: |
jbtronics/part-db1
ghcr.io/Part-DB/part-db1
# add git short SHA as Docker tag
tag-sha: true
- -
name: Set up QEMU name: Set up QEMU
uses: docker/setup-qemu-action@v1 uses: docker/setup-qemu-action@v1
@ -17,17 +38,24 @@ jobs:
uses: docker/setup-buildx-action@v1 uses: docker/setup-buildx-action@v1
- -
name: Login to DockerHub name: Login to DockerHub
if: github.event_name != 'pull_request'
uses: docker/login-action@v1 uses: docker/login-action@v1
with: with:
username: ${{ secrets.DOCKERHUB_USERNAME }} username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }} password: ${{ secrets.DOCKERHUB_TOKEN }}
-
name: Login to GHCR
if: github.event_name != 'pull_request'
uses: docker/login-action@v1
with:
registry: ghcr.io
username: ${{ secrets.GHCR_USERNAME }}
password: ${{ secrets.GHCR_TOKEN }}
- -
name: Build and push name: Build and push
id: docker_build
uses: docker/build-push-action@v2 uses: docker/build-push-action@v2
with: with:
push: true context: .
tags: jbtronics/part-db1:latest push: ${{ github.event_name != 'pull_request' }}
- tags: ${{ steps.docker_meta.outputs.tags }}
name: Image digest labels: ${{ steps.docker_meta.outputs.labels }}
run: echo ${{ steps.docker_build.outputs.digest }}