name: Build Stable Docker Image # Stable Docker images are built for every new tag on: push: tags: - 'v*.*.*' paths-ignore: - README.md - LICENSE.txt env: IMAGES: | actualbudget/actual-server ghcr.io/actualbudget/actual-server ghcr.io/actualbudget/actual # Creates the following tags: # - actual-server:latest (see docker/metadata-action flavor inputs, below) # - actual-server:1.3 # - actual-server:1.3.7 # - actual-server:sha-90dd603 TAGS: | type=semver,pattern={{version}} jobs: build: name: Build Docker image runs-on: ubuntu-latest steps: - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 - name: Set up QEMU uses: docker/setup-qemu-action@ce360397dd3f832beb865e1373c09c0e9f86d70a # v4.0.0 - name: Set up Docker Buildx uses: docker/setup-buildx-action@4d04d5d9486b7bd6fa91e7baf45bbb4f8b9deedd # v4.0.0 - name: Docker meta id: meta uses: docker/metadata-action@030e881283bb7a6894de51c315a6bfe6a94e05cf # v6.0.0 with: # Push to both Docker Hub and Github Container Registry images: ${{ env.IMAGES }} # Automatically update :latest flavor: latest=true tags: ${{ env.TAGS }} - name: Docker meta for Alpine image id: alpine-meta uses: docker/metadata-action@030e881283bb7a6894de51c315a6bfe6a94e05cf # v6.0.0 with: images: ${{ env.IMAGES }} # Automatically update :latest flavor: | latest=true suffix=-alpine,onlatest=true tags: ${{ env.TAGS }} - name: Login to Docker Hub uses: docker/login-action@b45d80f862d83dbcd57f89517bcf500b2ab88fb2 # v4.0.0 with: username: ${{ secrets.DOCKERHUB_USERNAME }} password: ${{ secrets.DOCKERHUB_TOKEN }} - name: Login to GitHub Container Registry uses: docker/login-action@b45d80f862d83dbcd57f89517bcf500b2ab88fb2 # v4.0.0 with: registry: ghcr.io username: ${{ github.repository_owner }} password: ${{ secrets.GITHUB_TOKEN }} # Building outside of the docker image allows us to build once and push to multiple platforms # This is faster and avoids yarn memory issues - name: Set up environment uses: ./.github/actions/setup - name: Build Web run: yarn build:server - name: Build and push ubuntu image uses: docker/build-push-action@d08e5c354a6adb9ed34480a06d141179aa583294 # v7.0.0 with: context: . push: true file: packages/sync-server/docker/ubuntu.Dockerfile platforms: linux/amd64,linux/arm64,linux/arm/v7 tags: ${{ steps.meta.outputs.tags }} - name: Build and push alpine image uses: docker/build-push-action@d08e5c354a6adb9ed34480a06d141179aa583294 # v7.0.0 with: context: . push: true file: packages/sync-server/docker/alpine.Dockerfile platforms: linux/amd64,linux/arm64,linux/arm/v7,linux/arm/v6 tags: ${{ steps.alpine-meta.outputs.tags }}