1+ name : Docker
2+
3+ on :
4+ push :
5+ branches : [main, develop]
6+ tags : ['v*']
7+ pull_request :
8+ branches : [main]
9+
10+ env :
11+ REGISTRY : ghcr.io
12+ IMAGE_NAME : ${{ github.repository }}
13+
14+ jobs :
15+ build :
16+ runs-on : ubuntu-latest
17+ permissions :
18+ contents : read
19+ packages : write
20+
21+ steps :
22+ - name : Checkout repository
23+ uses : actions/checkout@v4
24+
25+ - name : Setup Docker Buildx
26+ uses : docker/setup-buildx-action@v3
27+
28+ - name : Log in to Container Registry
29+ if : github.event_name != 'pull_request'
30+ uses : docker/login-action@v3
31+ with :
32+ registry : ${{ env.REGISTRY }}
33+ username : ${{ github.actor }}
34+ password : ${{ secrets.GITHUB_TOKEN }}
35+
36+ - name : Extract metadata
37+ id : meta
38+ uses : docker/metadata-action@v5
39+ with :
40+ images : ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
41+ tags : |
42+ # Canary builds for every push to main/develop
43+ type=raw,value=canary,enable={{is_default_branch}}
44+ type=raw,value=canary-{{branch}},enable=${{ github.ref_name != 'main' && github.event_name == 'push' }}
45+ type=raw,value=canary-{{sha}},enable=${{ github.event_name == 'push' }}
46+ # PR builds
47+ type=ref,event=pr,prefix=pr-
48+ # Release builds only on tags
49+ type=semver,pattern={{version}}
50+ type=semver,pattern={{major}}.{{minor}}
51+ type=raw,value=latest,enable=${{ startsWith(github.ref, 'refs/tags/v') }}
52+
53+ - name : Build and push Docker image
54+ uses : docker/build-push-action@v5
55+ with :
56+ context : .
57+ platforms : linux/amd64,linux/arm64
58+ push : ${{ github.event_name != 'pull_request' }}
59+ tags : ${{ steps.meta.outputs.tags }}
60+ labels : ${{ steps.meta.outputs.labels }}
61+ cache-from : type=gha
62+ cache-to : type=gha,mode=max
0 commit comments