techblog/.forgejo/workflows/docker-build.yml

60 lines
1.6 KiB
YAML
Raw Normal View History

2026-03-31 02:54:47 +00:00
name: Build and Push Docker Image
on:
push:
branches:
- main
workflow_dispatch:
jobs:
build-and-push:
runs-on: ubuntu-latest
permissions:
packages: write
contents: read
2026-03-31 02:54:47 +00:00
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Show commit and Dockerfile
run: git log --oneline -1 && echo "---" && head -35 Dockerfile
2026-03-31 15:49:04 +00:00
- name: Clear Docker build cache
run: docker builder prune -af
2026-03-31 02:54:47 +00:00
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Derive registry from server URL
run: |
REGISTRY=$(echo "${{ github.server_url }}" | sed 's|https://||' | sed 's|http://||')
echo "REGISTRY=${REGISTRY}" >> $GITHUB_ENV
echo "IMAGE=${REGISTRY}/${{ github.repository }}" >> $GITHUB_ENV
- name: Log in to Forgejo container registry
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.actor }}
password: ${{ secrets.REGISTRY_TOKEN }}
2026-03-31 02:54:47 +00:00
- name: Extract metadata (tags, labels)
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.IMAGE }}
tags: |
type=sha,prefix=,format=short
type=raw,value=latest,enable={{is_default_branch}}
- name: Build and push Docker image
uses: docker/build-push-action@v5
with:
context: .
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
2026-03-31 04:06:02 +00:00
secrets: |
composer_auth=${{ secrets.COMPOSER_AUTH }}
2026-03-31 04:11:41 +00:00
no-cache: true