Skip to content

Commit d800253

Browse files
FORK: add GHA to build images
Signed-off-by: Mathew Wicks <5735406+thesuperzapper@users.noreply.github.com>
1 parent 71af15e commit d800253

File tree

4 files changed

+511
-0
lines changed

4 files changed

+511
-0
lines changed

.github/workflows/build_commit.yml

+22
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
name: Build Commit
2+
3+
on:
4+
push:
5+
branches:
6+
- fork-*
7+
8+
permissions:
9+
packages: write
10+
11+
jobs:
12+
build_kfp_images:
13+
name: Build Kubeflow Pipelines Images
14+
uses: ./.github/workflows/build_kfp_images_TEMPLATE.yml
15+
secrets: inherit
16+
with:
17+
## NOTE: we push SHA builds to the .../ci registry
18+
image_name_prefix: ghcr.io/${{ github.repository_owner }}/ci/kubeflow-pipelines
19+
build_platforms: linux/amd64
20+
build_cache_prefix: ghcr.io/${{ github.repository_owner }}/ci/kubeflow-pipelines
21+
tag_with_sha: true
22+
login_to_ghcr: true
+128
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,128 @@
1+
name: Build Image (TEMPLATE)
2+
on:
3+
workflow_call:
4+
inputs:
5+
image_names:
6+
required: true
7+
description: "the images to push, including registry prefix, whitespace separated"
8+
type: string
9+
10+
metadata_title:
11+
required: true
12+
description: "the title of the image"
13+
type: string
14+
metadata_description:
15+
required: true
16+
description: "the description of the image"
17+
type: string
18+
19+
tag_with_latest:
20+
default: false
21+
description: "if true, image tags will include 'latest'"
22+
type: boolean
23+
tag_with_semver:
24+
default: false
25+
description: "if true, image tags will include the version (from git tag event, without 'v' prefix)"
26+
type: boolean
27+
tag_with_sha:
28+
default: false
29+
description: "if true, image tags will include the commit SHA (both short and long)"
30+
type: boolean
31+
32+
build_file:
33+
required: true
34+
description: "path to Dockerfile"
35+
type: string
36+
build_context:
37+
required: true
38+
description: "path to build context folder"
39+
type: string
40+
build_platforms:
41+
required: true
42+
description: "docker buildx platforms to build for, whitespace separated"
43+
type: string
44+
build_registry_cache:
45+
required: true
46+
description: "an image to use as a registry-type build cache (registry + image + tag)"
47+
type: string
48+
49+
login_to_ghcr:
50+
default: false
51+
description: "if true, login to GitHub Container Registry with the GITHUB_TOKEN"
52+
type: boolean
53+
login_to_docker:
54+
default: false
55+
description: "if true, login to DockerHub using the DOCKER_USERNAME and DOCKER_PASSWORD secrets in the repository"
56+
type: boolean
57+
58+
jobs:
59+
build_image:
60+
name: Build '${{ inputs.metadata_title }}' Image
61+
runs-on: ubuntu-latest
62+
steps:
63+
## We need to sanitize some inputs before we can use them:
64+
## - the `build_registry_cache` must be lowercase so we can safely use
65+
## it in `cache-from` and `cache-to` options
66+
- name: Sanitize Inputs
67+
id: sanitize_inputs
68+
env:
69+
build_registry_cache: ${{ inputs.build_registry_cache }}
70+
run: |
71+
echo "build_registry_cache=${build_registry_cache@L}" >> "$GITHUB_OUTPUT"
72+
73+
- name: Checkout
74+
uses: actions/checkout@v4
75+
76+
- name: Install QEMU
77+
uses: docker/setup-qemu-action@v3
78+
79+
- name: Install Docker Buildx
80+
uses: docker/setup-buildx-action@v3
81+
82+
- name: Login to GitHub Container Registry
83+
uses: docker/login-action@v3
84+
if: ${{ inputs.login_to_ghcr }}
85+
with:
86+
registry: ghcr.io
87+
username: ${{ github.actor }}
88+
password: ${{ secrets.GITHUB_TOKEN }}
89+
90+
- name: Login to DockerHub
91+
uses: docker/login-action@v3
92+
if: ${{ inputs.login_to_docker }}
93+
with:
94+
registry: docker.io
95+
username: ${{ secrets.DOCKER_USERNAME }}
96+
password: ${{ secrets.DOCKER_PASSWORD }}
97+
98+
- name: Generate Image Metadata
99+
id: meta
100+
uses: docker/metadata-action@v5
101+
with:
102+
images: ${{ inputs.image_names }}
103+
flavor: |
104+
latest=${{ inputs.tag_with_latest }}
105+
tags: |
106+
type=semver,priority=1000,pattern={{version}},enable=${{ inputs.tag_with_semver }}
107+
type=semver,priority=900,pattern={{major}}.{{minor}},enable=${{ inputs.tag_with_semver }}
108+
type=sha,priority=200,prefix=sha-,format=short,enable=${{ inputs.tag_with_sha }}
109+
type=sha,priority=100,prefix=sha-,format=long,enable=${{ inputs.tag_with_sha }}
110+
labels: |
111+
org.opencontainers.image.title=${{ inputs.metadata_title }}
112+
org.opencontainers.image.description=${{ inputs.metadata_description }}
113+
annotations: |
114+
org.opencontainers.image.title=${{ inputs.metadata_title }}
115+
org.opencontainers.image.description=${{ inputs.metadata_description }}
116+
117+
- name: Build and Push Image
118+
uses: docker/build-push-action@v5
119+
with:
120+
annotations: ${{ steps.meta.outputs.annotations }}
121+
cache-from: type=registry,ref=${{ steps.sanitize_inputs.outputs.build_registry_cache }}
122+
cache-to: type=registry,ref=${{ steps.sanitize_inputs.outputs.build_registry_cache }},mode=max
123+
context: ${{ inputs.build_context }}
124+
file: ${{ inputs.build_file }}
125+
labels: ${{ steps.meta.outputs.labels }}
126+
platforms: ${{ inputs.build_platforms }}
127+
push: true
128+
tags: ${{ steps.meta.outputs.tags }}

0 commit comments

Comments
 (0)