From 687567a09e47736866c6277bb87f360da46a08f7 Mon Sep 17 00:00:00 2001 From: Fijxu Date: Fri, 13 Dec 2024 18:32:59 -0300 Subject: [PATCH] workflow for git.nadeko.net --- .forgejo/workflows/docker-build-push.yaml | 68 +++++++++++++++++++++++ .github/workflows/docker-build-push.yaml | 16 ++---- 2 files changed, 74 insertions(+), 10 deletions(-) create mode 100644 .forgejo/workflows/docker-build-push.yaml diff --git a/.forgejo/workflows/docker-build-push.yaml b/.forgejo/workflows/docker-build-push.yaml new file mode 100644 index 0000000..4317571 --- /dev/null +++ b/.forgejo/workflows/docker-build-push.yaml @@ -0,0 +1,68 @@ +name: Build and Push Docker Image + +# Define when this workflow will run +on: + push: + branches: + - master # Trigger on pushes to master branch + tags: + - '[0-9]+.[0-9]+.[0-9]+' # Trigger on semantic version tags + paths-ignore: + - '.gitignore' + - 'LICENSE' + - 'README.md' + - 'docker-compose.yml' + workflow_dispatch: # Allow manual triggering of the workflow + +# Define environment variables used throughout the workflow +env: + REGISTRY: git.nadeko.net + IMAGE_NAME: fijxu/invidious-companion + +jobs: + build-and-push: + runs-on: runner + + steps: + # Step 1: Check out the repository code + - name: Checkout code + uses: actions/checkout@v3 + + # Step 3: Set up Docker Buildx for enhanced build capabilities + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v2 + + # Step 4: Authenticate with Quay.io registry + - name: Login to Docker Container Registry (git.nadeko.net) + uses: docker/login-action@v3 + with: + registry: ${{ env.REGISTRY }} + username: ${{ secrets.QUAY_USERNAME }} + password: ${{ secrets.QUAY_PASSWORD }} + + # Step 5: Extract metadata for Docker image tagging and labeling + - name: Extract metadata for Docker + id: meta + uses: docker/metadata-action@v4 + with: + images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} + # Define tagging strategy + tags: | + type=semver,pattern={{version}} + type=semver,pattern={{major}}.{{minor}} + type=semver,pattern={{major}} + type=raw,value=latest,enable=${{ github.ref == format('refs/heads/{0}', 'master') }} + type=sha,prefix={{branch}}- + # Define labels + labels: | + quay.expires-after=12w + + # Step 6: Build and push the Docker image + - name: Build and push Docker image + uses: docker/build-push-action@v4 + with: + context: . + push: true + platforms: linux/amd64 + tags: ${{ steps.meta.outputs.tags }} + labels: ${{ steps.meta.outputs.labels }} diff --git a/.github/workflows/docker-build-push.yaml b/.github/workflows/docker-build-push.yaml index 8a79d77..4317571 100644 --- a/.github/workflows/docker-build-push.yaml +++ b/.github/workflows/docker-build-push.yaml @@ -16,29 +16,25 @@ on: # Define environment variables used throughout the workflow env: - REGISTRY: quay.io - IMAGE_NAME: invidious/invidious-companion + REGISTRY: git.nadeko.net + IMAGE_NAME: fijxu/invidious-companion jobs: build-and-push: - runs-on: ubuntu-latest + runs-on: runner steps: # Step 1: Check out the repository code - name: Checkout code uses: actions/checkout@v3 - # Step 2: Set up QEMU for multi-architecture builds - - name: Set up QEMU - uses: docker/setup-qemu-action@v2 - # Step 3: Set up Docker Buildx for enhanced build capabilities - name: Set up Docker Buildx uses: docker/setup-buildx-action@v2 # Step 4: Authenticate with Quay.io registry - - name: Log in to Quay.io - uses: docker/login-action@v2 + - name: Login to Docker Container Registry (git.nadeko.net) + uses: docker/login-action@v3 with: registry: ${{ env.REGISTRY }} username: ${{ secrets.QUAY_USERNAME }} @@ -67,6 +63,6 @@ jobs: with: context: . push: true - platforms: linux/amd64,linux/arm64 # Build for multiple architectures + platforms: linux/amd64 tags: ${{ steps.meta.outputs.tags }} labels: ${{ steps.meta.outputs.labels }}