name: Create docker images on: push: tags: - "v*.*.*" workflow_dispatch: inputs: version: description: "Optional image version (e.g. 3.0.0, v3.0.0, or 3.0.0-beta.1)" required: false default: "" include_latest: description: "Include latest tag" required: false type: boolean default: true jobs: build: name: Build, push, and deploy runs-on: ubuntu-latest permissions: contents: read packages: write strategy: matrix: include: - type: standard base_path: "" suffix: "" - type: base base_path: "/umami" suffix: "-base" steps: - uses: actions/checkout@v5 - name: Set up QEMU uses: docker/setup-qemu-action@v3 - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 - name: Log into GHCR uses: docker/login-action@v3 with: registry: ghcr.io username: ${{ github.actor }} password: ${{ secrets.GITHUB_TOKEN }} - name: Log into Docker Hub if: github.repository == 'umami-software/umami' uses: docker/login-action@v3 with: registry: docker.io username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKER_PASSWORD }} - name: Compute version tags id: compute run: | INPUT="${{ github.event.inputs.version }}" REF_TYPE="${{ github.ref_type }}" REF_NAME="${{ github.ref_name }}" INCLUDE_LATEST="${{ github.event.inputs.include_latest }}" SUFFIX="${{ matrix.suffix }}" # Determine version source if [[ -n "$INPUT" ]]; then VERSION="${INPUT#v}" elif [[ "$REF_TYPE" == "tag" ]]; then VERSION="${REF_NAME#v}" else VERSION="" fi GHCR_TAGS="" DOCKER_TAGS="" if [[ -n "$VERSION" ]]; then MAJOR=$(echo "$VERSION" | cut -d. -f1) MINOR=$(echo "$VERSION" | cut -d. -f2) if [[ "$VERSION" == *-* ]]; then # prerelease: only version tag GHCR_TAGS="ghcr.io/${{ github.repository }}:$VERSION$SUFFIX" DOCKER_TAGS="umamisoftware/umami:$VERSION$SUFFIX" else # stable release: version + hierarchy GHCR_TAGS="ghcr.io/${{ github.repository }}:$VERSION$SUFFIX" GHCR_TAGS="$GHCR_TAGS,ghcr.io/${{ github.repository }}:${MAJOR}.${MINOR}$SUFFIX" GHCR_TAGS="$GHCR_TAGS,ghcr.io/${{ github.repository }}:${MAJOR}$SUFFIX" GHCR_TAGS="$GHCR_TAGS,ghcr.io/${{ github.repository }}:postgresql-latest$SUFFIX" DOCKER_TAGS="umamisoftware/umami:$VERSION$SUFFIX" DOCKER_TAGS="$DOCKER_TAGS,umamisoftware/umami:${MAJOR}.${MINOR}$SUFFIX" DOCKER_TAGS="$DOCKER_TAGS,umamisoftware/umami:${MAJOR}$SUFFIX" DOCKER_TAGS="$DOCKER_TAGS,umamisoftware/umami:postgresql-latest$SUFFIX" # Add latest tag based on trigger and input if [[ "$REF_TYPE" == "tag" ]] || [[ "$INCLUDE_LATEST" == "true" ]]; then GHCR_TAGS="$GHCR_TAGS,ghcr.io/${{ github.repository }}:latest$SUFFIX" DOCKER_TAGS="$DOCKER_TAGS,umamisoftware/umami:latest$SUFFIX" fi fi else # Non-tag build (e.g. from main branch) GHCR_TAGS="ghcr.io/${{ github.repository }}:${REF_NAME}$SUFFIX" DOCKER_TAGS="umamisoftware/umami:${REF_NAME}$SUFFIX" fi echo "ghcr_tags=$GHCR_TAGS" >> $GITHUB_OUTPUT echo "docker_tags=$DOCKER_TAGS" >> $GITHUB_OUTPUT echo "Computed GHCR tags: $GHCR_TAGS" echo "Computed Docker Hub tags: $DOCKER_TAGS" - name: Build and push to GHCR uses: docker/build-push-action@v5 with: context: . platforms: linux/amd64,linux/arm64 push: true tags: ${{ steps.compute.outputs.ghcr_tags }} build-args: | BASE_PATH=${{ matrix.base_path }} cache-from: type=gha,scope=${{ matrix.type }} cache-to: type=gha,mode=max,scope=${{ matrix.type }} - name: Build and push to Docker Hub if: github.repository == 'umami-software/umami' uses: docker/build-push-action@v5 with: context: . platforms: linux/amd64,linux/arm64 push: true tags: ${{ steps.compute.outputs.docker_tags }} build-args: | BASE_PATH=${{ matrix.base_path }} cache-from: type=gha cache-to: type=gha,mode=max