From e83948233432abe09e9cce44fc509d105daefd35 Mon Sep 17 00:00:00 2001 From: Chris Date: Sat, 7 Dec 2024 21:57:22 +0100 Subject: [PATCH] added default docker-compose and switched build to tag based multiarch --- .github/workflows/build-docker.yml | 68 +++++++++++++++++++++++------- docker-compose.yml | 28 ++++++++++++ 2 files changed, 81 insertions(+), 15 deletions(-) create mode 100644 docker-compose.yml diff --git a/.github/workflows/build-docker.yml b/.github/workflows/build-docker.yml index b978eb0..9e4546c 100644 --- a/.github/workflows/build-docker.yml +++ b/.github/workflows/build-docker.yml @@ -1,21 +1,59 @@ -name: Publish Docker image +name: ci + on: - release: - types: [published] push: - branches: [ master ] + tags: + - "v*.*.*" pull_request: - branches: [ master ] + branches: + - "master" + jobs: - push_to_registry: - name: Push Docker image to Docker Hub + docker: runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - name: Login to DockerHub Registry - run: echo ${{ secrets.DOCKER_PASSWORD }} | docker login -u ${{ secrets.DOCKER_USERNAME }} --password-stdin - - name: Build the Docker image - run: docker build . --file docker/Dockerfile --tag hascheksolutions/backupdrop:$(date +%s) --tag hascheksolutions/backupdrop:latest - - name: Push the Docker image to the registry - run: docker push hascheksolutions/backupdrop \ No newline at end of file + - name: Checkout + uses: actions/checkout@v4 + - name: Docker meta + id: meta + uses: docker/metadata-action@v5 + with: + # list of Docker images to use as base name for tags + images: | + hascheksolutions/backupdrop + ghcr.io/hascheksolutions/backupdrop + # generate Docker tags based on the following events/attributes + tags: | + type=schedule + type=ref,event=branch + type=ref,event=pr + type=semver,pattern={{version}} + type=semver,pattern={{major}}.{{minor}} + type=semver,pattern={{major}} + type=sha + - name: Set up QEMU + uses: docker/setup-qemu-action@v3 + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + - name: Login to Docker Hub + if: github.event_name != 'pull_request' + uses: docker/login-action@v3 + with: + username: ${{ secrets.DOCKER_USERNAME }} + password: ${{ secrets.DOCKER_PASSWORD }} + - name: Login to GHCR + if: github.event_name != 'pull_request' + uses: docker/login-action@v3 + with: + registry: ghcr.io + username: ${{ github.repository_owner }} + password: ${{ secrets.GITHUB_TOKEN }} + - name: Build and push + uses: docker/build-push-action@v5 + with: + context: . + file: docker/Dockerfile + platforms: linux/amd64,linux/arm/v7,linux/arm64 + push: ${{ github.event_name != 'pull_request' }} + tags: ${{ steps.meta.outputs.tags }} + labels: ${{ steps.meta.outputs.labels }} \ No newline at end of file diff --git a/docker-compose.yml b/docker-compose.yml new file mode 100644 index 0000000..966a4b1 --- /dev/null +++ b/docker-compose.yml @@ -0,0 +1,28 @@ +version: '3.8' + +services: + backupdrop: + image: hascheksolutions/backupdrop + ports: + - "8080:80" + environment: + # remove unneeded config options + - ENCRYPTION_AGE_SSH_PUBKEY= + - ENCRYPTION_AGE_PUBKEY= + - S3_BUCKET= + - S3_ACCESS_KEY= + - S3_SECRET_KEY= + - S3_ENDPOINT= + - KEEP_N_BACKUPS= + - KEEP_N_DAYS= + - KEEP_N_GIGABYTES= + - FTP_SSL= + - FTP_SERVER= + - FTP_PORT= + - FTP_USER= + - FTP_PASS= + - FTP_BASEDIR= + restart: unless-stopped + volumes: + - ./data:/var/www/backupdrop/data +