Updated README and cd.yml.

This commit is contained in:
Mike Cao 2025-11-07 12:21:17 -08:00
parent 3e9ca8761e
commit 6ee93f7ac9
2 changed files with 34 additions and 27 deletions

View file

@ -7,7 +7,7 @@ on:
workflow_dispatch: workflow_dispatch:
inputs: inputs:
version: version:
description: 'Optional image version (e.g. 3.0.0, beta)' description: 'Optional image version (e.g. 3.0.0, v3.0.0, or 3.0.0-beta.1)'
required: false required: false
default: '' default: ''
@ -29,6 +29,13 @@ jobs:
- name: Set up Docker Buildx - name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3 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 - name: Log into Docker Hub
if: github.repository == 'umami-software/umami' if: github.repository == 'umami-software/umami'
uses: docker/login-action@v3 uses: docker/login-action@v3
@ -37,26 +44,28 @@ jobs:
username: ${{ secrets.DOCKER_USERNAME }} username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }} password: ${{ secrets.DOCKER_PASSWORD }}
- name: Log into GHCR # Compute tags for the image
uses: docker/login-action@v3 - name: Compute version tags
with: id: compute
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
# Normalize manual input if provided
- name: Normalize manual version
id: normalize
run: | run: |
INPUT="${{ github.event.inputs.version }}" INPUT="${{ github.event.inputs.version }}"
TAGS=""
if [[ -n "$INPUT" ]]; then if [[ -n "$INPUT" ]]; then
VERSION="${INPUT#v}" VERSION="${INPUT#v}" # strip leading v
MAJOR=$(echo "$VERSION" | cut -d. -f1) MAJOR=$(echo "$VERSION" | cut -d. -f1)
MINOR=$(echo "$VERSION" | cut -d. -f2) MINOR=$(echo "$VERSION" | cut -d. -f2)
echo "version_tags=${VERSION},${MAJOR}.${MINOR},${MAJOR},latest" >> $GITHUB_ENV
# prereleases (e.g., 3.0.0-beta) do NOT get 'latest'
if [[ "$VERSION" == *-* ]]; then
TAGS="${VERSION}"
else else
echo "version_tags=" >> $GITHUB_ENV TAGS="${VERSION},${MAJOR}.${MINOR},${MAJOR},latest"
fi fi
fi
echo "tags=$TAGS" >> $GITHUB_OUTPUT
echo "Computed tags: $TAGS"
- name: Extract Docker metadata - name: Extract Docker metadata
id: meta id: meta
@ -65,34 +74,32 @@ jobs:
images: | images: |
umamisoftware/umami,enable=${{ github.repository == 'umami-software/umami' }} umamisoftware/umami,enable=${{ github.repository == 'umami-software/umami' }}
ghcr.io/${{ github.repository }} ghcr.io/${{ github.repository }}
flavor: |
latest=auto
tags: | tags: |
type=semver,pattern={{version}} type=semver,pattern={{version}},enable=${{ github.ref_type == 'tag' }}
type=semver,pattern={{major}}.{{minor}} type=semver,pattern={{major}}.{{minor}},enable=${{ github.ref_type == 'tag' }}
type=semver,pattern={{major}} type=semver,pattern={{major}},enable=${{ github.ref_type == 'tag' }}
type=raw,value=${{ env.version_tags }},enable=${{ env.version_tags != '' }} type=raw,value=${{ steps.compute.outputs.tags }},enable=${{ steps.compute.outputs.tags != '' }}
type=ref,event=branch type=ref,event=branch
type=sha type=sha
# Build and push images
- name: Build and push Docker image - name: Build and push Docker image
id: build-and-push id: build-and-push
uses: docker/build-push-action@v6 uses: docker/build-push-action@v6
with: with:
context: . context: .
platforms: linux/amd64,linux/arm64
push: true push: true
platforms: linux/amd64,linux/arm64
tags: ${{ steps.meta.outputs.tags }} tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }} labels: ${{ steps.meta.outputs.labels }}
cache-from: type=gha cache-from: type=gha
cache-to: type=gha,mode=max cache-to: type=gha,mode=max
provenance: false # disable automatic attestations provenance: false # disable automatic registry attestations
# Generate a local provenance attestation instead of uploading signatures # Generate a local provenance attestation (not uploaded)
- name: Generate provenance attestation - name: Generate local provenance attestation
run: | run: |
cosign attest --yes \ cosign attest --yes \
--predicate <(echo '{"build":"github-actions","repo":"${{ github.repository }}","run_id":"${{ github.run_id }}"}') \ --predicate <(echo '{"build":"github-actions","repo":"${{ github.repository }}","run_id":"${{ github.run_id }}"}') \
--type slsaprovenance \ --type slsaprovenance \
${{ steps.meta.outputs.tags }} ${{ steps.meta.outputs.tags }}

View file

@ -89,7 +89,7 @@ docker compose up -d
Alternatively, to pull just the Umami Docker image with PostgreSQL support: Alternatively, to pull just the Umami Docker image with PostgreSQL support:
```bash ```bash
docker pull docker.umami.is/umami-software/umami:postgresql-latest docker pull docker.umami.is/umami-software/umami:latest
``` ```
--- ---