From 57e31226146560fef12c033cef4a99fb70757c01 Mon Sep 17 00:00:00 2001 From: melody Date: Mon, 7 Jul 2025 01:11:15 +0200 Subject: [PATCH] Update .forgejo/workflows/package-check.yml --- .forgejo/workflows/package-check.yml | 69 +++------------------------- 1 file changed, 6 insertions(+), 63 deletions(-) diff --git a/.forgejo/workflows/package-check.yml b/.forgejo/workflows/package-check.yml index 12d002b..e29ea9f 100644 --- a/.forgejo/workflows/package-check.yml +++ b/.forgejo/workflows/package-check.yml @@ -1,16 +1,15 @@ -name: Auto Build Docker Container From Alpine PKG +name: Build monero node on: workflow_dispatch: - schedule: - - cron: '12 */3 * * *' + jobs: build: runs-on: dind env: - PACKAGE: rsync + PACKAGE: monero DOCKER_REGISTRY: git.shork.ch REGISTRY_USER: melody COMMIT_AUTHOR_NAME: "forgejo-runner" @@ -21,54 +20,10 @@ jobs: - name: Install dependencies shell: sh run: | - apk add --no-cache git nodejs npm bash sed curl $PACKAGE - - - uses: actions/checkout@v3 - - - name: Get latest package version - id: check - run: | - main_version=$(curl -s https://dl-cdn.alpinelinux.org/alpine/edge/main/x86_64/APKINDEX.tar.gz \ - | tar -xzO \ - | awk '$0=="P:rsync" { getline; if ($0 ~ /^V:/) print substr($0,3) }' \ - | sort -V | tail -n 1) - - community_version=$(curl -s https://dl-cdn.alpinelinux.org/alpine/edge/community/x86_64/APKINDEX.tar.gz \ - | tar -xzO \ - | awk '$0=="P:rsync" { getline; if ($0 ~ /^V:/) print substr($0,3) }' \ - | sort -V | tail -n 1) - - testing_version=$(curl -s https://dl-cdn.alpinelinux.org/alpine/edge/testing/x86_64/APKINDEX.tar.gz \ - | tar -xzO \ - | awk '$0=="P:rsync" { getline; if ($0 ~ /^V:/) print substr($0,3) }' \ - | sort -V | tail -n 1) - - newest_version=$(echo -e "$main_version\n$community_version\n$testing_version" | sort -V | tail -n 1) - - echo "NEWEST_VERSION=$newest_version" >> $GITHUB_ENV - - - name: Determine if update is needed - run: | - last_version_file=".last_version" - last_rebuild_file=".last_rebuild" - last_dockerfile_hash_file=".dockerfile_hash" - - last_version=$(cat $last_version_file 2>/dev/null || echo "none") - last_rebuild=$(cat $last_rebuild_file 2>/dev/null || echo 0) - last_dockerfile_hash=$(cat $last_dockerfile_hash_file 2>/dev/null || echo "none") - dockerfile_hash=$(sha256sum Dockerfile | awk '{print $1}' || echo "nuh") - current_day=$(( $(date +%s) / 86400 )) - - update="false" - if [ "$last_version" != "$NEWEST_VERSION" ] || [ "$last_dockerfile_hash" != "$dockerfile_hash" ] || [ $((current_day - last_rebuild)) -gt 3 ]; then - update="true" - fi - - echo "UPDATE=$update" >> $GITHUB_ENV - echo "DOCKERFILE_HASH=$dockerfile_hash" >> $GITHUB_ENV + apk add --no-cache git bash && \ + git clone https://github.com/monero-project/monero - name: Start Docker daemon - if: env.UPDATE == 'true' run: | dockerd-entrypoint.sh & for i in {1..10}; do @@ -79,21 +34,9 @@ jobs: 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:$NEWEST_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:$NEWEST_VERSION - echo "$NEWEST_VERSION" > .last_version - echo $(( $(date +%s) / 86400 )) > .last_rebuild - echo "$DOCKERFILE_HASH" > .dockerfile_hash - - - 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 .dockerfile_hash - git commit -m "$COMMIT_MESSAGE" - git push +