-
Notifications
You must be signed in to change notification settings - Fork 65
/
Copy pathaction.yml
255 lines (240 loc) · 7.95 KB
/
action.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
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
name: Build unikernel images with Unikraft
description: Build, push and run unikernel images with Unikraft.
author: Unikraft
branding:
icon: package
color: blue
inputs:
#
# Global flags
#
after:
description: Bash script to run after the action
required: false
default: ""
run:
description: Run the following script instead of the default command sequence
required: false
auths:
description: Authentication details for services, must be in YAML format
required: false
before:
description: Bash script to run before the action
required: false
default: ""
loglevel:
description: Log-level of the action
required: false
default: error
privileged:
description: Run kraft in a privileged container
required: false
default: "false"
runtimedir:
description: Path to store runtime artifacts
required: false
default: /github/workspace/.kraftkit/runtime
grouprwx:
description: Set group read/write/execute permissions on all files
required: false
default: "true"
manifests:
description: List of Unikraft source manifests
required: false
#
# Project flags
#
kraftfile:
description: Alternative path for the Kraftfile or inline-Kraftfile.
required: false
workdir:
description: Path to the project directory.
required: false
#
# Build flags
#
arch:
description: Architecture to build for.
required: false
build:
description: Toggle building the unikernel.
required: false
default: "true"
plat:
description: Platform to build for.
required: false
target:
description: Name of the target to build for.
required: false
#
# Running flags
#
execute:
description: If to run the unikernel.
required: false
default: "false"
memory:
description: Set the memory size. String of format "1M"/"1G"/"1K"
required: false
timeout:
description: Timeout for the unikernel.
required: false
#
# Packaging flags
#
args:
description: Arguments to pass to the unikernel.
required: false
name:
description: Set the name of the output.
required: true
output:
description: Set the output path.
required: false
push:
description: Push the output to a registry.
required: false
default: "false"
rootfs:
description: Set the root filesystem. This can be an existing CPIO archive or a directory.
required: false
strategy:
description: Merge strategy to use when packaging.
required: false
default: merge
dbg:
description: Use the debug kernel.
required: false
default: "false"
runs:
# Use a composite type so we can set up BuildKit beforehand so that
# `Dockerfile`s can be built as root filesystems. Next, run KraftKit's GitHub
# Action program via Docker which has been built as a container image so that
# all the necessary dependencies for building, packaging and excuting the
# unikernel are available. Attach all known environmental variables and the
# declared input variables to this action. Finally, include the Docker
# authentication config which may have been used prior via the
# `docker/login-action` action, mount the buildkit socket, and mount
# additional paths which are specific to the action including the workspace.
using: composite
steps:
- name: Generate Suffix
shell: bash
id: suffix
run: echo "suffix=$(date +%s)" >> "$GITHUB_OUTPUT"
- name: Set up BuildKit
shell: bash
run: |
docker run \
--rm \
-itd \
--privileged \
--name buildkitd_${GITHUB_RUN_ID}_${SUFFIX} \
-v /run/buildkit:/run/buildkit:rw \
moby/buildkit:v0.18.2;
timeout 60 bash -c 'while [ ! -S "/run/buildkit/buildkitd.sock" ]; do sleep 1; done'
sudo chmod 666 /run/buildkit/buildkitd.sock;
env:
SUFFIX: ${{ steps.suffix.outputs.suffix }}
- name: Set up scripts
shell: bash
run: |
mkdir -p "${GITHUB_WORKSPACE}/.kraftkit"
if [ "${{ inputs.grouprwx }}" = "true" ] && ([ "$(id -u)" != "1001" ] || [ "$(id -g)" != "127" ]); then
cat <<'EOF' > "${GITHUB_WORKSPACE}/.kraftkit/before.sh"
#!/usr/bin/env bash
sudo find /home/runner -exec chmod g+rwx {} +
sudo find /github/workspace -exec chmod g+rwx {} +
sudo chmod g+rwx . || true;
sudo chmod g+rwx "${{ inputs.runtimedir }}" || true;
if [ -n "${{ inputs.workdir }}" ]; then
sudo chmod g+rwx "${{ inputs.workdir }}" || true;
fi
${{ inputs.before }}
EOF
else
cat <<'EOF' > "${GITHUB_WORKSPACE}/.kraftkit/before.sh"
#!/usr/bin/env bash
${{ inputs.before }}
EOF
fi
chmod +x "${GITHUB_WORKSPACE}/.kraftkit/before.sh"
# Always dump the contents of the inputs into relevant files, and simply
# remove if they do not contain any content.
touch "${GITHUB_WORKSPACE}/.kraftkit/run.sh"
cat <<'EOF' >> "${GITHUB_WORKSPACE}/.kraftkit/run.sh"
${{ inputs.run }}
EOF
if [ "$(cat ${GITHUB_WORKSPACE}/.kraftkit/run.sh)" != "" ]; then
cat <<'EOF' > "${GITHUB_WORKSPACE}/.kraftkit/run.sh"
#!/usr/bin/env bash
${{ inputs.run }}
EOF
chmod +x "${GITHUB_WORKSPACE}/.kraftkit/run.sh"
else
rm -f "${GITHUB_WORKSPACE}/.kraftkit/run.sh"
fi
touch "${GITHUB_WORKSPACE}/.kraftkit/after.sh"
cat <<'EOF' >> "${GITHUB_WORKSPACE}/.kraftkit/after.sh"
${{ inputs.after }}
EOF
if [ "$(cat ${GITHUB_WORKSPACE}/.kraftkit/after.sh)" != "" ]; then
cat <<'EOF' > "${GITHUB_WORKSPACE}/.kraftkit/after.sh"
#!/usr/bin/env bash
${{ inputs.after }}
EOF
chmod +x "${GITHUB_WORKSPACE}/.kraftkit/after.sh"
else
rm -f "${GITHUB_WORKSPACE}/.kraftkit/after.sh"
fi
- name: Run kraft
shell: bash
run: |
ACTION_WORKSPACE=$(echo "${GITHUB_WORKSPACE}" | grep -Eo "^.*work")
docker run \
$([ "${{ inputs.privileged }}" = "true" ] && echo -n "--privileged") \
--workdir /github/workspace \
--rm \
--env-file <(env) \
-e "CI=true" \
-e "GITHUB_WORKSPACE=/github/workspace" \
-e "INPUT_ARCH=${{ inputs.arch }}" \
-e "INPUT_ARGS=${{ inputs.args }}" \
-e "INPUT_AUTHS=${{ inputs.auths }}" \
-e "INPUT_BUILD=${{ inputs.build }}" \
-e "INPUT_EXECUTE=${{ inputs.execute }}" \
-e "INPUT_ROOTFS=${{ inputs.rootfs }}" \
-e "INPUT_KRAFTFILE=${{ inputs.kraftfile }}" \
-e "INPUT_LOGLEVEL=${{ inputs.loglevel }}" \
-e "INPUT_MEMORY=${{ inputs.memory }}" \
-e "INPUT_MANIFESTS=${{ inputs.manifests }}" \
-e "INPUT_NAME=${{ inputs.name }}" \
-e "INPUT_OUTPUT=${{ inputs.output }}" \
-e "INPUT_PLAT=${{ inputs.plat }}" \
-e "INPUT_STRATEGY=${{ inputs.strategy }}" \
-e "INPUT_DBG=${{ inputs.dbg }}" \
-e "INPUT_PUSH=${{ inputs.push }}" \
-e "INPUT_RUNTIMEDIR=${{ inputs.runtimedir }}" \
-e "INPUT_TARGET=${{ inputs.target }}" \
-e "INPUT_TIMEOUT=${{ inputs.timeout }}" \
-e "INPUT_WORKDIR=${{ inputs.workdir }}" \
-v "${HOME}/.docker/config.json":"${HOME}/.docker/config.json" \
-v "/run/buildkit/buildkitd.sock":"/run/buildkit/buildkitd.sock" \
-v "${ACTION_WORKSPACE}/_temp/_github_home":"/github/home" \
-v "${ACTION_WORKSPACE}/_temp/_github_workflow":"/github/workflow" \
-v "${ACTION_WORKSPACE}/_temp/_runner_file_commands":"/home/runner/work/_temp/_runner_file_commands" \
-v "${GITHUB_WORKSPACE}":"/github/workspace" \
kraftkit.sh/github-action:v0
- name: Stop BuildKit
if: always()
shell: bash
run: docker stop buildkitd_${GITHUB_RUN_ID}_${SUFFIX} || true
env:
SUFFIX: ${{ steps.suffix.outputs.suffix }}
- name: Cleanup
if: always()
shell: bash
run: |
rm -f "${GITHUB_WORKSPACE}/.kraftkit/before.sh"
rm -f "${GITHUB_WORKSPACE}/.kraftkit/run.sh"
rm -f "${GITHUB_WORKSPACE}/.kraftkit/after.sh"