updated CI

This commit is contained in:
Chris 2023-11-13 10:00:16 +01:00
parent 8f46510eb7
commit d1f37d7f95

View file

@ -1,90 +1,59 @@
name: opentrashmail ci name: ci
on: on:
push: push:
branches: [ master ] branches:
- "**"
tags:
- "v*.*.*"
pull_request: pull_request:
branches: [ master ] branches:
- "main"
env:
IMAGE_NAME: $(echo ${{ github.repository }} | tr '[:upper:]' '[:lower:]')
jobs: jobs:
docker: docker:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- name: Checkout - name: Checkout
uses: actions/checkout@v2 uses: actions/checkout@v4
- name: Docker meta
- name: Prepare id: meta
id: prep uses: docker/metadata-action@v5
run: | with:
DOCKER_IMAGE="ghcr.io/${{ env.IMAGE_NAME }}" # list of Docker images to use as base name for tags
DOCKER_IMAGE_HUB="docker.io/${{ env.IMAGE_NAME }}" images: |
VERSION=latest hascheksolutions/opentrashmail
SHORTREF=${GITHUB_SHA::8} ghcr.io/hascheksolutions/opentrashmail
# generate Docker tags based on the following events/attributes
# If this is git tag, use the tag name as a docker tag tags: |
if [[ $GITHUB_REF == refs/tags/* ]]; then type=schedule
VERSION=${GITHUB_REF#refs/tags/v} type=ref,event=branch
fi type=ref,event=pr
TAGS="${DOCKER_IMAGE}:${VERSION},${DOCKER_IMAGE}:${SHORTREF}" type=semver,pattern={{version}}
TAGS_HUB="${DOCKER_IMAGE_HUB}:${VERSION},${DOCKER_IMAGE_HUB}:${SHORTREF}" type=semver,pattern={{major}}.{{minor}}
type=semver,pattern={{major}}
# If the VERSION looks like a version number, assume that type=sha
# this is the most recent version of the image and also
# tag it 'latest'.
if [[ $VERSION =~ ^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$ ]]; then
TAGS="$TAGS,${DOCKER_IMAGE}:latest"
TAGS_HUB="$TAGS_HUB,${DOCKER_IMAGE_HUB}:latest"
fi
# Set output parameters.
echo ::set-output name=tags::${TAGS}
echo ::set-output name=docker_image::${DOCKER_IMAGE}
echo ::set-output name=tags_hub::${TAGS_HUB}
echo ::set-output name=docker_image_hub::${DOCKER_IMAGE_HUB}
- name: Set up QEMU - name: Set up QEMU
uses: docker/setup-qemu-action@master uses: docker/setup-qemu-action@v3
with:
platforms: all
- name: Set up Docker Buildx - name: Set up Docker Buildx
id: buildx uses: docker/setup-buildx-action@v3
uses: docker/setup-buildx-action@master
- name: Log in to Github Packages
uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Login to Docker Hub - name: Login to Docker Hub
uses: docker/login-action@v2 if: github.event_name != 'pull_request'
uses: docker/login-action@v3
with: with:
registry: docker.io
username: ${{ secrets.DOCKER_USERNAME }} username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }} password: ${{ secrets.DOCKER_PASSWORD }}
- name: Login to GHCR
- name: Build and push to GHCR if: github.event_name != 'pull_request'
uses: docker/build-push-action@v2 uses: docker/login-action@v3
with: with:
builder: ${{ steps.buildx.outputs.name }} registry: ghcr.io
context: . username: ${{ github.repository_owner }}
file: docker/Dockerfile password: ${{ secrets.GITHUB_TOKEN }}
platforms: linux/amd64,linux/arm64 - name: Build and push
push: true uses: docker/build-push-action@v5
tags: ${{ steps.prep.outputs.tags }}
- name: Build and push to Docker Hub
uses: docker/build-push-action@v2
with: with:
builder: ${{ steps.buildx.outputs.name }}
context: . context: .
file: docker/Dockerfile push: ${{ github.event_name != 'pull_request' }}
platforms: linux/amd64,linux/arm64 tags: ${{ steps.meta.outputs.tags }}
push: true labels: ${{ steps.meta.outputs.labels }}
tags: ${{ steps.prep.outputs.tags_hub }}