-
Notifications
You must be signed in to change notification settings - Fork 13
122 lines (110 loc) · 4.05 KB
/
publish.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
name: Publish Image to Quay
on:
schedule:
- cron: 0 0 */30 * *
release:
types: [published]
workflow_dispatch:
inputs:
tag:
description: |
Name of the tag for the published image. Will be published as <tag>-<branch>-<sha>.
If a valid semver, associated semver tags will be published as well.
type: string
required: true
skip_tests:
description: "Skip end to end tests when publishing an image."
type: boolean
required: false
default: false
no_cache:
description: "Skip using cache when building the image."
type: boolean
required: false
default: false
env:
IMAGE_NAME: trestle-bot
IMAGE_REGISTRY: quay.io
concurrency:
group: ${{ github.ref }}-${{ github.workflow }}-publish
cancel-in-progress: true
jobs:
publish-image:
runs-on: 'ubuntu-latest'
permissions:
contents: read
# kics-scan ignore-line
id-token: write # needed for signing the images with GitHub OIDC Token
steps:
- name: Login to Quay
uses: docker/login-action@v3
with:
username: ${{ secrets.QUAY_USER }}
password: ${{ secrets.QUAY_TOKEN }}
registry: ${{ env.IMAGE_REGISTRY }}
- name: Check out
uses: actions/checkout@v4
with:
persist-credentials: false
- name: Set up cosign
uses: sigstore/[email protected]
- name: Check if triggered by release or workflow dispatch
id: check_event
run: echo "event_type=${{ toJson(github.event_name) }}" >> "$GITHUB_OUTPUT"
# Using intermediary variable to process event based input
- name: Set environment information for release
if: ${{ steps.check_event.outputs.event_type == 'release' }}
run: |
{
echo "TAG=$RELEASE_VERSION"
echo "NO_CACHE=true"
echo "BUILD_GIT_REF=$RELEASE_VERSION"
echo "SKIP_TESTS=true"
} >> "$GITHUB_ENV"
env:
RELEASE_VERSION: ${{ github.event.release.tag_name }}
- name: Set environment information for workflow dispatch
if: ${{ steps.check_event.outputs.event_type == 'workflow_dispatch' }}
run: |
{
echo "TAG=$INPUT_VERSION"
echo "NO_CACHE=$INPUT_NO_CACHE"
echo "BUILD_GIT_REF=${{ github.ref }}"
echo "SKIP_TESTS=$INPUT_SKIP_TESTS"
} >> "$GITHUB_ENV"
env:
INPUT_VERSION: ${{ github.event.inputs.tag }}
INPUT_NO_CACHE: ${{ github.event.inputs.no_cache }}
INPUT_SKIP_TESTS: ${{ github.event.inputs.skip_tests }}
- name: Set environment information for schedule
if: ${{ steps.check_event.outputs.event_type == 'schedule' }}
run: |
LATEST_VERSION=$( gh release view --json tagName --jq '.["tagName"]' )
{
echo "TAG=$LATEST_VERSION"
echo "NO_CACHE=true"
echo "BUILD_GIT_REF=$LATEST_VERSION"
echo "SKIP_TESTS=false"
} >> "$GITHUB_ENV"
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Build and Publish the image
uses: ./.github/actions/publish-image
id: build_publish_image
with:
image: ${{ env.IMAGE_REGISTRY }}/${{ vars.QUAY_ORG }}/${{ env.IMAGE_NAME }}
release_version: ${{ env.TAG }}
no_cache: ${{ env.NO_CACHE }}
git_ref: ${{ env.BUILD_GIT_REF }}
skip_tests: ${{ env.SKIP_TESTS }}
- name: Sign the image with GitHub OIDC Token
run: cosign sign --yes "$IMAGE"
env:
IMAGE: ${{ steps.build_publish_image.outputs.image_sha }}
- name: Verify image
run: |
cosign verify "$IMAGE" --certificate-identity-regexp="$SUBJECT" \
--certificate-oidc-issuer=https://token.actions.githubusercontent.com
env:
SUBJECT: https://github\.com/${{ github.repository_owner }}/trestle-bot/\.github/.+
IMAGE: ${{ steps.build_publish_image.outputs.image_sha }}