cf96ab45c1
Being able to functionaly utilize the same GH Docker action can be beneficial for users wanting to build, test and develop in their own repos. To do so, use ${{ github.repository_owner }} in the action. That should provide some rudimentary flexibility without breaking the canonical repo. Users of this functionality should take care to populate the required secrets in Github * DOCKERHUB_TOKEN, DOCKERHUB_USERNAME * CR_PAT
81 lines
2.8 KiB
YAML
81 lines
2.8 KiB
YAML
name: Docker
|
|
permissions: read-all
|
|
on:
|
|
schedule:
|
|
- cron: '0 1 * * *'
|
|
push:
|
|
tags:
|
|
- '*.*.*'
|
|
jobs:
|
|
docker-images:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v2
|
|
with:
|
|
fetch-depth: 0
|
|
|
|
- name: Generate Alpine Docker tag
|
|
id: docker_alpine_tag
|
|
run: |
|
|
DOCKER_IMAGE=${{ github.repository_owner }}/miniflux
|
|
DOCKER_VERSION=dev
|
|
if [ "${{ github.event_name }}" = "schedule" ]; then
|
|
DOCKER_VERSION=nightly
|
|
TAGS="${DOCKER_IMAGE}:${DOCKER_VERSION},ghcr.io/${DOCKER_IMAGE}:${DOCKER_VERSION}"
|
|
elif [[ $GITHUB_REF == refs/tags/* ]]; then
|
|
DOCKER_VERSION=${GITHUB_REF#refs/tags/}
|
|
TAGS="${DOCKER_IMAGE}:${DOCKER_VERSION},ghcr.io/${DOCKER_IMAGE}:${DOCKER_VERSION},${DOCKER_IMAGE}:latest,ghcr.io/${DOCKER_IMAGE}:latest"
|
|
fi
|
|
echo ::set-output name=tags::${TAGS}
|
|
|
|
- name: Generate Distroless Docker tag
|
|
id: docker_distroless_tag
|
|
run: |
|
|
DOCKER_IMAGE=${{ github.repository_owner }}/miniflux
|
|
DOCKER_VERSION=dev-distroless
|
|
if [ "${{ github.event_name }}" = "schedule" ]; then
|
|
DOCKER_VERSION=nightly-distroless
|
|
TAGS="${DOCKER_IMAGE}:${DOCKER_VERSION},ghcr.io/${DOCKER_IMAGE}:${DOCKER_VERSION}"
|
|
elif [[ $GITHUB_REF == refs/tags/* ]]; then
|
|
DOCKER_VERSION=${GITHUB_REF#refs/tags/}-distroless
|
|
TAGS="${DOCKER_IMAGE}:${DOCKER_VERSION},ghcr.io/${DOCKER_IMAGE}:${DOCKER_VERSION},${DOCKER_IMAGE}:latest-distroless,ghcr.io/${DOCKER_IMAGE}:latest-distroless"
|
|
fi
|
|
echo ::set-output name=tags::${TAGS}
|
|
|
|
- name: Set up QEMU
|
|
uses: docker/setup-qemu-action@v1
|
|
|
|
- name: Set up Docker Buildx
|
|
uses: docker/setup-buildx-action@v1
|
|
|
|
- name: Login to DockerHub
|
|
uses: docker/login-action@v1
|
|
with:
|
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
|
|
- name: Login to GitHub Container Registry
|
|
uses: docker/login-action@v1
|
|
with:
|
|
registry: ghcr.io
|
|
username: ${{ github.repository_owner }}
|
|
password: ${{ secrets.CR_PAT }}
|
|
|
|
- name: Build and Push Alpine images
|
|
uses: docker/build-push-action@v2
|
|
with:
|
|
context: .
|
|
file: ./packaging/docker/alpine/Dockerfile
|
|
platforms: linux/amd64,linux/arm/v6,linux/arm/v7,linux/arm64
|
|
push: true
|
|
tags: ${{ steps.docker_alpine_tag.outputs.tags }}
|
|
|
|
- name: Build and Push Distroless images
|
|
uses: docker/build-push-action@v2
|
|
with:
|
|
context: .
|
|
file: ./packaging/docker/distroless/Dockerfile
|
|
platforms: linux/amd64,linux/arm64
|
|
push: true
|
|
tags: ${{ steps.docker_distroless_tag.outputs.tags }}
|