-
Notifications
You must be signed in to change notification settings - Fork 1
/
test.sh
executable file
·114 lines (102 loc) · 2.78 KB
/
test.sh
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
#!/usr/bin/env bash
[ -z "$DEBUG" ] || set -x
set -eo pipefail
[ -n "$PLATFORMS" ] || PLATFORMS="linux/amd64,linux/arm64/v8"
[ -n "$PLATFORM" ] || PLATFORM="--platform=$PLATFORMS"
[ -z "$REGISTRY" ] || PREFIX="$REGISTRY/"
SOURCE_COMMIT=$(git rev-parse --verify HEAD 2>/dev/null || echo '')
if [[ ! -z "$SOURCE_COMMIT" ]]; then
GIT_STATUS=$(git status --untracked-files=normal --porcelain=v2 | grep -v ' hooks/build' || true)
if [[ ! -z "$GIT_STATUS" ]]; then
SOURCE_COMMIT="$SOURCE_COMMIT-dirty"
fi
fi
MULTIARCH_NONROOT="
docker-base
builder-base
builder-base-gcc
builder-base-gcloud
builder-tooling
builder-node
builder-quarkus
builder-evidence
git-init
toil
toil-network
node-distroless
blobs
headless-chrome
git-http-readonly
runtime-quarkus
runtime-deno
"
MULTIARCH_TONONROOT="
java
node
node-kafka
node-kafka-cache
node-watchexec
node-kafka-watch
node-gcloud
runtime-quarkus-ubuntu
runtime-quarkus-deno
runtime-quarkus-ubuntu-jre
runtime-quarkus-dev
toil-storage
curl-yq
"
DEPRECATED="
runtime-quarkus-deno
runtime-deno
"
BEGIN=" ### build steps below are generated ###"
CURRENT=.github/workflows/images.yaml
ACTIONS=$(mktemp)
sed "/^$BEGIN\$/q" $CURRENT > $ACTIONS
function base_action {
local CONTEXT=$1
local NAME=$2
local TAG=$3
local TAGSUFFIX=""
[ "$TAG" = "latest" ] || local TAGSUFFIX="-$TAG"
cat <<EOF
-
name: Build and push $NAME $TAG
uses: docker/build-push-action@v5
env:
SOURCE_DATE_EPOCH: 0
with:
context: $CONTEXT
tags: |
ghcr.io/yolean/$NAME:$TAG
ghcr.io/yolean/$NAME:\${{ github.sha }}$TAGSUFFIX
platforms: linux/amd64,linux/arm64/v8
push: true
cache-from: type=gha
cache-to: type=gha,mode=max
EOF
}
function add_dependencies {
local CONTEXT=$1
local DEPENDENCIES="$((grep -e 'FROM --platform=$TARGETPLATFORM yolean/' $CONTEXT/Dockerfile || true) | cut -d' ' -f3)"
[ -z "$DEPENDENCIES" ] || echo " build-contexts: |"
for NAME in $DEPENDENCIES; do
echo " $NAME=docker-image://ghcr.io/$NAME"
done
}
for CONTEXT in $MULTIARCH_NONROOT; do
base_action "$CONTEXT" "$CONTEXT" latest >> $ACTIONS
add_dependencies "$CONTEXT" >> $ACTIONS
done
for CONTEXT in $MULTIARCH_TONONROOT; do
mkdir -p to-nonroot/$CONTEXT
echo "FROM --platform=\$TARGETPLATFORM yolean/$CONTEXT:root" > to-nonroot/$CONTEXT/Dockerfile
cat nonroot-footer.Dockerfile >> to-nonroot/$CONTEXT/Dockerfile
base_action "$CONTEXT" "$CONTEXT" root >> $ACTIONS
add_dependencies "$CONTEXT" >> $ACTIONS
base_action "to-nonroot/$CONTEXT" "$CONTEXT" latest >> $ACTIONS
add_dependencies "to-nonroot/$CONTEXT" >> $ACTIONS
done
cp $ACTIONS $CURRENT
GIT_STATUS=$(git status --untracked-files=no --porcelain=v2)
[ -z "$GIT_STATUS" ] && echo "Done, no local diff" || echo "Done, with local diff"