| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 |
- 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@v3
- 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@v2
- - name: Set up Docker Buildx
- uses: docker/setup-buildx-action@v2
- - name: Login to DockerHub
- uses: docker/login-action@v2
- with:
- username: ${{ secrets.DOCKERHUB_USERNAME }}
- password: ${{ secrets.DOCKERHUB_TOKEN }}
- - name: Login to GitHub Container Registry
- uses: docker/login-action@v2
- with:
- registry: ghcr.io
- username: ${{ github.repository_owner }}
- password: ${{ secrets.CR_PAT }}
- - name: Build and Push Alpine images
- uses: docker/build-push-action@v3
- 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@v3
- with:
- context: .
- file: ./packaging/docker/distroless/Dockerfile
- platforms: linux/amd64,linux/arm64
- push: true
- tags: ${{ steps.docker_distroless_tag.outputs.tags }}
|