diff --git a/.gitea/workflows/base-build.yml b/.gitea/workflows/base-build.yml index 7c9d8c7..6d1fbee 100644 --- a/.gitea/workflows/base-build.yml +++ b/.gitea/workflows/base-build.yml @@ -1,60 +1,172 @@ -name: Build and Push Minecraft Docker Images +name: Build and Push Minecraft Docker Images on Debian-base update on: push: branches: - master + schedule: + - cron: '0 */6 * * *' # every 6 hours; adjust as you want + +env: + IMAGE_REGISTRY: gitea.fithwum.tech + IMAGE_ORG: fithwum + IMAGE_REPO_DEBIAN: debian-base + IMAGE_REPO_MINECRAFT: minecraft + IMAGE_TAG_DEBIAN: bookworm jobs: - build: + poll-debian-base-and-build: runs-on: docker-build steps: - - name: Checkout code + - name: Checkout repo (to read/write digest file) uses: actions/checkout@v3 - - name: Set image tags and names - id: vars - run: | - IMAGE_REGISTRY=gitea.fithwum.tech - IMAGE_ORG=fithwum - IMAGE_REPO=minecraft - - # Set the tag based on the folder name (vanilla, TESTING, fabric) - IMAGE_TAG_VANILLA=vanilla - IMAGE_TAG_TESTING=testing - IMAGE_TAG_FABRIC=fabric - - echo "IMAGE_TAG_VANILLA=${IMAGE_TAG_VANILLA}" >> $GITHUB_ENV - echo "IMAGE_TAG_TESTING=${IMAGE_TAG_TESTING}" >> $GITHUB_ENV - echo "IMAGE_TAG_FABRIC=${IMAGE_TAG_FABRIC}" >> $GITHUB_ENV - - # Set image names for each subfolder Dockerfile - IMAGE_VANILLA=${IMAGE_REGISTRY}/${IMAGE_ORG}/${IMAGE_REPO}:${IMAGE_TAG_VANILLA} - IMAGE_TESTING=${IMAGE_REGISTRY}/${IMAGE_ORG}/${IMAGE_REPO}:${IMAGE_TAG_TESTING} - IMAGE_FABRIC=${IMAGE_REGISTRY}/${IMAGE_ORG}/${IMAGE_REPO}:${IMAGE_TAG_FABRIC} - - echo "IMAGE_VANILLA=${IMAGE_VANILLA}" >> $GITHUB_ENV - echo "IMAGE_TESTING=${IMAGE_TESTING}" >> $GITHUB_ENV - echo "IMAGE_FABRIC=${IMAGE_FABRIC}" >> $GITHUB_ENV - - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v3 - - name: Log in to Gitea Registry - run: echo "${{ secrets.DOCKER_PASSWORD }}" | docker login gitea.fithwum.tech -u "${{ secrets.DOCKER_USERNAME }}" --password-stdin + run: echo "${{ secrets.DOCKER_PASSWORD }}" | docker login ${{ env.IMAGE_REGISTRY }} -u "${{ secrets.DOCKER_USERNAME }}" --password-stdin - # Build and Push Vanilla Docker Image - - name: Build and Push Vanilla Docker Image + - name: Get current digest of debian-base image + id: get_digest run: | - docker buildx build --platform linux/amd64 --push -t ${{ env.IMAGE_VANILLA }} ./vanilla + IMAGE="${{ env.IMAGE_REGISTRY }}/${{ env.IMAGE_ORG }}/${{ env.IMAGE_REPO_DEBIAN }}:${{ env.IMAGE_TAG_DEBIAN }}" + echo "Checking image: $IMAGE" + DIGEST=$(docker inspect --format='{{index .RepoDigests 0}}' "$IMAGE" 2>/dev/null || echo "unknown") + if [ "$DIGEST" = "unknown" ]; then + echo "Failed to get digest for $IMAGE" + exit 1 + fi + echo "digest=$DIGEST" >> $GITHUB_OUTPUT - # Build and Push Testing Docker Image - - name: Build and Push Testing Docker Image + - name: Compare with stored digest + id: compare_digest run: | - docker buildx build --platform linux/amd64 --push -t ${{ env.IMAGE_TESTING }} ./testing + LAST_DIGEST_FILE=debian-base-digest.txt + CURRENT_DIGEST="${{ steps.get_digest.outputs.digest }}" - # Build and Push Fabric Docker Image - - name: Build and Push Fabric Docker Image + if [ -f "$LAST_DIGEST_FILE" ]; then + LAST_DIGEST=$(cat "$LAST_DIGEST_FILE") + echo "Last digest: $LAST_DIGEST" + else + LAST_DIGEST="" + fi + + echo "Current digest: $CURRENT_DIGEST" + + if [ "$CURRENT_DIGEST" = "$LAST_DIGEST" ]; then + echo "Digest unchanged. Skipping build." + echo "changed=false" >> $GITHUB_OUTPUT + exit 0 + else + echo "Digest changed or first run." + echo "$CURRENT_DIGEST" > "$LAST_DIGEST_FILE" + git config user.name "${{ secrets.GIT_USERNAME }}" + git config user.email "${{ secrets.GIT_EMAIL }}" + git add "$LAST_DIGEST_FILE" + git commit -m "Update debian-base image digest to $CURRENT_DIGEST" + git push + echo "changed=true" >> $GITHUB_OUTPUT + fi + + - name: Build and Push Minecraft Docker Images + if: steps.compare_digest.outputs.changed == 'true' + env: + IMAGE_REGISTRY: ${{ env.IMAGE_REGISTRY }} + IMAGE_ORG: ${{ env.IMAGE_ORG }} + IMAGE_REPO: ${{ env.IMAGE_REPO_MINECRAFT }} + IMAGE_TAG_VANILLA: vanilla + IMAGE_TAG_TESTING: testing + IMAGE_TAG_FABRIC: fabric + DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} + DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }} run: | - docker buildx build --platform linux/amd64 --push -t ${{ env.IMAGE_FABRIC }} ./fabric + echo "${DOCKER_PASSWORD}" | docker login $IMAGE_REGISTRY -u "${DOCKER_USERNAME}" --password-stdin + + for TAG in $IMAGE_TAG_VANILLA $IMAGE_TAG_TESTING $IMAGE_TAG_FABRIC; do + IMAGE="$IMAGE_REGISTRY/$IMAGE_ORG/$IMAGE_REPO:$TAG" + echo "[INFO] Building and pushing $IMAGE" + docker buildx build --platform linux/amd64 --push -t "$IMAGE" "./$TAG" + done + + + + + + + + + + + + + + + + + + + + + + + + +# name: Build and Push Minecraft Docker Images + +# on: +# push: +# branches: +# - master + +# jobs: +# build: +# runs-on: docker-build + +# steps: +# - name: Checkout code +# uses: actions/checkout@v3 + +# - name: Set image tags and names +# id: vars +# run: | +# IMAGE_REGISTRY=gitea.fithwum.tech +# IMAGE_ORG=fithwum +# IMAGE_REPO=minecraft + +# # Set the tag based on the folder name (vanilla, TESTING, fabric) +# IMAGE_TAG_VANILLA=vanilla +# IMAGE_TAG_TESTING=testing +# IMAGE_TAG_FABRIC=fabric + +# echo "IMAGE_TAG_VANILLA=${IMAGE_TAG_VANILLA}" >> $GITHUB_ENV +# echo "IMAGE_TAG_TESTING=${IMAGE_TAG_TESTING}" >> $GITHUB_ENV +# echo "IMAGE_TAG_FABRIC=${IMAGE_TAG_FABRIC}" >> $GITHUB_ENV + +# # Set image names for each subfolder Dockerfile +# IMAGE_VANILLA=${IMAGE_REGISTRY}/${IMAGE_ORG}/${IMAGE_REPO}:${IMAGE_TAG_VANILLA} +# IMAGE_TESTING=${IMAGE_REGISTRY}/${IMAGE_ORG}/${IMAGE_REPO}:${IMAGE_TAG_TESTING} +# IMAGE_FABRIC=${IMAGE_REGISTRY}/${IMAGE_ORG}/${IMAGE_REPO}:${IMAGE_TAG_FABRIC} + +# echo "IMAGE_VANILLA=${IMAGE_VANILLA}" >> $GITHUB_ENV +# echo "IMAGE_TESTING=${IMAGE_TESTING}" >> $GITHUB_ENV +# echo "IMAGE_FABRIC=${IMAGE_FABRIC}" >> $GITHUB_ENV + +# - name: Set up Docker Buildx +# uses: docker/setup-buildx-action@v3 + +# - name: Log in to Gitea Registry +# run: echo "${{ secrets.DOCKER_PASSWORD }}" | docker login gitea.fithwum.tech -u "${{ secrets.DOCKER_USERNAME }}" --password-stdin + +# # Build and Push Vanilla Docker Image +# - name: Build and Push Vanilla Docker Image +# run: | +# docker buildx build --platform linux/amd64 --push -t ${{ env.IMAGE_VANILLA }} ./vanilla + +# # Build and Push Testing Docker Image +# - name: Build and Push Testing Docker Image +# run: | +# docker buildx build --platform linux/amd64 --push -t ${{ env.IMAGE_TESTING }} ./testing + +# # Build and Push Fabric Docker Image +# - name: Build and Push Fabric Docker Image +# run: | +# docker buildx build --platform linux/amd64 --push -t ${{ env.IMAGE_FABRIC }} ./fabric diff --git a/bedrock/Dockerfile b/bedrock/Dockerfile index 62aa973..0da9390 100644 --- a/bedrock/Dockerfile +++ b/bedrock/Dockerfile @@ -1,4 +1,4 @@ -FROM gitea.fithwum.tech/fithwum/debian-base:bullseye +FROM gitea.fithwum.tech/fithwum/debian-base:bookworm LABEL maintainer="fithwum" # Environment Variables diff --git a/forge/Dockerfile b/forge/Dockerfile index 7358b23..31e18b4 100644 --- a/forge/Dockerfile +++ b/forge/Dockerfile @@ -1,4 +1,4 @@ -FROM gitea.fithwum.tech/fithwum/debian-base:bullseye +FROM gitea.fithwum.tech/fithwum/debian-base:bookworm LABEL maintainer="fithwum" ENV ACCEPT_EULA="false"