name: Docker on: push: tags: ['v*'] workflow_dispatch: env: REGISTRY: ghcr.io IMAGE_NAME: ${{ github.repository }} jobs: build-and-push: name: Build & Push (${{ matrix.variant }}) runs-on: ubuntu-latest timeout-minutes: 30 permissions: contents: read packages: write strategy: matrix: include: - variant: base target: base suffix: '' platforms: linux/amd64,linux/arm64 - variant: claude target: with-claude suffix: '-claude' platforms: linux/amd64,linux/arm64 - variant: codex target: with-codex suffix: '-codex' platforms: linux/amd64,linux/arm64 - variant: opencode target: with-opencode suffix: '-opencode' platforms: linux/amd64,linux/arm64 - variant: copilot target: with-copilot suffix: '-copilot' platforms: linux/amd64,linux/arm64 - variant: gemini target: with-gemini suffix: '-gemini' platforms: linux/amd64,linux/arm64 - variant: full target: full suffix: '-full' platforms: linux/amd64,linux/arm64 steps: - uses: actions/checkout@v4 with: submodules: recursive - name: Log in to GitHub Container Registry uses: docker/login-action@v3 with: registry: ${{ env.REGISTRY }} username: ${{ github.actor }} password: ${{ secrets.GITHUB_TOKEN }} - name: Extract metadata id: meta uses: docker/metadata-action@v5 with: images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} flavor: | suffix=${{ matrix.suffix }} tags: | type=semver,pattern={{version}} type=semver,pattern={{major}}.{{minor}} type=raw,value=latest - name: Set up QEMU uses: docker/setup-qemu-action@v3 - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 - name: Build and push uses: docker/build-push-action@v6 with: context: . target: ${{ matrix.target }} platforms: ${{ matrix.platforms }} push: true tags: ${{ steps.meta.outputs.tags }} labels: ${{ steps.meta.outputs.labels }} cache-from: type=gha,scope=${{ matrix.variant }} cache-to: type=gha,mode=max,scope=${{ matrix.variant }}