Skip to content

Publish Docker Image (GPR) #3985

Publish Docker Image (GPR)

Publish Docker Image (GPR) #3985

name: Publish Docker Image (GPR)
on:
workflow_dispatch:
schedule:
- cron: '*/5 * * * *'
env:
REGISTRY: ghcr.io
IMAGE_NAME: ${{ github.repository }}
APP_ID: 232250
REMOTE_BUILDID: 0
TAG_EXISTS: 'false'
TAG: null
jobs:
build:
runs-on: ubuntu-latest
timeout-minutes: 45
strategy:
matrix:
tag: [latest, slim]
steps:
- uses: actions/checkout@v4
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Build (Dockerfile.buildid) with retries
run: |
for i in {1..3}; do
timeout 300 docker build --no-cache -f Dockerfile.buildid -t remote-buildid:${{ env.APP_ID }} --build-arg APP_ID=${{ env.APP_ID }} . && break || sleep 10
done
- name: Find the Remote buildid
id: remote-buildid
run: |
REMOTE_BUILDID=$(docker run --rm remote-buildid:${{ env.APP_ID }})
echo "REMOTE_BUILDID=$REMOTE_BUILDID" >> $GITHUB_ENV
if [ "${{ matrix.tag }}" == "latest" ]; then
echo "TAG=${REMOTE_BUILDID}" >> $GITHUB_ENV
else
echo "TAG=${REMOTE_BUILDID}-${{ matrix.tag }}" >> $GITHUB_ENV
fi
- name: Remove Docker image
run: docker rmi remote-buildid:${{ env.APP_ID }}
- name: Free up disk space
run: |
sudo rm -rf /usr/local/lib/android || true
sudo rm -rf /usr/share/dotnet || true
sudo rm -rf "$AGENT_TOOLSDIRECTORY" || true
- name: Check if tag exists
if: github.event_name != 'workflow_dispatch'
id: tag-exists
run: |
if docker pull ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ env.TAG }}; then
echo "TAG_EXISTS=true" >> $GITHUB_ENV
fi
- name: Log in to the Container registry
if: env.TAG_EXISTS == 'false' || github.event_name == 'workflow_dispatch'
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Extract metadata (tags, labels) for Docker
if: env.TAG_EXISTS == 'false' || github.event_name == 'workflow_dispatch'
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
tags: |
type=raw,value=${{ matrix.tag }}
type=raw,value=${{ env.TAG }}
- name: Push Docker image
if: env.TAG_EXISTS == 'false' || github.event_name == 'workflow_dispatch'
uses: docker/build-push-action@v6
with:
context: .
push: true
provenance: false
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
annotations: ${{ steps.meta.outputs.annotations }}
build-args: |
TAG=${{ matrix.tag }}
REMOTE_BUILDID=${{ env.REMOTE_BUILDID }}