p2pool/.forgejo/workflows/package-check.yml

78 lines
2.6 KiB
YAML

name: Alpine Package Auto-Rebuild
on:
workflow_dispatch:
schedule:
- cron: '0 1 * * *'
env:
PACKAGE: curl
DOCKER_REGISTRY: git.shork.ch
REGISTRY_USER: melody
COMMIT_AUTHOR_NAME: "forgejo-runner"
COMMIT_AUTHOR_EMAIL: "forgejo-runner@shork.ch"
COMMIT_MESSAGE: "Update build metadata"
jobs:
build:
runs-on: dind
steps:
- name: Install dependencies
shell: sh
run: apk add --no-cache git nodejs npm bash sed $PACKAGE
- uses: actions/checkout@v3
- name: Get latest package version
id: check
run: |
LATEST=$(apk policy "$PACKAGE" | awk '/^[[:space:]]*[0-9]/ { gsub(":", "", $1); print $1; exit }')
echo "LATEST_VERSION=$LATEST" >> $GITHUB_ENV
echo "latest_version=$LATEST" >> $GITHUB_OUTPUT
- name: Determine if update is needed
run: |
last_version_file=".last_version"
last_rebuild_file=".last_rebuild"
last_version=$(cat $last_version_file 2>/dev/null || echo "none")
last_rebuild=$(cat $last_rebuild_file 2>/dev/null || echo 0)
current_day=$(( $(date +%s) / 86400 ))
update="false"
if [ "$last_version" != "$LATEST_VERSION" ] || [ $((current_day - last_rebuild)) -gt 3 ]; then
update="true"
fi
echo "UPDATE=$update" >> $GITHUB_ENV
- name: Start Docker daemon
if: env.UPDATE == 'true'
run: |
dockerd-entrypoint.sh &
for i in {1..10}; do
docker info && break
echo "Waiting for Docker daemon..."
sleep 3
done
docker info || { echo "Docker daemon failed to start."; exit 1; }
- name: Build and push Docker image
if: env.UPDATE == 'true'
run: |
docker build -t $DOCKER_REGISTRY/$REGISTRY_USER/docker-$PACKAGE:latest -t $DOCKER_REGISTRY/$REGISTRY_USER/docker-$PACKAGE:$LATEST_VERSION .
echo "${{ secrets.DOCKER_PASSWORD }}" | docker login $DOCKER_REGISTRY -u "${{ secrets.DOCKER_USERNAME }}" --password-stdin
docker push $DOCKER_REGISTRY/$REGISTRY_USER/docker-$PACKAGE:latest
docker push $DOCKER_REGISTRY/$REGISTRY_USER/docker-$PACKAGE:$LATEST_VERSION
echo "$LATEST_VERSION" > .last_version
echo $(( $(date +%s) / 86400 )) > .last_rebuild
- name: Commit updated metadata
if: env.UPDATE == 'true'
run: |
git config user.name $COMMIT_AUTHOR_NAME
git config user.email $COMMIT_AUTHOR_EMAIL
git add .last_version .last_rebuild
git commit -m $COMMIT_MESSAGE
git push