Skip to content

Nightly Build and Push #1

Nightly Build and Push

Nightly Build and Push #1

Workflow file for this run

name: Nightly Build and Push
on:
schedule:
- cron: '0 0 * * *' # Runs at 00:00 UTC every day
env:
REGISTRY: ghcr.io
IMAGE_NAME: ${{ github.repository }}
jobs:
build-push:
name: Build and Push Multi-Arch Image
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps:
- name: Checkout code
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Free up disk space
run: |
sudo rm -rf /usr/share/dotnet
sudo rm -rf /usr/local/lib/android
sudo rm -rf /opt/ghc
sudo rm -rf /opt/hostedtoolcache
df -h
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Log in to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Extract metadata
id: meta
run: |
GIT_SHA=$(git rev-parse --short HEAD)
BUILD_TIMESTAMP=$(date +"%Y%m%d%H%M%S")
echo "git_sha=${GIT_SHA}" >> $GITHUB_OUTPUT
echo "build_timestamp=${BUILD_TIMESTAMP}" >> $GITHUB_OUTPUT
- name: Build and push image
uses: docker/build-push-action@v6
with:
context: .
target: prod
platforms: linux/amd64,linux/arm64
push: true
tags: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:main
labels: |
org.opencontainers.image.revision=${{ steps.meta.outputs.git_sha }}
org.opencontainers.image.created=${{ steps.meta.outputs.build_timestamp }}