Skip to content

fix: handle multi-source ArgoCD applications #308

fix: handle multi-source ArgoCD applications

fix: handle multi-source ArgoCD applications #308

name: Build and Publish Docker Images
on:
push:
branches:
- main
tags:
- 'v*'
pull_request:
branches:
- main
env:
REGISTRY: ghcr.io
ORG: ${{ github.repository_owner }}
jobs:
build-standard:
name: Build Standard Image (Public)
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
id-token: write
attestations: write
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Log in to Container Registry
if: github.event_name != 'pull_request'
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Extract metadata for standard image
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.REGISTRY }}/${{ env.ORG }}/cased-cd
tags: |
type=ref,event=branch
type=ref,event=pr
type=semver,pattern={{version}}
type=semver,pattern={{major}}.{{minor}}
type=semver,pattern={{major}}
type=sha,prefix=sha-
type=raw,value=latest,enable={{is_default_branch}}
- name: Build and push standard image
id: build
uses: docker/build-push-action@v5
with:
context: .
target: standard
push: ${{ github.event_name != 'pull_request' }}
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
cache-from: |
type=gha,scope=frontend
type=gha,scope=standard
cache-to: type=gha,mode=max,scope=standard
platforms: linux/amd64,linux/arm64
build-args: |
VERSION=${{ github.ref_name }}
BUILD_DATE=${{ github.event.head_commit.timestamp }}
VCS_REF=${{ github.sha }}
- name: Generate artifact attestation
if: github.event_name != 'pull_request'
uses: actions/attest-build-provenance@v1
with:
subject-name: ${{ env.REGISTRY }}/${{ env.ORG }}/cased-cd
subject-digest: ${{ steps.build.outputs.digest }}
push-to-registry: true
summary:
name: Build Summary
needs: [build-standard]
runs-on: ubuntu-latest
if: github.event_name != 'pull_request'
steps:
- name: Generate summary
run: |
cat >> $GITHUB_STEP_SUMMARY <<'EOF'
## Docker Image Built Successfully
### Community Edition Image
```
${{ env.REGISTRY }}/${{ env.ORG }}/cased-cd:${{ github.ref_name }}
```
- **Registry**: GitHub Container Registry (GHCR)
- **License**: FSL-1.1-Apache-2.0
- **Visibility**: Public
- **Access**: Anyone can pull
### Platforms
- `linux/amd64`
- `linux/arm64`
### Security
- Build provenance attestation included
- Supply chain security via GitHub
### Documentation
- Installation: https://github.com/${{ github.repository }}#quick-start
- Troubleshooting: https://github.com/${{ github.repository }}/blob/main/TROUBLESHOOTING.md
EOF