Files
privoxy-docker/.gitea/workflows/build-docker.yml
thuanle e34337e6cc
All checks were successful
Weekly Docker Build / build (arm64) (push) Successful in 11s
Weekly Docker Build / build (amd64) (push) Successful in 26s
Weekly Docker Build / amend-manifest (push) Successful in 6s
Add push trigger to weekly Docker build workflow
Remove redundant COPY command from Dockerfile
2025-07-11 12:16:18 +07:00

66 lines
1.9 KiB
YAML

name: Weekly Docker Build
on:
push:
schedule:
- cron: '0 0 * * 0' # 00:00 sáng Chủ nhật hằng tuần (UTC)
workflow_dispatch: # Cho phép chạy tay nếu cần
env:
IMAGE_PATH: git.thuanle.me/public/privoxy-docker
jobs:
build:
strategy:
matrix:
arch:
- amd64
- arm64
runs-on: ${{ matrix.arch }}
steps:
- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0 # Fetch full history, keeping all commits
- name: Login to Docker Registry
uses: docker/login-action@v3
with:
registry: git.thuanle.me
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Build Docker images
run: |
echo "Building image for architecture: ${{ matrix.arch }}"
docker build \
-t ${{ env.IMAGE_PATH }}:${{ matrix.arch }}-latest \
--label "build_date=$(date -u +'%Y-%m-%dT%H:%M:%SZ')" \
--label "commit_sha=${{ github.sha }}" \
.
docker push ${{ env.IMAGE_PATH }}:${{ matrix.arch }}-latest
amend-manifest:
runs-on: ubuntu-latest
needs: [build]
steps:
- name: Login to Docker Registry
uses: docker/login-action@v3
with:
registry: git.thuanle.me
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Push Docker manifest
run: |
echo "Delete existing manifest"
docker manifest rm ${{ env.IMAGE_PATH }}:latest || true
echo "Create new manifest"
docker manifest create ${{ env.IMAGE_PATH }}:latest \
${{ env.IMAGE_PATH }}:amd64-latest \
${{ env.IMAGE_PATH }}:arm64-latest
docker manifest push ${{ env.IMAGE_PATH }}:latest