-
Notifications
You must be signed in to change notification settings - Fork 1
138 lines (124 loc) · 3.98 KB
/
docker.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
name: Docker CI/CD
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
on:
pull_request_target:
paths:
- "app/**"
- "public/**"
- "test/**"
- ".dockerignore"
- "bun.lockb"
- "Dockerfile"
- "package.json"
- "*config.*"
push:
branches: main
paths:
- "app/**"
- "public/**"
- "test/**"
- ".dockerignore"
- "bun.lockb"
- "Dockerfile"
- "package.json"
- "*config.*"
tags:
- "v*.*.*"
workflow_dispatch:
inputs:
no-cache:
description: "Build docker images with no cache"
default: false
required: false
type: boolean
push:
description: 'Push docker image to registry'
required: false
default: false
type: boolean
permissions:
attestations: write
contents: read
id-token: write
packages: write
pull-requests: write
env:
REPOSITORY: jambalaya56562/blog
GHCR_REGISTRY: ghcr.io
GHCR_REPOSITORY: jambalaya56562/blog
SHA: ${{ github.event.pull_request.head.sha || github.sha }}
IS_PUSH: ${{ github.event_name == 'push' || inputs.push == true }}
jobs:
build:
runs-on: ubuntu-latest
timeout-minutes: 30
if: github.repository_owner == 'jambalaya56562'
steps:
- name: Checkout
uses: actions/checkout@v4
with:
ref: ${{ env.SHA }}
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Login to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USER }}
password: ${{ secrets.DOCKER_PAT }}
- name: Login to GitHub Container Registry
if: fromJSON(env.IS_PUSH)
uses: docker/login-action@v3
with:
registry: ${{ env.GHCR_REGISTRY }}
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Docker Meta
id: meta
uses: docker/metadata-action@v5
with:
images: |
name=${{ env.REPOSITORY }}
name=${{ env.GHCR_REGISTRY }}/${{ env.GHCR_REPOSITORY }},enable=${{ fromJSON(env.IS_PUSH) }}
labels: org.opencontainers.image.revision=${{ env.SHA }}
tags: |
type=semver,pattern={{version}}
type=semver,pattern={{major}}.{{minor}}
type=semver,pattern={{major}},enable=${{ !startsWith(github.ref, 'refs/tags/v0.') }}
type=ref,event=pr,prefix=pr-
type=raw,value=canary,enable=${{ github.event_name != 'pull_request_target' }}
env:
DOCKER_METADATA_ANNOTATIONS_LEVELS: ${{ fromJSON(env.IS_PUSH) && 'manifest,index' || 'manifest' }}
- name: Build and Push
uses: docker/build-push-action@v6
id: push
with:
annotations: ${{ steps.meta.outputs.annotations }}
cache-from: type=gha
cache-to: type=gha,mode=max
context: .
labels: ${{ steps.meta.outputs.labels }}
load: ${{ !fromJSON(env.IS_PUSH) }}
no-cache: ${{ inputs.no-cache == true }}
platforms: ${{ fromJSON(env.IS_PUSH) && 'linux/amd64,linux/arm64' || 'linux/amd64' }}
provenance: ${{ fromJSON(env.IS_PUSH) && 'mode=max' }}
push: ${{ fromJSON(env.IS_PUSH) }}
sbom: ${{ fromJSON(env.IS_PUSH) }}
tags: ${{ steps.meta.outputs.tags }}
- name: Attest
if: fromJSON(env.IS_PUSH)
uses: actions/attest-build-provenance@v1
with:
subject-name: ${{ env.GHCR_REGISTRY }}/${{ env.GHCR_REPOSITORY }}
subject-digest: ${{ steps.push.outputs.digest }}
- name: Docker Scout
if: github.event_name == 'pull_request_target'
uses: docker/scout-action@v1
with:
command: compare
image: ${{ steps.meta.outputs.tags }}
to: ${{ env.REPOSITORY }}:canary
only-severities: critical,high