@catladder/pipeline 1.139.3 โ†’ 1.139.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,1879 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`matches snapshot 1`] = `
4
+ {
5
+ "mainBranch": {
6
+ "image": "path/to/docker/jobs-default:the-version",
7
+ "jobs": {
8
+ "api ๐Ÿ‘ฎ lint": {
9
+ "cache": [
10
+ {
11
+ "key": "app-yarn",
12
+ "paths": [
13
+ "app/.yarn",
14
+ ],
15
+ "policy": "pull-push",
16
+ },
17
+ {
18
+ "key": "app-node-modules",
19
+ "paths": [
20
+ "app/node_modules",
21
+ ],
22
+ "policy": "pull-push",
23
+ },
24
+ ],
25
+ "image": "path/to/docker/jobs-default:the-version",
26
+ "interruptible": true,
27
+ "needs": [],
28
+ "retry": {
29
+ "max": 2,
30
+ "when": [
31
+ "runner_system_failure",
32
+ "stuck_or_timeout_failure",
33
+ ],
34
+ },
35
+ "script": [
36
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
37
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
38
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
39
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
40
+ "cd app",
41
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
42
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
43
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
44
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
45
+ "echo -e "\\e[0Ksection_start:$(date +%s):yarninstall[collapsed=true]\\r\\e[0KYarn install"",
46
+ "yarn install --immutable",
47
+ "echo -e "\\e[0Ksection_end:$(date +%s):yarninstall\\r\\e[0K"",
48
+ "yarn lint",
49
+ ],
50
+ "stage": "test",
51
+ "variables": {
52
+ "APP_PATH": "app",
53
+ "KUBERNETES_CPU_REQUEST": "0.5",
54
+ "KUBERNETES_MEMORY_LIMIT": "4Gi",
55
+ "KUBERNETES_MEMORY_REQUEST": "2Gi",
56
+ },
57
+ },
58
+ "api ๐Ÿ”จ app | dev ": {
59
+ "artifacts": {
60
+ "expire_in": "1 day",
61
+ "paths": [
62
+ "app/__build_info.json",
63
+ "app/dist",
64
+ "app/.next",
65
+ ],
66
+ "reports": {
67
+ "junit": undefined,
68
+ },
69
+ "when": "always",
70
+ },
71
+ "cache": [
72
+ {
73
+ "key": "app-yarn",
74
+ "paths": [
75
+ "app/.yarn",
76
+ ],
77
+ "policy": "pull-push",
78
+ },
79
+ {
80
+ "key": "app-node-modules",
81
+ "paths": [
82
+ "app/node_modules",
83
+ ],
84
+ "policy": "pull-push",
85
+ },
86
+ {
87
+ "key": "api-next-cache",
88
+ "paths": [
89
+ "app/.next/cache/",
90
+ ],
91
+ "policy": "pull-push",
92
+ },
93
+ ],
94
+ "image": "path/to/docker/jobs-default:the-version",
95
+ "interruptible": true,
96
+ "needs": [],
97
+ "retry": {
98
+ "max": 2,
99
+ "when": [
100
+ "runner_system_failure",
101
+ "stuck_or_timeout_failure",
102
+ ],
103
+ },
104
+ "script": [
105
+ "echo '{"id":"some-id","time":"01-01-2023 12:13:14"}' > app/__build_info.json",
106
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
107
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
108
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
109
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
110
+ "cd app",
111
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
112
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
113
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
114
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
115
+ "echo -e "\\e[0Ksection_start:$(date +%s):yarninstall[collapsed=true]\\r\\e[0KYarn install"",
116
+ "yarn install --immutable",
117
+ "echo -e "\\e[0Ksection_end:$(date +%s):yarninstall\\r\\e[0K"",
118
+ "yarn build",
119
+ ],
120
+ "stage": "build",
121
+ "variables": {
122
+ "APP_DIR": "app",
123
+ "BUILD_INFO_BUILD_TIME": "01-01-2023 12:13:14",
124
+ "BUILD_INFO_CURRENT_VERSION": "3.2.1",
125
+ "BUILD_INFO_ID": "some-id",
126
+ "CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock": "https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-dev-api-alarm-clock:run",
127
+ "ENV_SHORT": "dev",
128
+ "ENV_TYPE": "dev",
129
+ "GCLOUD_DEPLOY_credentialsKey": "$CL_dev_api_GCLOUD_DEPLOY_credentialsKey",
130
+ "GCLOUD_RUN_canonicalHostSuffix": "$CL_dev_api_GCLOUD_RUN_canonicalHostSuffix",
131
+ "HOST": "pan-test-app-dev-api-unknown-host.example.com",
132
+ "HOST_CANONICAL": "pan-test-app-dev-api-unknown-host.example.com",
133
+ "HOST_INTERNAL": "pan-test-app-dev-api-unknown-host.example.com",
134
+ "KUBERNETES_CPU_REQUEST": "0.5",
135
+ "KUBERNETES_MEMORY_LIMIT": "4Gi",
136
+ "KUBERNETES_MEMORY_REQUEST": "2Gi",
137
+ "ROOT_URL": "https://pan-test-app-dev-api-unknown-host.example.com",
138
+ "ROOT_URL_INTERNAL": "https://pan-test-app-dev-api-unknown-host.example.com",
139
+ "_ALL_ENV_VAR_KEYS": "["ENV_SHORT","APP_DIR","ENV_TYPE","BUILD_INFO_ID","BUILD_INFO_BUILD_TIME","BUILD_INFO_CURRENT_VERSION","HOST","ROOT_URL","HOST_CANONICAL","ROOT_URL_INTERNAL","HOST_INTERNAL","CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock","GCLOUD_DEPLOY_credentialsKey","GCLOUD_RUN_canonicalHostSuffix"]",
140
+ },
141
+ },
142
+ "api ๐Ÿ”จ docker | dev ": {
143
+ "cache": [
144
+ {
145
+ "key": "app-yarn",
146
+ "paths": [
147
+ "app/.yarn",
148
+ ],
149
+ "policy": "pull",
150
+ },
151
+ ],
152
+ "image": "path/to/docker/docker-build:the-version",
153
+ "interruptible": true,
154
+ "needs": [
155
+ "api ๐Ÿ”จ app | dev ",
156
+ ],
157
+ "retry": {
158
+ "max": 2,
159
+ "when": [
160
+ "runner_system_failure",
161
+ "stuck_or_timeout_failure",
162
+ ],
163
+ },
164
+ "script": [
165
+ "ensureNodeDockerfile",
166
+ "echo -e "\\e[0Ksection_start:$(date +%s):docker-login[collapsed=true]\\r\\e[0KDocker Login"",
167
+ "gcloud auth activate-service-account --key-file=<(echo "$CL_dev_api_GCLOUD_DEPLOY_credentialsKey")",
168
+ "gcloud auth configure-docker asia-east1-docker.pkg.dev",
169
+ "echo -e "\\e[0Ksection_end:$(date +%s):docker-login\\r\\e[0K"",
170
+ "echo -e "\\e[0Ksection_start:$(date +%s):docker-build[collapsed=true]\\r\\e[0KDocker build"",
171
+ "docker build --network host --cache-from $DOCKER_CACHE_IMAGE --tag $DOCKER_IMAGE:$DOCKER_IMAGE_TAG -f $APP_DIR/Dockerfile . --build-arg BUILDKIT_INLINE_CACHE=1",
172
+ "echo -e "\\e[0Ksection_end:$(date +%s):docker-build\\r\\e[0K"",
173
+ "echo -e "\\e[0Ksection_start:$(date +%s):docker-push[collapsed=true]\\r\\e[0KDocker push and tag"",
174
+ "docker push $DOCKER_IMAGE:$DOCKER_IMAGE_TAG",
175
+ "docker tag $DOCKER_IMAGE:$DOCKER_IMAGE_TAG $DOCKER_CACHE_IMAGE",
176
+ "docker push $DOCKER_CACHE_IMAGE",
177
+ "echo -e "\\e[0Ksection_end:$(date +%s):docker-push\\r\\e[0K"",
178
+ ],
179
+ "services": [
180
+ {
181
+ "command": [
182
+ "--tls=false",
183
+ ],
184
+ "name": "docker:24.0.6-dind",
185
+ },
186
+ ],
187
+ "stage": "build",
188
+ "variables": {
189
+ "APP_DIR": "app",
190
+ "DOCKERFILE_ADDITIONS": undefined,
191
+ "DOCKERFILE_ADDITIONS_END": undefined,
192
+ "DOCKER_BUILDKIT": "1",
193
+ "DOCKER_CACHE_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api",
194
+ "DOCKER_COPY_AND_INSTALL_APP": "COPY --chown=node:node $APP_DIR .
195
+ RUN yarn plugin import workspace-tools
196
+ RUN yarn workspaces focus --production && yarn rebuild",
197
+ "DOCKER_COPY_WORKSPACE_FILES": "COPY --chown=node:node app/package.json /app/app/package.json
198
+ COPY --chown=node:node app/yarn.lock /app/app/yarn.lock
199
+ COPY --chown=node:node .yarnrc.yml /app/.yarnrc.yml
200
+ COPY --chown=node:node .yarn /app/.yarn",
201
+ "DOCKER_DIR": ".",
202
+ "DOCKER_DRIVER": "overlay2",
203
+ "DOCKER_HOST": "tcp://0.0.0.0:2375",
204
+ "DOCKER_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/dev/api",
205
+ "DOCKER_IMAGE_TAG": "$CI_COMMIT_SHA",
206
+ "DOCKER_REGISTRY": "asia-east1-docker.pkg.dev",
207
+ "DOCKER_TLS_CERTDIR": "",
208
+ "KUBERNETES_CPU_REQUEST": "0.5",
209
+ "KUBERNETES_MEMORY_LIMIT": "2Gi",
210
+ "KUBERNETES_MEMORY_REQUEST": "1Gi",
211
+ },
212
+ },
213
+ "api ๐Ÿš€ Deploy | dev ": {
214
+ "allow_failure": false,
215
+ "artifacts": {
216
+ "paths": [
217
+ "____envvars.yaml",
218
+ ],
219
+ },
220
+ "environment": {
221
+ "auto_stop_in": "4 weeks",
222
+ "name": "dev/api",
223
+ "on_stop": "api ๐Ÿ›‘ Stop โš ๏ธ | dev ",
224
+ },
225
+ "image": "path/to/docker/gcloud:the-version",
226
+ "interruptible": true,
227
+ "needs": [
228
+ {
229
+ "artifacts": false,
230
+ "job": "api ๐Ÿ‘ฎ lint",
231
+ },
232
+ {
233
+ "artifacts": false,
234
+ "job": "api ๐Ÿ”จ app | dev ",
235
+ },
236
+ {
237
+ "artifacts": false,
238
+ "job": "api ๐Ÿ”จ docker | dev ",
239
+ },
240
+ {
241
+ "artifacts": false,
242
+ "job": "api ๐Ÿงช test",
243
+ },
244
+ {
245
+ "artifacts": true,
246
+ "job": "api ๐Ÿงพ sbom | dev ",
247
+ },
248
+ {
249
+ "artifacts": false,
250
+ "job": "api ๐Ÿ›ก audit",
251
+ },
252
+ ],
253
+ "retry": {
254
+ "max": 2,
255
+ "when": [
256
+ "runner_system_failure",
257
+ "stuck_or_timeout_failure",
258
+ ],
259
+ },
260
+ "rules": [
261
+ {
262
+ "when": "on_success",
263
+ },
264
+ ],
265
+ "script": [
266
+ "echo -e "\\e[0Ksection_start:$(date +%s):prepare[collapsed=true]\\r\\e[0KPrepare..."",
267
+ "gcloud auth activate-service-account --key-file=<(echo "$CL_dev_api_GCLOUD_DEPLOY_credentialsKey")",
268
+ "export GCLOUD_PROJECT_NUMBER=$(gcloud projects describe asdf --format="value(projectNumber)")",
269
+ "echo "GCLOUD_PROJECT_NUMBER: $GCLOUD_PROJECT_NUMBER"",
270
+ "echo -e "\\e[0Ksection_end:$(date +%s):prepare\\r\\e[0K"",
271
+ "echo -e "\\e[0Ksection_start:$(date +%s):deploy[collapsed=true]\\r\\e[0KDeploy to cloud run"",
272
+ "echo "$ENV_VARS" > ____envvars.yaml",
273
+ "set +e",
274
+ "gcloud scheduler jobs create http pan-test-app-dev-api-alarm-clock-scheduler --project=asdf --location=asia-east1 --schedule="0 7 0 0 1-5" --max-retry-attempts=0 --uri="https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-dev-api-alarm-clock:run" --http-method=POST --oauth-service-account-email=$GCLOUD_PROJECT_NUMBER-compute@developer.gserviceaccount.com",
275
+ "set -e",
276
+ "gcloud scheduler jobs update http pan-test-app-dev-api-alarm-clock-scheduler --project=asdf --location=asia-east1 --schedule="0 7 0 0 1-5" --max-retry-attempts=0 --uri="https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-dev-api-alarm-clock:run" --http-method=POST --oauth-service-account-email=$GCLOUD_PROJECT_NUMBER-compute@developer.gserviceaccount.com",
277
+ "set +e",
278
+ "gcloud run jobs create pan-test-app-dev-api-alarm-clock --command="./wake-up-call" --image=asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/dev/api:$DOCKER_IMAGE_TAG --project=asdf --region=asia-east1 --labels=customer-name=pan,component-name=api,app-name=test-app,env-type=dev,env-name=dev,build-type=node,cloud-run-job-name=pan-test-app-dev-api-alarm-clock --memory=512Mi --task-timeout=10m --parallelism=1 --env-vars-file=____envvars.yaml --max-retries=0",
279
+ "set -e",
280
+ "gcloud run jobs update pan-test-app-dev-api-alarm-clock --command="./wake-up-call" --image=asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/dev/api:$DOCKER_IMAGE_TAG --project=asdf --region=asia-east1 --labels=customer-name=pan,component-name=api,app-name=test-app,env-type=dev,env-name=dev,build-type=node,cloud-run-job-name=pan-test-app-dev-api-alarm-clock --memory=512Mi --task-timeout=10m --parallelism=1 --env-vars-file=____envvars.yaml --max-retries=0 ",
281
+ "echo -e "\\e[0Ksection_end:$(date +%s):deploy\\r\\e[0K"",
282
+ "echo -e "\\e[0Ksection_start:$(date +%s):cleanup[collapsed=true]\\r\\e[0KCleanup"",
283
+ "gcloud run revisions list --project=asdf --region=asia-east1 --service=pan-test-app-dev-api --limit=unlimited --sort-by=metadata.creationTimestamp --format="value(name)" --filter='(status.conditions.status=False OR status.conditions.status=Unknown)' | while read -r revisionname; do gcloud run revisions delete --project=asdf --region=asia-east1 --quiet $revisionname ; done",
284
+ "gcloud artifacts docker images list asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/dev/api --sort-by=~CREATE_TIME --format="value(version)" | tail -n +2 | while read -r version; do gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/dev/api@$version --quiet --delete-tags; done",
285
+ "gcloud artifacts docker images list asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api --sort-by=~CREATE_TIME --format="value(version)" | tail -n +2 | while read -r version; do gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api@$version --quiet --delete-tags; done",
286
+ "echo -e "\\e[0Ksection_end:$(date +%s):cleanup\\r\\e[0K"",
287
+ "echo Uploading SBOM to Dependency Track",
288
+ "/dtrackuploader https://dep.panter.swiss/ "$DT_KEY_PROD" upload "pan-test-app/api" "https://pan-test-app-dev-api-unknown-host.example.com" "__sbom.json" vex.json || true",
289
+ ],
290
+ "services": [
291
+ {
292
+ "command": [
293
+ "--tls=false",
294
+ ],
295
+ "name": "docker:24.0.6-dind",
296
+ },
297
+ ],
298
+ "stage": "deploy dev",
299
+ "variables": {
300
+ "APP_DIR": "app",
301
+ "BUILD_INFO_BUILD_TIME": "01-01-2023 12:13:14",
302
+ "BUILD_INFO_CURRENT_VERSION": "3.2.1",
303
+ "BUILD_INFO_ID": "some-id",
304
+ "CLOUDSDK_CORE_DISABLE_PROMPTS": "1",
305
+ "CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock": "https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-dev-api-alarm-clock:run",
306
+ "DOCKER_BUILDKIT": "1",
307
+ "DOCKER_CACHE_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api",
308
+ "DOCKER_DRIVER": "overlay2",
309
+ "DOCKER_HOST": "tcp://0.0.0.0:2375",
310
+ "DOCKER_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/dev/api",
311
+ "DOCKER_IMAGE_TAG": "$CI_COMMIT_SHA",
312
+ "DOCKER_REGISTRY": "asia-east1-docker.pkg.dev",
313
+ "DOCKER_TLS_CERTDIR": "",
314
+ "ENV_SHORT": "dev",
315
+ "ENV_TYPE": "dev",
316
+ "ENV_VARS": "ENV_SHORT: 'dev'
317
+ APP_DIR: 'app'
318
+ ENV_TYPE: 'dev'
319
+ BUILD_INFO_ID: 'some-id'
320
+ BUILD_INFO_BUILD_TIME: '01-01-2023 12:13:14'
321
+ BUILD_INFO_CURRENT_VERSION: '3.2.1'
322
+ HOST: 'pan-test-app-dev-api-unknown-host.example.com'
323
+ ROOT_URL: 'https://pan-test-app-dev-api-unknown-host.example.com'
324
+ HOST_CANONICAL: 'pan-test-app-dev-api-unknown-host.example.com'
325
+ ROOT_URL_INTERNAL: 'https://pan-test-app-dev-api-unknown-host.example.com'
326
+ HOST_INTERNAL: 'pan-test-app-dev-api-unknown-host.example.com'
327
+ CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock: 'https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-dev-api-alarm-clock:run'
328
+ GCLOUD_RUN_canonicalHostSuffix: '$CL_dev_api_GCLOUD_RUN_canonicalHostSuffix'
329
+ _ALL_ENV_VAR_KEYS: '["ENV_SHORT","APP_DIR","ENV_TYPE","BUILD_INFO_ID","BUILD_INFO_BUILD_TIME","BUILD_INFO_CURRENT_VERSION","HOST","ROOT_URL","HOST_CANONICAL","ROOT_URL_INTERNAL","HOST_INTERNAL","CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock","GCLOUD_DEPLOY_credentialsKey","GCLOUD_RUN_canonicalHostSuffix"]'
330
+ ",
331
+ "GCLOUD_DEPLOY_credentialsKey": "$CL_dev_api_GCLOUD_DEPLOY_credentialsKey",
332
+ "GCLOUD_RUN_canonicalHostSuffix": "$CL_dev_api_GCLOUD_RUN_canonicalHostSuffix",
333
+ "HOST": "pan-test-app-dev-api-unknown-host.example.com",
334
+ "HOST_CANONICAL": "pan-test-app-dev-api-unknown-host.example.com",
335
+ "HOST_INTERNAL": "pan-test-app-dev-api-unknown-host.example.com",
336
+ "KUBERNETES_CPU_REQUEST": "0.5",
337
+ "KUBERNETES_MEMORY_LIMIT": "400Mi",
338
+ "KUBERNETES_MEMORY_REQUEST": "200Mi",
339
+ "ROOT_URL": "https://pan-test-app-dev-api-unknown-host.example.com",
340
+ "ROOT_URL_INTERNAL": "https://pan-test-app-dev-api-unknown-host.example.com",
341
+ "_ALL_ENV_VAR_KEYS": "["ENV_SHORT","APP_DIR","ENV_TYPE","BUILD_INFO_ID","BUILD_INFO_BUILD_TIME","BUILD_INFO_CURRENT_VERSION","HOST","ROOT_URL","HOST_CANONICAL","ROOT_URL_INTERNAL","HOST_INTERNAL","CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock","GCLOUD_DEPLOY_credentialsKey","GCLOUD_RUN_canonicalHostSuffix"]",
342
+ },
343
+ },
344
+ "api ๐Ÿ›‘ Stop โš ๏ธ | dev ": {
345
+ "environment": {
346
+ "action": "stop",
347
+ "name": "dev/api",
348
+ },
349
+ "image": "path/to/docker/gcloud:the-version",
350
+ "interruptible": true,
351
+ "needs": [],
352
+ "retry": {
353
+ "max": 2,
354
+ "when": [
355
+ "runner_system_failure",
356
+ "stuck_or_timeout_failure",
357
+ ],
358
+ },
359
+ "rules": [
360
+ {
361
+ "allow_failure": true,
362
+ "if": "$CI_COMMIT_BRANCH =~ /^[0-9]+\\.([0-9]+|x)\\.x$/",
363
+ "when": "on_success",
364
+ },
365
+ {
366
+ "allow_failure": true,
367
+ "when": "manual",
368
+ },
369
+ ],
370
+ "script": [
371
+ "set +e",
372
+ "gcloud auth activate-service-account --key-file=<(echo "$CL_dev_api_GCLOUD_DEPLOY_credentialsKey")",
373
+ "gcloud scheduler jobs delete pan-test-app-dev-api-alarm-clock-scheduler --project=asdf --location=asia-east1",
374
+ "gcloud run jobs executions list --project=asdf --region=asia-east1 --job pan-test-app-dev-api-alarm-clock --format="value(name)" | xargs -I {} gcloud run jobs executions delete {} --quiet --project=asdf --region=asia-east1",
375
+ "gcloud run jobs delete pan-test-app-dev-api-alarm-clock --project=asdf --region=asia-east1",
376
+ "gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/dev/api --quiet --delete-tags",
377
+ "gcloud artifacts docker images list asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api --sort-by=~CREATE_TIME --format="value(version)" | tail -n +2 | while read -r version; do gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api@$version --quiet --delete-tags; done",
378
+ "echo Disabling component in Dependency Track",
379
+ "/dtrackuploader https://dep.panter.swiss/ "$DT_KEY_PROD" disable "pan-test-app/api" "https://pan-test-app-dev-api-unknown-host.example.com" || true",
380
+ "set -e",
381
+ ],
382
+ "stage": "stop dev",
383
+ "variables": {
384
+ "CLOUDSDK_CORE_DISABLE_PROMPTS": "1",
385
+ "GIT_STRATEGY": "none",
386
+ "KUBERNETES_CPU_REQUEST": "0.5",
387
+ "KUBERNETES_MEMORY_LIMIT": "400Mi",
388
+ "KUBERNETES_MEMORY_REQUEST": "200Mi",
389
+ },
390
+ },
391
+ "api ๐Ÿ›ก audit": {
392
+ "allow_failure": true,
393
+ "image": "path/to/docker/jobs-default:the-version",
394
+ "interruptible": true,
395
+ "needs": [],
396
+ "retry": {
397
+ "max": 2,
398
+ "when": [
399
+ "runner_system_failure",
400
+ "stuck_or_timeout_failure",
401
+ ],
402
+ },
403
+ "script": [
404
+ "cd app",
405
+ "yarn npm audit --environment production",
406
+ ],
407
+ "stage": "test",
408
+ "variables": {
409
+ "APP_PATH": "app",
410
+ "KUBERNETES_CPU_REQUEST": "0.5",
411
+ "KUBERNETES_MEMORY_LIMIT": "4Gi",
412
+ "KUBERNETES_MEMORY_REQUEST": "2Gi",
413
+ },
414
+ },
415
+ "api ๐Ÿงช test": {
416
+ "cache": [
417
+ {
418
+ "key": "app-yarn",
419
+ "paths": [
420
+ "app/.yarn",
421
+ ],
422
+ "policy": "pull-push",
423
+ },
424
+ {
425
+ "key": "app-node-modules",
426
+ "paths": [
427
+ "app/node_modules",
428
+ ],
429
+ "policy": "pull-push",
430
+ },
431
+ ],
432
+ "image": "path/to/docker/jobs-testing-chrome:the-version",
433
+ "interruptible": true,
434
+ "needs": [],
435
+ "retry": {
436
+ "max": 2,
437
+ "when": [
438
+ "runner_system_failure",
439
+ "stuck_or_timeout_failure",
440
+ ],
441
+ },
442
+ "script": [
443
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
444
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
445
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
446
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
447
+ "cd app",
448
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
449
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
450
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
451
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
452
+ "echo -e "\\e[0Ksection_start:$(date +%s):yarninstall[collapsed=true]\\r\\e[0KYarn install"",
453
+ "yarn install --immutable",
454
+ "echo -e "\\e[0Ksection_end:$(date +%s):yarninstall\\r\\e[0K"",
455
+ "yarn test",
456
+ ],
457
+ "stage": "test",
458
+ "variables": {
459
+ "APP_PATH": "app",
460
+ "KUBERNETES_CPU_REQUEST": "0.5",
461
+ "KUBERNETES_MEMORY_LIMIT": "4Gi",
462
+ "KUBERNETES_MEMORY_REQUEST": "2Gi",
463
+ },
464
+ },
465
+ "api ๐Ÿงพ sbom | dev ": {
466
+ "allow_failure": true,
467
+ "artifacts": {
468
+ "paths": [
469
+ "__sbom.json",
470
+ ],
471
+ },
472
+ "image": "aquasec/trivy:0.38.3",
473
+ "interruptible": true,
474
+ "needs": [],
475
+ "retry": {
476
+ "max": 2,
477
+ "when": [
478
+ "runner_system_failure",
479
+ "stuck_or_timeout_failure",
480
+ ],
481
+ },
482
+ "script": [
483
+ "trivy fs --quiet --format cyclonedx --output "__sbom.json" app",
484
+ ],
485
+ "stage": "build",
486
+ "variables": {},
487
+ },
488
+ },
489
+ "stages": [
490
+ "setup",
491
+ "setup dev",
492
+ "setup review",
493
+ "setup stage",
494
+ "setup prod",
495
+ "setup local",
496
+ "test",
497
+ "test dev",
498
+ "test review",
499
+ "test stage",
500
+ "test prod",
501
+ "test local",
502
+ "build",
503
+ "build dev",
504
+ "build review",
505
+ "build stage",
506
+ "build prod",
507
+ "build local",
508
+ "deploy",
509
+ "deploy dev",
510
+ "deploy review",
511
+ "deploy stage",
512
+ "deploy prod",
513
+ "deploy local",
514
+ "verify",
515
+ "verify dev",
516
+ "verify review",
517
+ "verify stage",
518
+ "verify prod",
519
+ "verify local",
520
+ "rollback",
521
+ "rollback dev",
522
+ "rollback review",
523
+ "rollback stage",
524
+ "rollback prod",
525
+ "rollback local",
526
+ "stop",
527
+ "stop dev",
528
+ "stop review",
529
+ "stop stage",
530
+ "stop prod",
531
+ "stop local",
532
+ ],
533
+ "variables": {
534
+ "FF_USE_FASTZIP": "true",
535
+ "GIT_DEPTH": 1,
536
+ },
537
+ "workflow": {
538
+ "rules": [
539
+ {
540
+ "if": "$CI_COMMIT_TAG",
541
+ },
542
+ {
543
+ "if": "$CI_COMMIT_MESSAGE =~ /^chore\\(release\\).*/",
544
+ "when": "never",
545
+ },
546
+ {
547
+ "if": "$CI_COMMIT_BRANCH =~ /^[0-9]+.([0-9]+|x).x$/",
548
+ },
549
+ {
550
+ "if": "$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH",
551
+ },
552
+ {
553
+ "if": "$CI_MERGE_REQUEST_ID",
554
+ },
555
+ ],
556
+ },
557
+ },
558
+ "mr": {
559
+ "image": "path/to/docker/jobs-default:the-version",
560
+ "jobs": {
561
+ "api ๐Ÿ‘ฎ lint": {
562
+ "cache": [
563
+ {
564
+ "key": "app-yarn",
565
+ "paths": [
566
+ "app/.yarn",
567
+ ],
568
+ "policy": "pull-push",
569
+ },
570
+ {
571
+ "key": "app-node-modules",
572
+ "paths": [
573
+ "app/node_modules",
574
+ ],
575
+ "policy": "pull-push",
576
+ },
577
+ ],
578
+ "image": "path/to/docker/jobs-default:the-version",
579
+ "interruptible": true,
580
+ "needs": [],
581
+ "retry": {
582
+ "max": 2,
583
+ "when": [
584
+ "runner_system_failure",
585
+ "stuck_or_timeout_failure",
586
+ ],
587
+ },
588
+ "script": [
589
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
590
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
591
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
592
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
593
+ "cd app",
594
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
595
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
596
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
597
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
598
+ "echo -e "\\e[0Ksection_start:$(date +%s):yarninstall[collapsed=true]\\r\\e[0KYarn install"",
599
+ "yarn install --immutable",
600
+ "echo -e "\\e[0Ksection_end:$(date +%s):yarninstall\\r\\e[0K"",
601
+ "yarn lint",
602
+ ],
603
+ "stage": "test",
604
+ "variables": {
605
+ "APP_PATH": "app",
606
+ "KUBERNETES_CPU_REQUEST": "0.5",
607
+ "KUBERNETES_MEMORY_LIMIT": "4Gi",
608
+ "KUBERNETES_MEMORY_REQUEST": "2Gi",
609
+ },
610
+ },
611
+ "api ๐Ÿ”จ app | review ": {
612
+ "artifacts": {
613
+ "expire_in": "1 day",
614
+ "paths": [
615
+ "app/__build_info.json",
616
+ "app/dist",
617
+ "app/.next",
618
+ ],
619
+ "reports": {
620
+ "junit": undefined,
621
+ },
622
+ "when": "always",
623
+ },
624
+ "cache": [
625
+ {
626
+ "key": "app-yarn",
627
+ "paths": [
628
+ "app/.yarn",
629
+ ],
630
+ "policy": "pull-push",
631
+ },
632
+ {
633
+ "key": "app-node-modules",
634
+ "paths": [
635
+ "app/node_modules",
636
+ ],
637
+ "policy": "pull-push",
638
+ },
639
+ {
640
+ "key": "api-next-cache",
641
+ "paths": [
642
+ "app/.next/cache/",
643
+ ],
644
+ "policy": "pull-push",
645
+ },
646
+ ],
647
+ "image": "path/to/docker/jobs-default:the-version",
648
+ "interruptible": true,
649
+ "needs": [],
650
+ "retry": {
651
+ "max": 2,
652
+ "when": [
653
+ "runner_system_failure",
654
+ "stuck_or_timeout_failure",
655
+ ],
656
+ },
657
+ "script": [
658
+ "echo '{"id":"some-id","time":"01-01-2023 12:13:14"}' > app/__build_info.json",
659
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
660
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
661
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
662
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
663
+ "cd app",
664
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
665
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
666
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
667
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
668
+ "echo -e "\\e[0Ksection_start:$(date +%s):yarninstall[collapsed=true]\\r\\e[0KYarn install"",
669
+ "yarn install --immutable",
670
+ "echo -e "\\e[0Ksection_end:$(date +%s):yarninstall\\r\\e[0K"",
671
+ "yarn build",
672
+ ],
673
+ "stage": "build",
674
+ "variables": {
675
+ "APP_DIR": "app",
676
+ "BUILD_INFO_BUILD_TIME": "01-01-2023 12:13:14",
677
+ "BUILD_INFO_CURRENT_VERSION": "3.2.1",
678
+ "BUILD_INFO_ID": "some-id",
679
+ "CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock": "https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-review-mr1234-api-alarm-clock:run",
680
+ "ENV_SHORT": "review",
681
+ "ENV_TYPE": "review",
682
+ "GCLOUD_DEPLOY_credentialsKey": "$CL_review_api_GCLOUD_DEPLOY_credentialsKey",
683
+ "GCLOUD_RUN_canonicalHostSuffix": "$CL_review_api_GCLOUD_RUN_canonicalHostSuffix",
684
+ "HOST": "pan-test-app-review-mr1234-api-unknown-host.example.com",
685
+ "HOST_CANONICAL": "pan-test-app-review-mr1234-api-unknown-host.example.com",
686
+ "HOST_INTERNAL": "pan-test-app-review-mr1234-api-unknown-host.example.com",
687
+ "KUBERNETES_CPU_REQUEST": "0.5",
688
+ "KUBERNETES_MEMORY_LIMIT": "4Gi",
689
+ "KUBERNETES_MEMORY_REQUEST": "2Gi",
690
+ "ROOT_URL": "https://pan-test-app-review-mr1234-api-unknown-host.example.com",
691
+ "ROOT_URL_INTERNAL": "https://pan-test-app-review-mr1234-api-unknown-host.example.com",
692
+ "_ALL_ENV_VAR_KEYS": "["ENV_SHORT","APP_DIR","ENV_TYPE","BUILD_INFO_ID","BUILD_INFO_BUILD_TIME","BUILD_INFO_CURRENT_VERSION","HOST","ROOT_URL","HOST_CANONICAL","ROOT_URL_INTERNAL","HOST_INTERNAL","CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock","GCLOUD_DEPLOY_credentialsKey","GCLOUD_RUN_canonicalHostSuffix"]",
693
+ },
694
+ },
695
+ "api ๐Ÿ”จ docker | review ": {
696
+ "cache": [
697
+ {
698
+ "key": "app-yarn",
699
+ "paths": [
700
+ "app/.yarn",
701
+ ],
702
+ "policy": "pull",
703
+ },
704
+ ],
705
+ "image": "path/to/docker/docker-build:the-version",
706
+ "interruptible": true,
707
+ "needs": [
708
+ "api ๐Ÿ”จ app | review ",
709
+ ],
710
+ "retry": {
711
+ "max": 2,
712
+ "when": [
713
+ "runner_system_failure",
714
+ "stuck_or_timeout_failure",
715
+ ],
716
+ },
717
+ "script": [
718
+ "ensureNodeDockerfile",
719
+ "echo -e "\\e[0Ksection_start:$(date +%s):docker-login[collapsed=true]\\r\\e[0KDocker Login"",
720
+ "gcloud auth activate-service-account --key-file=<(echo "$CL_review_api_GCLOUD_DEPLOY_credentialsKey")",
721
+ "gcloud auth configure-docker asia-east1-docker.pkg.dev",
722
+ "echo -e "\\e[0Ksection_end:$(date +%s):docker-login\\r\\e[0K"",
723
+ "echo -e "\\e[0Ksection_start:$(date +%s):docker-build[collapsed=true]\\r\\e[0KDocker build"",
724
+ "docker build --network host --cache-from $DOCKER_CACHE_IMAGE --tag $DOCKER_IMAGE:$DOCKER_IMAGE_TAG -f $APP_DIR/Dockerfile . --build-arg BUILDKIT_INLINE_CACHE=1",
725
+ "echo -e "\\e[0Ksection_end:$(date +%s):docker-build\\r\\e[0K"",
726
+ "echo -e "\\e[0Ksection_start:$(date +%s):docker-push[collapsed=true]\\r\\e[0KDocker push and tag"",
727
+ "docker push $DOCKER_IMAGE:$DOCKER_IMAGE_TAG",
728
+ "docker tag $DOCKER_IMAGE:$DOCKER_IMAGE_TAG $DOCKER_CACHE_IMAGE",
729
+ "docker push $DOCKER_CACHE_IMAGE",
730
+ "echo -e "\\e[0Ksection_end:$(date +%s):docker-push\\r\\e[0K"",
731
+ ],
732
+ "services": [
733
+ {
734
+ "command": [
735
+ "--tls=false",
736
+ ],
737
+ "name": "docker:24.0.6-dind",
738
+ },
739
+ ],
740
+ "stage": "build",
741
+ "variables": {
742
+ "APP_DIR": "app",
743
+ "DOCKERFILE_ADDITIONS": undefined,
744
+ "DOCKERFILE_ADDITIONS_END": undefined,
745
+ "DOCKER_BUILDKIT": "1",
746
+ "DOCKER_CACHE_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api",
747
+ "DOCKER_COPY_AND_INSTALL_APP": "COPY --chown=node:node $APP_DIR .
748
+ RUN yarn plugin import workspace-tools
749
+ RUN yarn workspaces focus --production && yarn rebuild",
750
+ "DOCKER_COPY_WORKSPACE_FILES": "COPY --chown=node:node app/package.json /app/app/package.json
751
+ COPY --chown=node:node app/yarn.lock /app/app/yarn.lock
752
+ COPY --chown=node:node .yarnrc.yml /app/.yarnrc.yml
753
+ COPY --chown=node:node .yarn /app/.yarn",
754
+ "DOCKER_DIR": ".",
755
+ "DOCKER_DRIVER": "overlay2",
756
+ "DOCKER_HOST": "tcp://0.0.0.0:2375",
757
+ "DOCKER_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/review/api/mr1234",
758
+ "DOCKER_IMAGE_TAG": "$CI_COMMIT_SHA",
759
+ "DOCKER_REGISTRY": "asia-east1-docker.pkg.dev",
760
+ "DOCKER_TLS_CERTDIR": "",
761
+ "KUBERNETES_CPU_REQUEST": "0.5",
762
+ "KUBERNETES_MEMORY_LIMIT": "2Gi",
763
+ "KUBERNETES_MEMORY_REQUEST": "1Gi",
764
+ },
765
+ },
766
+ "api ๐Ÿš€ Deploy | review ": {
767
+ "allow_failure": false,
768
+ "artifacts": {
769
+ "paths": [
770
+ "____envvars.yaml",
771
+ ],
772
+ },
773
+ "environment": {
774
+ "auto_stop_in": "1 week",
775
+ "name": "review/some-commit/api",
776
+ "on_stop": "api ๐Ÿ›‘ Stop โš ๏ธ | review ",
777
+ },
778
+ "image": "path/to/docker/gcloud:the-version",
779
+ "interruptible": true,
780
+ "needs": [
781
+ {
782
+ "artifacts": false,
783
+ "job": "api ๐Ÿ‘ฎ lint",
784
+ },
785
+ {
786
+ "artifacts": false,
787
+ "job": "api ๐Ÿ”จ app | review ",
788
+ },
789
+ {
790
+ "artifacts": false,
791
+ "job": "api ๐Ÿ”จ docker | review ",
792
+ },
793
+ {
794
+ "artifacts": false,
795
+ "job": "api ๐Ÿงช test",
796
+ },
797
+ {
798
+ "artifacts": true,
799
+ "job": "api ๐Ÿงพ sbom | review ",
800
+ },
801
+ {
802
+ "artifacts": false,
803
+ "job": "api ๐Ÿ›ก audit",
804
+ },
805
+ ],
806
+ "retry": {
807
+ "max": 2,
808
+ "when": [
809
+ "runner_system_failure",
810
+ "stuck_or_timeout_failure",
811
+ ],
812
+ },
813
+ "rules": [
814
+ {
815
+ "when": "on_success",
816
+ },
817
+ ],
818
+ "script": [
819
+ "echo -e "\\e[0Ksection_start:$(date +%s):prepare[collapsed=true]\\r\\e[0KPrepare..."",
820
+ "gcloud auth activate-service-account --key-file=<(echo "$CL_review_api_GCLOUD_DEPLOY_credentialsKey")",
821
+ "export GCLOUD_PROJECT_NUMBER=$(gcloud projects describe asdf --format="value(projectNumber)")",
822
+ "echo "GCLOUD_PROJECT_NUMBER: $GCLOUD_PROJECT_NUMBER"",
823
+ "echo -e "\\e[0Ksection_end:$(date +%s):prepare\\r\\e[0K"",
824
+ "echo -e "\\e[0Ksection_start:$(date +%s):deploy[collapsed=true]\\r\\e[0KDeploy to cloud run"",
825
+ "echo "$ENV_VARS" > ____envvars.yaml",
826
+ "set +e",
827
+ "gcloud scheduler jobs create http pan-test-app-review-mr1234-api-alarm-clock-scheduler --project=asdf --location=asia-east1 --schedule="0 7 0 0 1-5" --max-retry-attempts=0 --uri="https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-review-mr1234-api-alarm-clock:run" --http-method=POST --oauth-service-account-email=$GCLOUD_PROJECT_NUMBER-compute@developer.gserviceaccount.com",
828
+ "set -e",
829
+ "gcloud scheduler jobs update http pan-test-app-review-mr1234-api-alarm-clock-scheduler --project=asdf --location=asia-east1 --schedule="0 7 0 0 1-5" --max-retry-attempts=0 --uri="https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-review-mr1234-api-alarm-clock:run" --http-method=POST --oauth-service-account-email=$GCLOUD_PROJECT_NUMBER-compute@developer.gserviceaccount.com",
830
+ "set +e",
831
+ "gcloud run jobs create pan-test-app-review-mr1234-api-alarm-clock --command="./wake-up-call" --image=asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/review/api/mr1234:$DOCKER_IMAGE_TAG --project=asdf --region=asia-east1 --labels=customer-name=pan,component-name=api,app-name=test-app,env-type=review,env-name=review,build-type=node,cloud-run-job-name=pan-test-app-review-mr1234-api-alarm-clock --memory=512Mi --task-timeout=10m --parallelism=1 --env-vars-file=____envvars.yaml --max-retries=0",
832
+ "set -e",
833
+ "gcloud run jobs update pan-test-app-review-mr1234-api-alarm-clock --command="./wake-up-call" --image=asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/review/api/mr1234:$DOCKER_IMAGE_TAG --project=asdf --region=asia-east1 --labels=customer-name=pan,component-name=api,app-name=test-app,env-type=review,env-name=review,build-type=node,cloud-run-job-name=pan-test-app-review-mr1234-api-alarm-clock --memory=512Mi --task-timeout=10m --parallelism=1 --env-vars-file=____envvars.yaml --max-retries=0 ",
834
+ "echo -e "\\e[0Ksection_end:$(date +%s):deploy\\r\\e[0K"",
835
+ "echo -e "\\e[0Ksection_start:$(date +%s):cleanup[collapsed=true]\\r\\e[0KCleanup"",
836
+ "gcloud run revisions list --project=asdf --region=asia-east1 --service=pan-test-app-review-mr1234-api --limit=unlimited --sort-by=metadata.creationTimestamp --format="value(name)" --filter='(status.conditions.status=False OR status.conditions.status=Unknown)' | while read -r revisionname; do gcloud run revisions delete --project=asdf --region=asia-east1 --quiet $revisionname ; done",
837
+ "gcloud artifacts docker images list asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/review/api/mr1234 --sort-by=~CREATE_TIME --format="value(version)" | tail -n +2 | while read -r version; do gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/review/api/mr1234@$version --quiet --delete-tags; done",
838
+ "gcloud artifacts docker images list asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api --sort-by=~CREATE_TIME --format="value(version)" | tail -n +2 | while read -r version; do gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api@$version --quiet --delete-tags; done",
839
+ "set +e",
840
+ "gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/review/api --quiet --delete-tags",
841
+ "set -e",
842
+ "echo -e "\\e[0Ksection_end:$(date +%s):cleanup\\r\\e[0K"",
843
+ "echo Uploading SBOM to Dependency Track",
844
+ "/dtrackuploader https://dep.panter.swiss/ "$DT_KEY_PROD" upload "pan-test-app/api" "https://pan-test-app-review-mr1234-api-unknown-host.example.com" "__sbom.json" vex.json || true",
845
+ ],
846
+ "services": [
847
+ {
848
+ "command": [
849
+ "--tls=false",
850
+ ],
851
+ "name": "docker:24.0.6-dind",
852
+ },
853
+ ],
854
+ "stage": "deploy review",
855
+ "variables": {
856
+ "APP_DIR": "app",
857
+ "BUILD_INFO_BUILD_TIME": "01-01-2023 12:13:14",
858
+ "BUILD_INFO_CURRENT_VERSION": "3.2.1",
859
+ "BUILD_INFO_ID": "some-id",
860
+ "CLOUDSDK_CORE_DISABLE_PROMPTS": "1",
861
+ "CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock": "https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-review-mr1234-api-alarm-clock:run",
862
+ "DOCKER_BUILDKIT": "1",
863
+ "DOCKER_CACHE_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api",
864
+ "DOCKER_DRIVER": "overlay2",
865
+ "DOCKER_HOST": "tcp://0.0.0.0:2375",
866
+ "DOCKER_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/review/api/mr1234",
867
+ "DOCKER_IMAGE_TAG": "$CI_COMMIT_SHA",
868
+ "DOCKER_REGISTRY": "asia-east1-docker.pkg.dev",
869
+ "DOCKER_TLS_CERTDIR": "",
870
+ "ENV_SHORT": "review",
871
+ "ENV_TYPE": "review",
872
+ "ENV_VARS": "ENV_SHORT: 'review'
873
+ APP_DIR: 'app'
874
+ ENV_TYPE: 'review'
875
+ BUILD_INFO_ID: 'some-id'
876
+ BUILD_INFO_BUILD_TIME: '01-01-2023 12:13:14'
877
+ BUILD_INFO_CURRENT_VERSION: '3.2.1'
878
+ HOST: 'pan-test-app-review-mr1234-api-unknown-host.example.com'
879
+ ROOT_URL: 'https://pan-test-app-review-mr1234-api-unknown-host.example.com'
880
+ HOST_CANONICAL: 'pan-test-app-review-mr1234-api-unknown-host.example.com'
881
+ ROOT_URL_INTERNAL: 'https://pan-test-app-review-mr1234-api-unknown-host.example.com'
882
+ HOST_INTERNAL: 'pan-test-app-review-mr1234-api-unknown-host.example.com'
883
+ CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock: 'https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-review-mr1234-api-alarm-clock:run'
884
+ GCLOUD_RUN_canonicalHostSuffix: '$CL_review_api_GCLOUD_RUN_canonicalHostSuffix'
885
+ _ALL_ENV_VAR_KEYS: '["ENV_SHORT","APP_DIR","ENV_TYPE","BUILD_INFO_ID","BUILD_INFO_BUILD_TIME","BUILD_INFO_CURRENT_VERSION","HOST","ROOT_URL","HOST_CANONICAL","ROOT_URL_INTERNAL","HOST_INTERNAL","CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock","GCLOUD_DEPLOY_credentialsKey","GCLOUD_RUN_canonicalHostSuffix"]'
886
+ ",
887
+ "GCLOUD_DEPLOY_credentialsKey": "$CL_review_api_GCLOUD_DEPLOY_credentialsKey",
888
+ "GCLOUD_RUN_canonicalHostSuffix": "$CL_review_api_GCLOUD_RUN_canonicalHostSuffix",
889
+ "HOST": "pan-test-app-review-mr1234-api-unknown-host.example.com",
890
+ "HOST_CANONICAL": "pan-test-app-review-mr1234-api-unknown-host.example.com",
891
+ "HOST_INTERNAL": "pan-test-app-review-mr1234-api-unknown-host.example.com",
892
+ "KUBERNETES_CPU_REQUEST": "0.5",
893
+ "KUBERNETES_MEMORY_LIMIT": "400Mi",
894
+ "KUBERNETES_MEMORY_REQUEST": "200Mi",
895
+ "ROOT_URL": "https://pan-test-app-review-mr1234-api-unknown-host.example.com",
896
+ "ROOT_URL_INTERNAL": "https://pan-test-app-review-mr1234-api-unknown-host.example.com",
897
+ "_ALL_ENV_VAR_KEYS": "["ENV_SHORT","APP_DIR","ENV_TYPE","BUILD_INFO_ID","BUILD_INFO_BUILD_TIME","BUILD_INFO_CURRENT_VERSION","HOST","ROOT_URL","HOST_CANONICAL","ROOT_URL_INTERNAL","HOST_INTERNAL","CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock","GCLOUD_DEPLOY_credentialsKey","GCLOUD_RUN_canonicalHostSuffix"]",
898
+ },
899
+ },
900
+ "api ๐Ÿ›‘ Stop โš ๏ธ | review ": {
901
+ "environment": {
902
+ "action": "stop",
903
+ "name": "review/some-commit/api",
904
+ },
905
+ "image": "path/to/docker/gcloud:the-version",
906
+ "interruptible": true,
907
+ "needs": [],
908
+ "retry": {
909
+ "max": 2,
910
+ "when": [
911
+ "runner_system_failure",
912
+ "stuck_or_timeout_failure",
913
+ ],
914
+ },
915
+ "rules": [
916
+ {
917
+ "allow_failure": true,
918
+ "if": "$CI_COMMIT_BRANCH =~ /^[0-9]+\\.([0-9]+|x)\\.x$/",
919
+ "when": "on_success",
920
+ },
921
+ {
922
+ "allow_failure": true,
923
+ "when": "manual",
924
+ },
925
+ ],
926
+ "script": [
927
+ "set +e",
928
+ "gcloud auth activate-service-account --key-file=<(echo "$CL_review_api_GCLOUD_DEPLOY_credentialsKey")",
929
+ "gcloud scheduler jobs delete pan-test-app-review-mr1234-api-alarm-clock-scheduler --project=asdf --location=asia-east1",
930
+ "gcloud run jobs executions list --project=asdf --region=asia-east1 --job pan-test-app-review-mr1234-api-alarm-clock --format="value(name)" | xargs -I {} gcloud run jobs executions delete {} --quiet --project=asdf --region=asia-east1",
931
+ "gcloud run jobs delete pan-test-app-review-mr1234-api-alarm-clock --project=asdf --region=asia-east1",
932
+ "gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/review/api/mr1234 --quiet --delete-tags",
933
+ "gcloud artifacts docker images list asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api --sort-by=~CREATE_TIME --format="value(version)" | tail -n +2 | while read -r version; do gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api@$version --quiet --delete-tags; done",
934
+ "set +e",
935
+ "gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/review/api --quiet --delete-tags",
936
+ "set -e",
937
+ "echo Disabling component in Dependency Track",
938
+ "/dtrackuploader https://dep.panter.swiss/ "$DT_KEY_PROD" disable "pan-test-app/api" "https://pan-test-app-review-mr1234-api-unknown-host.example.com" || true",
939
+ "set -e",
940
+ ],
941
+ "stage": "stop review",
942
+ "variables": {
943
+ "CLOUDSDK_CORE_DISABLE_PROMPTS": "1",
944
+ "GIT_STRATEGY": "none",
945
+ "KUBERNETES_CPU_REQUEST": "0.5",
946
+ "KUBERNETES_MEMORY_LIMIT": "400Mi",
947
+ "KUBERNETES_MEMORY_REQUEST": "200Mi",
948
+ },
949
+ },
950
+ "api ๐Ÿ›ก audit": {
951
+ "allow_failure": true,
952
+ "image": "path/to/docker/jobs-default:the-version",
953
+ "interruptible": true,
954
+ "needs": [],
955
+ "retry": {
956
+ "max": 2,
957
+ "when": [
958
+ "runner_system_failure",
959
+ "stuck_or_timeout_failure",
960
+ ],
961
+ },
962
+ "script": [
963
+ "cd app",
964
+ "yarn npm audit --environment production",
965
+ ],
966
+ "stage": "test",
967
+ "variables": {
968
+ "APP_PATH": "app",
969
+ "KUBERNETES_CPU_REQUEST": "0.5",
970
+ "KUBERNETES_MEMORY_LIMIT": "4Gi",
971
+ "KUBERNETES_MEMORY_REQUEST": "2Gi",
972
+ },
973
+ },
974
+ "api ๐Ÿงช test": {
975
+ "cache": [
976
+ {
977
+ "key": "app-yarn",
978
+ "paths": [
979
+ "app/.yarn",
980
+ ],
981
+ "policy": "pull-push",
982
+ },
983
+ {
984
+ "key": "app-node-modules",
985
+ "paths": [
986
+ "app/node_modules",
987
+ ],
988
+ "policy": "pull-push",
989
+ },
990
+ ],
991
+ "image": "path/to/docker/jobs-testing-chrome:the-version",
992
+ "interruptible": true,
993
+ "needs": [],
994
+ "retry": {
995
+ "max": 2,
996
+ "when": [
997
+ "runner_system_failure",
998
+ "stuck_or_timeout_failure",
999
+ ],
1000
+ },
1001
+ "script": [
1002
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
1003
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
1004
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
1005
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
1006
+ "cd app",
1007
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
1008
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
1009
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
1010
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
1011
+ "echo -e "\\e[0Ksection_start:$(date +%s):yarninstall[collapsed=true]\\r\\e[0KYarn install"",
1012
+ "yarn install --immutable",
1013
+ "echo -e "\\e[0Ksection_end:$(date +%s):yarninstall\\r\\e[0K"",
1014
+ "yarn test",
1015
+ ],
1016
+ "stage": "test",
1017
+ "variables": {
1018
+ "APP_PATH": "app",
1019
+ "KUBERNETES_CPU_REQUEST": "0.5",
1020
+ "KUBERNETES_MEMORY_LIMIT": "4Gi",
1021
+ "KUBERNETES_MEMORY_REQUEST": "2Gi",
1022
+ },
1023
+ },
1024
+ "api ๐Ÿงพ sbom | review ": {
1025
+ "allow_failure": true,
1026
+ "artifacts": {
1027
+ "paths": [
1028
+ "__sbom.json",
1029
+ ],
1030
+ },
1031
+ "image": "aquasec/trivy:0.38.3",
1032
+ "interruptible": true,
1033
+ "needs": [],
1034
+ "retry": {
1035
+ "max": 2,
1036
+ "when": [
1037
+ "runner_system_failure",
1038
+ "stuck_or_timeout_failure",
1039
+ ],
1040
+ },
1041
+ "script": [
1042
+ "trivy fs --quiet --format cyclonedx --output "__sbom.json" app",
1043
+ ],
1044
+ "stage": "build",
1045
+ "variables": {},
1046
+ },
1047
+ },
1048
+ "stages": [
1049
+ "setup",
1050
+ "setup dev",
1051
+ "setup review",
1052
+ "setup stage",
1053
+ "setup prod",
1054
+ "setup local",
1055
+ "test",
1056
+ "test dev",
1057
+ "test review",
1058
+ "test stage",
1059
+ "test prod",
1060
+ "test local",
1061
+ "build",
1062
+ "build dev",
1063
+ "build review",
1064
+ "build stage",
1065
+ "build prod",
1066
+ "build local",
1067
+ "deploy",
1068
+ "deploy dev",
1069
+ "deploy review",
1070
+ "deploy stage",
1071
+ "deploy prod",
1072
+ "deploy local",
1073
+ "verify",
1074
+ "verify dev",
1075
+ "verify review",
1076
+ "verify stage",
1077
+ "verify prod",
1078
+ "verify local",
1079
+ "rollback",
1080
+ "rollback dev",
1081
+ "rollback review",
1082
+ "rollback stage",
1083
+ "rollback prod",
1084
+ "rollback local",
1085
+ "stop",
1086
+ "stop dev",
1087
+ "stop review",
1088
+ "stop stage",
1089
+ "stop prod",
1090
+ "stop local",
1091
+ ],
1092
+ "variables": {
1093
+ "FF_USE_FASTZIP": "true",
1094
+ "GIT_DEPTH": 1,
1095
+ },
1096
+ "workflow": {
1097
+ "rules": [
1098
+ {
1099
+ "if": "$CI_COMMIT_TAG",
1100
+ },
1101
+ {
1102
+ "if": "$CI_COMMIT_MESSAGE =~ /^chore\\(release\\).*/",
1103
+ "when": "never",
1104
+ },
1105
+ {
1106
+ "if": "$CI_COMMIT_BRANCH =~ /^[0-9]+.([0-9]+|x).x$/",
1107
+ },
1108
+ {
1109
+ "if": "$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH",
1110
+ },
1111
+ {
1112
+ "if": "$CI_MERGE_REQUEST_ID",
1113
+ },
1114
+ ],
1115
+ },
1116
+ },
1117
+ "taggedRelease": {
1118
+ "image": "path/to/docker/jobs-default:the-version",
1119
+ "jobs": {
1120
+ "api ๐Ÿ”จ app | prod ": {
1121
+ "artifacts": {
1122
+ "expire_in": "1 day",
1123
+ "paths": [
1124
+ "app/__build_info.json",
1125
+ "app/dist",
1126
+ "app/.next",
1127
+ ],
1128
+ "reports": {
1129
+ "junit": undefined,
1130
+ },
1131
+ "when": "always",
1132
+ },
1133
+ "cache": [
1134
+ {
1135
+ "key": "app-yarn",
1136
+ "paths": [
1137
+ "app/.yarn",
1138
+ ],
1139
+ "policy": "pull-push",
1140
+ },
1141
+ {
1142
+ "key": "app-node-modules",
1143
+ "paths": [
1144
+ "app/node_modules",
1145
+ ],
1146
+ "policy": "pull-push",
1147
+ },
1148
+ {
1149
+ "key": "api-next-cache",
1150
+ "paths": [
1151
+ "app/.next/cache/",
1152
+ ],
1153
+ "policy": "pull-push",
1154
+ },
1155
+ ],
1156
+ "image": "path/to/docker/jobs-default:the-version",
1157
+ "interruptible": true,
1158
+ "needs": [],
1159
+ "retry": {
1160
+ "max": 2,
1161
+ "when": [
1162
+ "runner_system_failure",
1163
+ "stuck_or_timeout_failure",
1164
+ ],
1165
+ },
1166
+ "script": [
1167
+ "echo '{"id":"some-id","time":"01-01-2023 12:13:14"}' > app/__build_info.json",
1168
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
1169
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
1170
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
1171
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
1172
+ "cd app",
1173
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
1174
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
1175
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
1176
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
1177
+ "echo -e "\\e[0Ksection_start:$(date +%s):yarninstall[collapsed=true]\\r\\e[0KYarn install"",
1178
+ "yarn install --immutable",
1179
+ "echo -e "\\e[0Ksection_end:$(date +%s):yarninstall\\r\\e[0K"",
1180
+ "yarn build",
1181
+ ],
1182
+ "stage": "build",
1183
+ "variables": {
1184
+ "APP_DIR": "app",
1185
+ "BUILD_INFO_BUILD_TIME": "01-01-2023 12:13:14",
1186
+ "BUILD_INFO_CURRENT_VERSION": "3.2.1",
1187
+ "BUILD_INFO_ID": "some-id",
1188
+ "CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock": "https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-prod-api-alarm-clock:run",
1189
+ "ENV_SHORT": "prod",
1190
+ "ENV_TYPE": "prod",
1191
+ "GCLOUD_DEPLOY_credentialsKey": "$CL_prod_api_GCLOUD_DEPLOY_credentialsKey",
1192
+ "GCLOUD_RUN_canonicalHostSuffix": "$CL_prod_api_GCLOUD_RUN_canonicalHostSuffix",
1193
+ "HOST": "pan-test-app-prod-api-unknown-host.example.com",
1194
+ "HOST_CANONICAL": "pan-test-app-prod-api-unknown-host.example.com",
1195
+ "HOST_INTERNAL": "pan-test-app-prod-api-unknown-host.example.com",
1196
+ "KUBERNETES_CPU_REQUEST": "0.5",
1197
+ "KUBERNETES_MEMORY_LIMIT": "4Gi",
1198
+ "KUBERNETES_MEMORY_REQUEST": "2Gi",
1199
+ "ROOT_URL": "https://pan-test-app-prod-api-unknown-host.example.com",
1200
+ "ROOT_URL_INTERNAL": "https://pan-test-app-prod-api-unknown-host.example.com",
1201
+ "_ALL_ENV_VAR_KEYS": "["ENV_SHORT","APP_DIR","ENV_TYPE","BUILD_INFO_ID","BUILD_INFO_BUILD_TIME","BUILD_INFO_CURRENT_VERSION","HOST","ROOT_URL","HOST_CANONICAL","ROOT_URL_INTERNAL","HOST_INTERNAL","CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock","GCLOUD_DEPLOY_credentialsKey","GCLOUD_RUN_canonicalHostSuffix"]",
1202
+ },
1203
+ },
1204
+ "api ๐Ÿ”จ app | stage ": {
1205
+ "artifacts": {
1206
+ "expire_in": "1 day",
1207
+ "paths": [
1208
+ "app/__build_info.json",
1209
+ "app/dist",
1210
+ "app/.next",
1211
+ ],
1212
+ "reports": {
1213
+ "junit": undefined,
1214
+ },
1215
+ "when": "always",
1216
+ },
1217
+ "cache": [
1218
+ {
1219
+ "key": "app-yarn",
1220
+ "paths": [
1221
+ "app/.yarn",
1222
+ ],
1223
+ "policy": "pull-push",
1224
+ },
1225
+ {
1226
+ "key": "app-node-modules",
1227
+ "paths": [
1228
+ "app/node_modules",
1229
+ ],
1230
+ "policy": "pull-push",
1231
+ },
1232
+ {
1233
+ "key": "api-next-cache",
1234
+ "paths": [
1235
+ "app/.next/cache/",
1236
+ ],
1237
+ "policy": "pull-push",
1238
+ },
1239
+ ],
1240
+ "image": "path/to/docker/jobs-default:the-version",
1241
+ "interruptible": true,
1242
+ "needs": [],
1243
+ "retry": {
1244
+ "max": 2,
1245
+ "when": [
1246
+ "runner_system_failure",
1247
+ "stuck_or_timeout_failure",
1248
+ ],
1249
+ },
1250
+ "script": [
1251
+ "echo '{"id":"some-id","time":"01-01-2023 12:13:14"}' > app/__build_info.json",
1252
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
1253
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
1254
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
1255
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
1256
+ "cd app",
1257
+ "echo -e "\\e[0Ksection_start:$(date +%s):nodeinstall[collapsed=true]\\r\\e[0KEnsure node version"",
1258
+ "if [ -f ~/.nvm/nvm.sh ]; then source ~/.nvm/nvm.sh; fi",
1259
+ "if command -v nvm &> /dev/null && [ -f ./.nvmrc ]; then nvm install; fi",
1260
+ "echo -e "\\e[0Ksection_end:$(date +%s):nodeinstall\\r\\e[0K"",
1261
+ "echo -e "\\e[0Ksection_start:$(date +%s):yarninstall[collapsed=true]\\r\\e[0KYarn install"",
1262
+ "yarn install --immutable",
1263
+ "echo -e "\\e[0Ksection_end:$(date +%s):yarninstall\\r\\e[0K"",
1264
+ "yarn build",
1265
+ ],
1266
+ "stage": "build",
1267
+ "variables": {
1268
+ "APP_DIR": "app",
1269
+ "BUILD_INFO_BUILD_TIME": "01-01-2023 12:13:14",
1270
+ "BUILD_INFO_CURRENT_VERSION": "3.2.1",
1271
+ "BUILD_INFO_ID": "some-id",
1272
+ "CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock": "https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-stage-api-alarm-clock:run",
1273
+ "ENV_SHORT": "stage",
1274
+ "ENV_TYPE": "stage",
1275
+ "GCLOUD_DEPLOY_credentialsKey": "$CL_stage_api_GCLOUD_DEPLOY_credentialsKey",
1276
+ "GCLOUD_RUN_canonicalHostSuffix": "$CL_stage_api_GCLOUD_RUN_canonicalHostSuffix",
1277
+ "HOST": "pan-test-app-stage-api-unknown-host.example.com",
1278
+ "HOST_CANONICAL": "pan-test-app-stage-api-unknown-host.example.com",
1279
+ "HOST_INTERNAL": "pan-test-app-stage-api-unknown-host.example.com",
1280
+ "KUBERNETES_CPU_REQUEST": "0.5",
1281
+ "KUBERNETES_MEMORY_LIMIT": "4Gi",
1282
+ "KUBERNETES_MEMORY_REQUEST": "2Gi",
1283
+ "ROOT_URL": "https://pan-test-app-stage-api-unknown-host.example.com",
1284
+ "ROOT_URL_INTERNAL": "https://pan-test-app-stage-api-unknown-host.example.com",
1285
+ "_ALL_ENV_VAR_KEYS": "["ENV_SHORT","APP_DIR","ENV_TYPE","BUILD_INFO_ID","BUILD_INFO_BUILD_TIME","BUILD_INFO_CURRENT_VERSION","HOST","ROOT_URL","HOST_CANONICAL","ROOT_URL_INTERNAL","HOST_INTERNAL","CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock","GCLOUD_DEPLOY_credentialsKey","GCLOUD_RUN_canonicalHostSuffix"]",
1286
+ },
1287
+ },
1288
+ "api ๐Ÿ”จ docker | prod ": {
1289
+ "cache": [
1290
+ {
1291
+ "key": "app-yarn",
1292
+ "paths": [
1293
+ "app/.yarn",
1294
+ ],
1295
+ "policy": "pull",
1296
+ },
1297
+ ],
1298
+ "image": "path/to/docker/docker-build:the-version",
1299
+ "interruptible": true,
1300
+ "needs": [
1301
+ "api ๐Ÿ”จ app | prod ",
1302
+ ],
1303
+ "retry": {
1304
+ "max": 2,
1305
+ "when": [
1306
+ "runner_system_failure",
1307
+ "stuck_or_timeout_failure",
1308
+ ],
1309
+ },
1310
+ "script": [
1311
+ "ensureNodeDockerfile",
1312
+ "echo -e "\\e[0Ksection_start:$(date +%s):docker-login[collapsed=true]\\r\\e[0KDocker Login"",
1313
+ "gcloud auth activate-service-account --key-file=<(echo "$CL_prod_api_GCLOUD_DEPLOY_credentialsKey")",
1314
+ "gcloud auth configure-docker asia-east1-docker.pkg.dev",
1315
+ "echo -e "\\e[0Ksection_end:$(date +%s):docker-login\\r\\e[0K"",
1316
+ "echo -e "\\e[0Ksection_start:$(date +%s):docker-build[collapsed=true]\\r\\e[0KDocker build"",
1317
+ "docker build --network host --cache-from $DOCKER_CACHE_IMAGE --tag $DOCKER_IMAGE:$DOCKER_IMAGE_TAG -f $APP_DIR/Dockerfile . --build-arg BUILDKIT_INLINE_CACHE=1",
1318
+ "echo -e "\\e[0Ksection_end:$(date +%s):docker-build\\r\\e[0K"",
1319
+ "echo -e "\\e[0Ksection_start:$(date +%s):docker-push[collapsed=true]\\r\\e[0KDocker push and tag"",
1320
+ "docker push $DOCKER_IMAGE:$DOCKER_IMAGE_TAG",
1321
+ "docker tag $DOCKER_IMAGE:$DOCKER_IMAGE_TAG $DOCKER_CACHE_IMAGE",
1322
+ "docker push $DOCKER_CACHE_IMAGE",
1323
+ "echo -e "\\e[0Ksection_end:$(date +%s):docker-push\\r\\e[0K"",
1324
+ ],
1325
+ "services": [
1326
+ {
1327
+ "command": [
1328
+ "--tls=false",
1329
+ ],
1330
+ "name": "docker:24.0.6-dind",
1331
+ },
1332
+ ],
1333
+ "stage": "build",
1334
+ "variables": {
1335
+ "APP_DIR": "app",
1336
+ "DOCKERFILE_ADDITIONS": undefined,
1337
+ "DOCKERFILE_ADDITIONS_END": undefined,
1338
+ "DOCKER_BUILDKIT": "1",
1339
+ "DOCKER_CACHE_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api",
1340
+ "DOCKER_COPY_AND_INSTALL_APP": "COPY --chown=node:node $APP_DIR .
1341
+ RUN yarn plugin import workspace-tools
1342
+ RUN yarn workspaces focus --production && yarn rebuild",
1343
+ "DOCKER_COPY_WORKSPACE_FILES": "COPY --chown=node:node app/package.json /app/app/package.json
1344
+ COPY --chown=node:node app/yarn.lock /app/app/yarn.lock
1345
+ COPY --chown=node:node .yarnrc.yml /app/.yarnrc.yml
1346
+ COPY --chown=node:node .yarn /app/.yarn",
1347
+ "DOCKER_DIR": ".",
1348
+ "DOCKER_DRIVER": "overlay2",
1349
+ "DOCKER_HOST": "tcp://0.0.0.0:2375",
1350
+ "DOCKER_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/prod/api",
1351
+ "DOCKER_IMAGE_TAG": "$CI_COMMIT_SHA",
1352
+ "DOCKER_REGISTRY": "asia-east1-docker.pkg.dev",
1353
+ "DOCKER_TLS_CERTDIR": "",
1354
+ "KUBERNETES_CPU_REQUEST": "0.5",
1355
+ "KUBERNETES_MEMORY_LIMIT": "2Gi",
1356
+ "KUBERNETES_MEMORY_REQUEST": "1Gi",
1357
+ },
1358
+ },
1359
+ "api ๐Ÿ”จ docker | stage ": {
1360
+ "cache": [
1361
+ {
1362
+ "key": "app-yarn",
1363
+ "paths": [
1364
+ "app/.yarn",
1365
+ ],
1366
+ "policy": "pull",
1367
+ },
1368
+ ],
1369
+ "image": "path/to/docker/docker-build:the-version",
1370
+ "interruptible": true,
1371
+ "needs": [
1372
+ "api ๐Ÿ”จ app | stage ",
1373
+ ],
1374
+ "retry": {
1375
+ "max": 2,
1376
+ "when": [
1377
+ "runner_system_failure",
1378
+ "stuck_or_timeout_failure",
1379
+ ],
1380
+ },
1381
+ "script": [
1382
+ "ensureNodeDockerfile",
1383
+ "echo -e "\\e[0Ksection_start:$(date +%s):docker-login[collapsed=true]\\r\\e[0KDocker Login"",
1384
+ "gcloud auth activate-service-account --key-file=<(echo "$CL_stage_api_GCLOUD_DEPLOY_credentialsKey")",
1385
+ "gcloud auth configure-docker asia-east1-docker.pkg.dev",
1386
+ "echo -e "\\e[0Ksection_end:$(date +%s):docker-login\\r\\e[0K"",
1387
+ "echo -e "\\e[0Ksection_start:$(date +%s):docker-build[collapsed=true]\\r\\e[0KDocker build"",
1388
+ "docker build --network host --cache-from $DOCKER_CACHE_IMAGE --tag $DOCKER_IMAGE:$DOCKER_IMAGE_TAG -f $APP_DIR/Dockerfile . --build-arg BUILDKIT_INLINE_CACHE=1",
1389
+ "echo -e "\\e[0Ksection_end:$(date +%s):docker-build\\r\\e[0K"",
1390
+ "echo -e "\\e[0Ksection_start:$(date +%s):docker-push[collapsed=true]\\r\\e[0KDocker push and tag"",
1391
+ "docker push $DOCKER_IMAGE:$DOCKER_IMAGE_TAG",
1392
+ "docker tag $DOCKER_IMAGE:$DOCKER_IMAGE_TAG $DOCKER_CACHE_IMAGE",
1393
+ "docker push $DOCKER_CACHE_IMAGE",
1394
+ "echo -e "\\e[0Ksection_end:$(date +%s):docker-push\\r\\e[0K"",
1395
+ ],
1396
+ "services": [
1397
+ {
1398
+ "command": [
1399
+ "--tls=false",
1400
+ ],
1401
+ "name": "docker:24.0.6-dind",
1402
+ },
1403
+ ],
1404
+ "stage": "build",
1405
+ "variables": {
1406
+ "APP_DIR": "app",
1407
+ "DOCKERFILE_ADDITIONS": undefined,
1408
+ "DOCKERFILE_ADDITIONS_END": undefined,
1409
+ "DOCKER_BUILDKIT": "1",
1410
+ "DOCKER_CACHE_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api",
1411
+ "DOCKER_COPY_AND_INSTALL_APP": "COPY --chown=node:node $APP_DIR .
1412
+ RUN yarn plugin import workspace-tools
1413
+ RUN yarn workspaces focus --production && yarn rebuild",
1414
+ "DOCKER_COPY_WORKSPACE_FILES": "COPY --chown=node:node app/package.json /app/app/package.json
1415
+ COPY --chown=node:node app/yarn.lock /app/app/yarn.lock
1416
+ COPY --chown=node:node .yarnrc.yml /app/.yarnrc.yml
1417
+ COPY --chown=node:node .yarn /app/.yarn",
1418
+ "DOCKER_DIR": ".",
1419
+ "DOCKER_DRIVER": "overlay2",
1420
+ "DOCKER_HOST": "tcp://0.0.0.0:2375",
1421
+ "DOCKER_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/stage/api",
1422
+ "DOCKER_IMAGE_TAG": "$CI_COMMIT_SHA",
1423
+ "DOCKER_REGISTRY": "asia-east1-docker.pkg.dev",
1424
+ "DOCKER_TLS_CERTDIR": "",
1425
+ "KUBERNETES_CPU_REQUEST": "0.5",
1426
+ "KUBERNETES_MEMORY_LIMIT": "2Gi",
1427
+ "KUBERNETES_MEMORY_REQUEST": "1Gi",
1428
+ },
1429
+ },
1430
+ "api ๐Ÿš€ Deploy | prod ": {
1431
+ "allow_failure": true,
1432
+ "artifacts": {
1433
+ "paths": [
1434
+ "____envvars.yaml",
1435
+ ],
1436
+ },
1437
+ "environment": {
1438
+ "auto_stop_in": undefined,
1439
+ "name": "prod/api",
1440
+ "on_stop": "api ๐Ÿ›‘ Stop โš ๏ธ | prod ",
1441
+ },
1442
+ "image": "path/to/docker/gcloud:the-version",
1443
+ "interruptible": true,
1444
+ "needs": [
1445
+ {
1446
+ "artifacts": false,
1447
+ "job": "api ๐Ÿ”จ app | prod ",
1448
+ },
1449
+ {
1450
+ "artifacts": false,
1451
+ "job": "api ๐Ÿ”จ docker | prod ",
1452
+ },
1453
+ {
1454
+ "artifacts": true,
1455
+ "job": "api ๐Ÿงพ sbom | prod ",
1456
+ },
1457
+ ],
1458
+ "retry": {
1459
+ "max": 2,
1460
+ "when": [
1461
+ "runner_system_failure",
1462
+ "stuck_or_timeout_failure",
1463
+ ],
1464
+ },
1465
+ "rules": [
1466
+ {
1467
+ "when": "manual",
1468
+ },
1469
+ ],
1470
+ "script": [
1471
+ "echo -e "\\e[0Ksection_start:$(date +%s):prepare[collapsed=true]\\r\\e[0KPrepare..."",
1472
+ "gcloud auth activate-service-account --key-file=<(echo "$CL_prod_api_GCLOUD_DEPLOY_credentialsKey")",
1473
+ "export GCLOUD_PROJECT_NUMBER=$(gcloud projects describe asdf --format="value(projectNumber)")",
1474
+ "echo "GCLOUD_PROJECT_NUMBER: $GCLOUD_PROJECT_NUMBER"",
1475
+ "echo -e "\\e[0Ksection_end:$(date +%s):prepare\\r\\e[0K"",
1476
+ "echo -e "\\e[0Ksection_start:$(date +%s):deploy[collapsed=true]\\r\\e[0KDeploy to cloud run"",
1477
+ "echo "$ENV_VARS" > ____envvars.yaml",
1478
+ "set +e",
1479
+ "gcloud scheduler jobs create http pan-test-app-prod-api-alarm-clock-scheduler --project=asdf --location=asia-east1 --schedule="0 7 0 0 1-5" --max-retry-attempts=0 --uri="https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-prod-api-alarm-clock:run" --http-method=POST --oauth-service-account-email=$GCLOUD_PROJECT_NUMBER-compute@developer.gserviceaccount.com",
1480
+ "set -e",
1481
+ "gcloud scheduler jobs update http pan-test-app-prod-api-alarm-clock-scheduler --project=asdf --location=asia-east1 --schedule="0 7 0 0 1-5" --max-retry-attempts=0 --uri="https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-prod-api-alarm-clock:run" --http-method=POST --oauth-service-account-email=$GCLOUD_PROJECT_NUMBER-compute@developer.gserviceaccount.com",
1482
+ "set +e",
1483
+ "gcloud run jobs create pan-test-app-prod-api-alarm-clock --command="./wake-up-call" --image=asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/prod/api:$DOCKER_IMAGE_TAG --project=asdf --region=asia-east1 --labels=customer-name=pan,component-name=api,app-name=test-app,env-type=prod,env-name=prod,build-type=node,cloud-run-job-name=pan-test-app-prod-api-alarm-clock --memory=512Mi --task-timeout=10m --parallelism=1 --env-vars-file=____envvars.yaml --max-retries=0",
1484
+ "set -e",
1485
+ "gcloud run jobs update pan-test-app-prod-api-alarm-clock --command="./wake-up-call" --image=asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/prod/api:$DOCKER_IMAGE_TAG --project=asdf --region=asia-east1 --labels=customer-name=pan,component-name=api,app-name=test-app,env-type=prod,env-name=prod,build-type=node,cloud-run-job-name=pan-test-app-prod-api-alarm-clock --memory=512Mi --task-timeout=10m --parallelism=1 --env-vars-file=____envvars.yaml --max-retries=0 ",
1486
+ "echo -e "\\e[0Ksection_end:$(date +%s):deploy\\r\\e[0K"",
1487
+ "echo -e "\\e[0Ksection_start:$(date +%s):cleanup[collapsed=true]\\r\\e[0KCleanup"",
1488
+ "gcloud run revisions list --project=asdf --region=asia-east1 --service=pan-test-app-prod-api --limit=unlimited --sort-by=metadata.creationTimestamp --format="value(name)" --filter='(status.conditions.status=False OR status.conditions.status=Unknown)' | tail -n +6 | while read -r revisionname; do gcloud run revisions delete --project=asdf --region=asia-east1 --quiet $revisionname ; done",
1489
+ "gcloud artifacts docker images list asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/prod/api --sort-by=~CREATE_TIME --format="value(version)" | tail -n +7 | while read -r version; do gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/prod/api@$version --quiet --delete-tags; done",
1490
+ "gcloud artifacts docker images list asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api --sort-by=~CREATE_TIME --format="value(version)" | tail -n +2 | while read -r version; do gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api@$version --quiet --delete-tags; done",
1491
+ "echo -e "\\e[0Ksection_end:$(date +%s):cleanup\\r\\e[0K"",
1492
+ "echo Uploading SBOM to Dependency Track",
1493
+ "/dtrackuploader https://dep.panter.swiss/ "$DT_KEY_PROD" upload "pan-test-app/api" "https://pan-test-app-prod-api-unknown-host.example.com" "__sbom.json" vex.json || true",
1494
+ ],
1495
+ "services": [
1496
+ {
1497
+ "command": [
1498
+ "--tls=false",
1499
+ ],
1500
+ "name": "docker:24.0.6-dind",
1501
+ },
1502
+ ],
1503
+ "stage": "deploy prod",
1504
+ "variables": {
1505
+ "APP_DIR": "app",
1506
+ "BUILD_INFO_BUILD_TIME": "01-01-2023 12:13:14",
1507
+ "BUILD_INFO_CURRENT_VERSION": "3.2.1",
1508
+ "BUILD_INFO_ID": "some-id",
1509
+ "CLOUDSDK_CORE_DISABLE_PROMPTS": "1",
1510
+ "CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock": "https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-prod-api-alarm-clock:run",
1511
+ "DOCKER_BUILDKIT": "1",
1512
+ "DOCKER_CACHE_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api",
1513
+ "DOCKER_DRIVER": "overlay2",
1514
+ "DOCKER_HOST": "tcp://0.0.0.0:2375",
1515
+ "DOCKER_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/prod/api",
1516
+ "DOCKER_IMAGE_TAG": "$CI_COMMIT_SHA",
1517
+ "DOCKER_REGISTRY": "asia-east1-docker.pkg.dev",
1518
+ "DOCKER_TLS_CERTDIR": "",
1519
+ "ENV_SHORT": "prod",
1520
+ "ENV_TYPE": "prod",
1521
+ "ENV_VARS": "ENV_SHORT: 'prod'
1522
+ APP_DIR: 'app'
1523
+ ENV_TYPE: 'prod'
1524
+ BUILD_INFO_ID: 'some-id'
1525
+ BUILD_INFO_BUILD_TIME: '01-01-2023 12:13:14'
1526
+ BUILD_INFO_CURRENT_VERSION: '3.2.1'
1527
+ HOST: 'pan-test-app-prod-api-unknown-host.example.com'
1528
+ ROOT_URL: 'https://pan-test-app-prod-api-unknown-host.example.com'
1529
+ HOST_CANONICAL: 'pan-test-app-prod-api-unknown-host.example.com'
1530
+ ROOT_URL_INTERNAL: 'https://pan-test-app-prod-api-unknown-host.example.com'
1531
+ HOST_INTERNAL: 'pan-test-app-prod-api-unknown-host.example.com'
1532
+ CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock: 'https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-prod-api-alarm-clock:run'
1533
+ GCLOUD_RUN_canonicalHostSuffix: '$CL_prod_api_GCLOUD_RUN_canonicalHostSuffix'
1534
+ _ALL_ENV_VAR_KEYS: '["ENV_SHORT","APP_DIR","ENV_TYPE","BUILD_INFO_ID","BUILD_INFO_BUILD_TIME","BUILD_INFO_CURRENT_VERSION","HOST","ROOT_URL","HOST_CANONICAL","ROOT_URL_INTERNAL","HOST_INTERNAL","CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock","GCLOUD_DEPLOY_credentialsKey","GCLOUD_RUN_canonicalHostSuffix"]'
1535
+ ",
1536
+ "GCLOUD_DEPLOY_credentialsKey": "$CL_prod_api_GCLOUD_DEPLOY_credentialsKey",
1537
+ "GCLOUD_RUN_canonicalHostSuffix": "$CL_prod_api_GCLOUD_RUN_canonicalHostSuffix",
1538
+ "HOST": "pan-test-app-prod-api-unknown-host.example.com",
1539
+ "HOST_CANONICAL": "pan-test-app-prod-api-unknown-host.example.com",
1540
+ "HOST_INTERNAL": "pan-test-app-prod-api-unknown-host.example.com",
1541
+ "KUBERNETES_CPU_REQUEST": "0.5",
1542
+ "KUBERNETES_MEMORY_LIMIT": "400Mi",
1543
+ "KUBERNETES_MEMORY_REQUEST": "200Mi",
1544
+ "ROOT_URL": "https://pan-test-app-prod-api-unknown-host.example.com",
1545
+ "ROOT_URL_INTERNAL": "https://pan-test-app-prod-api-unknown-host.example.com",
1546
+ "_ALL_ENV_VAR_KEYS": "["ENV_SHORT","APP_DIR","ENV_TYPE","BUILD_INFO_ID","BUILD_INFO_BUILD_TIME","BUILD_INFO_CURRENT_VERSION","HOST","ROOT_URL","HOST_CANONICAL","ROOT_URL_INTERNAL","HOST_INTERNAL","CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock","GCLOUD_DEPLOY_credentialsKey","GCLOUD_RUN_canonicalHostSuffix"]",
1547
+ },
1548
+ },
1549
+ "api ๐Ÿš€ Deploy | stage ": {
1550
+ "allow_failure": false,
1551
+ "artifacts": {
1552
+ "paths": [
1553
+ "____envvars.yaml",
1554
+ ],
1555
+ },
1556
+ "environment": {
1557
+ "auto_stop_in": undefined,
1558
+ "name": "stage/api",
1559
+ "on_stop": "api ๐Ÿ›‘ Stop โš ๏ธ | stage ",
1560
+ },
1561
+ "image": "path/to/docker/gcloud:the-version",
1562
+ "interruptible": true,
1563
+ "needs": [
1564
+ {
1565
+ "artifacts": false,
1566
+ "job": "api ๐Ÿ”จ app | stage ",
1567
+ },
1568
+ {
1569
+ "artifacts": false,
1570
+ "job": "api ๐Ÿ”จ docker | stage ",
1571
+ },
1572
+ {
1573
+ "artifacts": true,
1574
+ "job": "api ๐Ÿงพ sbom | stage ",
1575
+ },
1576
+ ],
1577
+ "retry": {
1578
+ "max": 2,
1579
+ "when": [
1580
+ "runner_system_failure",
1581
+ "stuck_or_timeout_failure",
1582
+ ],
1583
+ },
1584
+ "rules": [
1585
+ {
1586
+ "when": "on_success",
1587
+ },
1588
+ ],
1589
+ "script": [
1590
+ "echo -e "\\e[0Ksection_start:$(date +%s):prepare[collapsed=true]\\r\\e[0KPrepare..."",
1591
+ "gcloud auth activate-service-account --key-file=<(echo "$CL_stage_api_GCLOUD_DEPLOY_credentialsKey")",
1592
+ "export GCLOUD_PROJECT_NUMBER=$(gcloud projects describe asdf --format="value(projectNumber)")",
1593
+ "echo "GCLOUD_PROJECT_NUMBER: $GCLOUD_PROJECT_NUMBER"",
1594
+ "echo -e "\\e[0Ksection_end:$(date +%s):prepare\\r\\e[0K"",
1595
+ "echo -e "\\e[0Ksection_start:$(date +%s):deploy[collapsed=true]\\r\\e[0KDeploy to cloud run"",
1596
+ "echo "$ENV_VARS" > ____envvars.yaml",
1597
+ "set +e",
1598
+ "gcloud scheduler jobs create http pan-test-app-stage-api-alarm-clock-scheduler --project=asdf --location=asia-east1 --schedule="0 7 0 0 1-5" --max-retry-attempts=0 --uri="https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-stage-api-alarm-clock:run" --http-method=POST --oauth-service-account-email=$GCLOUD_PROJECT_NUMBER-compute@developer.gserviceaccount.com",
1599
+ "set -e",
1600
+ "gcloud scheduler jobs update http pan-test-app-stage-api-alarm-clock-scheduler --project=asdf --location=asia-east1 --schedule="0 7 0 0 1-5" --max-retry-attempts=0 --uri="https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-stage-api-alarm-clock:run" --http-method=POST --oauth-service-account-email=$GCLOUD_PROJECT_NUMBER-compute@developer.gserviceaccount.com",
1601
+ "set +e",
1602
+ "gcloud run jobs create pan-test-app-stage-api-alarm-clock --command="./wake-up-call" --image=asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/stage/api:$DOCKER_IMAGE_TAG --project=asdf --region=asia-east1 --labels=customer-name=pan,component-name=api,app-name=test-app,env-type=stage,env-name=stage,build-type=node,cloud-run-job-name=pan-test-app-stage-api-alarm-clock --memory=512Mi --task-timeout=10m --parallelism=1 --env-vars-file=____envvars.yaml --max-retries=0",
1603
+ "set -e",
1604
+ "gcloud run jobs update pan-test-app-stage-api-alarm-clock --command="./wake-up-call" --image=asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/stage/api:$DOCKER_IMAGE_TAG --project=asdf --region=asia-east1 --labels=customer-name=pan,component-name=api,app-name=test-app,env-type=stage,env-name=stage,build-type=node,cloud-run-job-name=pan-test-app-stage-api-alarm-clock --memory=512Mi --task-timeout=10m --parallelism=1 --env-vars-file=____envvars.yaml --max-retries=0 ",
1605
+ "echo -e "\\e[0Ksection_end:$(date +%s):deploy\\r\\e[0K"",
1606
+ "echo -e "\\e[0Ksection_start:$(date +%s):cleanup[collapsed=true]\\r\\e[0KCleanup"",
1607
+ "gcloud run revisions list --project=asdf --region=asia-east1 --service=pan-test-app-stage-api --limit=unlimited --sort-by=metadata.creationTimestamp --format="value(name)" --filter='(status.conditions.status=False OR status.conditions.status=Unknown)' | while read -r revisionname; do gcloud run revisions delete --project=asdf --region=asia-east1 --quiet $revisionname ; done",
1608
+ "gcloud artifacts docker images list asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/stage/api --sort-by=~CREATE_TIME --format="value(version)" | tail -n +2 | while read -r version; do gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/stage/api@$version --quiet --delete-tags; done",
1609
+ "gcloud artifacts docker images list asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api --sort-by=~CREATE_TIME --format="value(version)" | tail -n +2 | while read -r version; do gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api@$version --quiet --delete-tags; done",
1610
+ "echo -e "\\e[0Ksection_end:$(date +%s):cleanup\\r\\e[0K"",
1611
+ "echo Uploading SBOM to Dependency Track",
1612
+ "/dtrackuploader https://dep.panter.swiss/ "$DT_KEY_PROD" upload "pan-test-app/api" "https://pan-test-app-stage-api-unknown-host.example.com" "__sbom.json" vex.json || true",
1613
+ ],
1614
+ "services": [
1615
+ {
1616
+ "command": [
1617
+ "--tls=false",
1618
+ ],
1619
+ "name": "docker:24.0.6-dind",
1620
+ },
1621
+ ],
1622
+ "stage": "deploy stage",
1623
+ "variables": {
1624
+ "APP_DIR": "app",
1625
+ "BUILD_INFO_BUILD_TIME": "01-01-2023 12:13:14",
1626
+ "BUILD_INFO_CURRENT_VERSION": "3.2.1",
1627
+ "BUILD_INFO_ID": "some-id",
1628
+ "CLOUDSDK_CORE_DISABLE_PROMPTS": "1",
1629
+ "CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock": "https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-stage-api-alarm-clock:run",
1630
+ "DOCKER_BUILDKIT": "1",
1631
+ "DOCKER_CACHE_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api",
1632
+ "DOCKER_DRIVER": "overlay2",
1633
+ "DOCKER_HOST": "tcp://0.0.0.0:2375",
1634
+ "DOCKER_IMAGE": "asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/stage/api",
1635
+ "DOCKER_IMAGE_TAG": "$CI_COMMIT_SHA",
1636
+ "DOCKER_REGISTRY": "asia-east1-docker.pkg.dev",
1637
+ "DOCKER_TLS_CERTDIR": "",
1638
+ "ENV_SHORT": "stage",
1639
+ "ENV_TYPE": "stage",
1640
+ "ENV_VARS": "ENV_SHORT: 'stage'
1641
+ APP_DIR: 'app'
1642
+ ENV_TYPE: 'stage'
1643
+ BUILD_INFO_ID: 'some-id'
1644
+ BUILD_INFO_BUILD_TIME: '01-01-2023 12:13:14'
1645
+ BUILD_INFO_CURRENT_VERSION: '3.2.1'
1646
+ HOST: 'pan-test-app-stage-api-unknown-host.example.com'
1647
+ ROOT_URL: 'https://pan-test-app-stage-api-unknown-host.example.com'
1648
+ HOST_CANONICAL: 'pan-test-app-stage-api-unknown-host.example.com'
1649
+ ROOT_URL_INTERNAL: 'https://pan-test-app-stage-api-unknown-host.example.com'
1650
+ HOST_INTERNAL: 'pan-test-app-stage-api-unknown-host.example.com'
1651
+ CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock: 'https://asia-east1-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/asdf/jobs/pan-test-app-stage-api-alarm-clock:run'
1652
+ GCLOUD_RUN_canonicalHostSuffix: '$CL_stage_api_GCLOUD_RUN_canonicalHostSuffix'
1653
+ _ALL_ENV_VAR_KEYS: '["ENV_SHORT","APP_DIR","ENV_TYPE","BUILD_INFO_ID","BUILD_INFO_BUILD_TIME","BUILD_INFO_CURRENT_VERSION","HOST","ROOT_URL","HOST_CANONICAL","ROOT_URL_INTERNAL","HOST_INTERNAL","CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock","GCLOUD_DEPLOY_credentialsKey","GCLOUD_RUN_canonicalHostSuffix"]'
1654
+ ",
1655
+ "GCLOUD_DEPLOY_credentialsKey": "$CL_stage_api_GCLOUD_DEPLOY_credentialsKey",
1656
+ "GCLOUD_RUN_canonicalHostSuffix": "$CL_stage_api_GCLOUD_RUN_canonicalHostSuffix",
1657
+ "HOST": "pan-test-app-stage-api-unknown-host.example.com",
1658
+ "HOST_CANONICAL": "pan-test-app-stage-api-unknown-host.example.com",
1659
+ "HOST_INTERNAL": "pan-test-app-stage-api-unknown-host.example.com",
1660
+ "KUBERNETES_CPU_REQUEST": "0.5",
1661
+ "KUBERNETES_MEMORY_LIMIT": "400Mi",
1662
+ "KUBERNETES_MEMORY_REQUEST": "200Mi",
1663
+ "ROOT_URL": "https://pan-test-app-stage-api-unknown-host.example.com",
1664
+ "ROOT_URL_INTERNAL": "https://pan-test-app-stage-api-unknown-host.example.com",
1665
+ "_ALL_ENV_VAR_KEYS": "["ENV_SHORT","APP_DIR","ENV_TYPE","BUILD_INFO_ID","BUILD_INFO_BUILD_TIME","BUILD_INFO_CURRENT_VERSION","HOST","ROOT_URL","HOST_CANONICAL","ROOT_URL_INTERNAL","HOST_INTERNAL","CLOUD_RUN_JOB_TRIGGER_URL_alarm_clock","GCLOUD_DEPLOY_credentialsKey","GCLOUD_RUN_canonicalHostSuffix"]",
1666
+ },
1667
+ },
1668
+ "api ๐Ÿ›‘ Stop โš ๏ธ | prod ": {
1669
+ "environment": {
1670
+ "action": "stop",
1671
+ "name": "prod/api",
1672
+ },
1673
+ "image": "path/to/docker/gcloud:the-version",
1674
+ "interruptible": true,
1675
+ "needs": [],
1676
+ "retry": {
1677
+ "max": 2,
1678
+ "when": [
1679
+ "runner_system_failure",
1680
+ "stuck_or_timeout_failure",
1681
+ ],
1682
+ },
1683
+ "rules": [
1684
+ {
1685
+ "allow_failure": true,
1686
+ "if": "$CI_COMMIT_BRANCH =~ /^[0-9]+\\.([0-9]+|x)\\.x$/",
1687
+ "when": "on_success",
1688
+ },
1689
+ {
1690
+ "allow_failure": true,
1691
+ "when": "manual",
1692
+ },
1693
+ ],
1694
+ "script": [
1695
+ "set +e",
1696
+ "gcloud auth activate-service-account --key-file=<(echo "$CL_prod_api_GCLOUD_DEPLOY_credentialsKey")",
1697
+ "gcloud scheduler jobs delete pan-test-app-prod-api-alarm-clock-scheduler --project=asdf --location=asia-east1",
1698
+ "gcloud run jobs executions list --project=asdf --region=asia-east1 --job pan-test-app-prod-api-alarm-clock --format="value(name)" | xargs -I {} gcloud run jobs executions delete {} --quiet --project=asdf --region=asia-east1",
1699
+ "gcloud run jobs delete pan-test-app-prod-api-alarm-clock --project=asdf --region=asia-east1",
1700
+ "gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/prod/api --quiet --delete-tags",
1701
+ "gcloud artifacts docker images list asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api --sort-by=~CREATE_TIME --format="value(version)" | tail -n +2 | while read -r version; do gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api@$version --quiet --delete-tags; done",
1702
+ "echo Disabling component in Dependency Track",
1703
+ "/dtrackuploader https://dep.panter.swiss/ "$DT_KEY_PROD" disable "pan-test-app/api" "https://pan-test-app-prod-api-unknown-host.example.com" || true",
1704
+ "set -e",
1705
+ ],
1706
+ "stage": "stop prod",
1707
+ "variables": {
1708
+ "CLOUDSDK_CORE_DISABLE_PROMPTS": "1",
1709
+ "GIT_STRATEGY": "none",
1710
+ "KUBERNETES_CPU_REQUEST": "0.5",
1711
+ "KUBERNETES_MEMORY_LIMIT": "400Mi",
1712
+ "KUBERNETES_MEMORY_REQUEST": "200Mi",
1713
+ },
1714
+ },
1715
+ "api ๐Ÿ›‘ Stop โš ๏ธ | stage ": {
1716
+ "environment": {
1717
+ "action": "stop",
1718
+ "name": "stage/api",
1719
+ },
1720
+ "image": "path/to/docker/gcloud:the-version",
1721
+ "interruptible": true,
1722
+ "needs": [],
1723
+ "retry": {
1724
+ "max": 2,
1725
+ "when": [
1726
+ "runner_system_failure",
1727
+ "stuck_or_timeout_failure",
1728
+ ],
1729
+ },
1730
+ "rules": [
1731
+ {
1732
+ "allow_failure": true,
1733
+ "if": "$CI_COMMIT_BRANCH =~ /^[0-9]+\\.([0-9]+|x)\\.x$/",
1734
+ "when": "on_success",
1735
+ },
1736
+ {
1737
+ "allow_failure": true,
1738
+ "when": "manual",
1739
+ },
1740
+ ],
1741
+ "script": [
1742
+ "set +e",
1743
+ "gcloud auth activate-service-account --key-file=<(echo "$CL_stage_api_GCLOUD_DEPLOY_credentialsKey")",
1744
+ "gcloud scheduler jobs delete pan-test-app-stage-api-alarm-clock-scheduler --project=asdf --location=asia-east1",
1745
+ "gcloud run jobs executions list --project=asdf --region=asia-east1 --job pan-test-app-stage-api-alarm-clock --format="value(name)" | xargs -I {} gcloud run jobs executions delete {} --quiet --project=asdf --region=asia-east1",
1746
+ "gcloud run jobs delete pan-test-app-stage-api-alarm-clock --project=asdf --region=asia-east1",
1747
+ "gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/stage/api --quiet --delete-tags",
1748
+ "gcloud artifacts docker images list asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api --sort-by=~CREATE_TIME --format="value(version)" | tail -n +2 | while read -r version; do gcloud artifacts docker images delete asia-east1-docker.pkg.dev/asdf/catladder-deploy/pan-test-app/caches/api@$version --quiet --delete-tags; done",
1749
+ "echo Disabling component in Dependency Track",
1750
+ "/dtrackuploader https://dep.panter.swiss/ "$DT_KEY_PROD" disable "pan-test-app/api" "https://pan-test-app-stage-api-unknown-host.example.com" || true",
1751
+ "set -e",
1752
+ ],
1753
+ "stage": "stop stage",
1754
+ "variables": {
1755
+ "CLOUDSDK_CORE_DISABLE_PROMPTS": "1",
1756
+ "GIT_STRATEGY": "none",
1757
+ "KUBERNETES_CPU_REQUEST": "0.5",
1758
+ "KUBERNETES_MEMORY_LIMIT": "400Mi",
1759
+ "KUBERNETES_MEMORY_REQUEST": "200Mi",
1760
+ },
1761
+ },
1762
+ "api ๐Ÿงพ sbom | prod ": {
1763
+ "allow_failure": true,
1764
+ "artifacts": {
1765
+ "paths": [
1766
+ "__sbom.json",
1767
+ ],
1768
+ },
1769
+ "image": "aquasec/trivy:0.38.3",
1770
+ "interruptible": true,
1771
+ "needs": [],
1772
+ "retry": {
1773
+ "max": 2,
1774
+ "when": [
1775
+ "runner_system_failure",
1776
+ "stuck_or_timeout_failure",
1777
+ ],
1778
+ },
1779
+ "script": [
1780
+ "trivy fs --quiet --format cyclonedx --output "__sbom.json" app",
1781
+ ],
1782
+ "stage": "build",
1783
+ "variables": {},
1784
+ },
1785
+ "api ๐Ÿงพ sbom | stage ": {
1786
+ "allow_failure": true,
1787
+ "artifacts": {
1788
+ "paths": [
1789
+ "__sbom.json",
1790
+ ],
1791
+ },
1792
+ "image": "aquasec/trivy:0.38.3",
1793
+ "interruptible": true,
1794
+ "needs": [],
1795
+ "retry": {
1796
+ "max": 2,
1797
+ "when": [
1798
+ "runner_system_failure",
1799
+ "stuck_or_timeout_failure",
1800
+ ],
1801
+ },
1802
+ "script": [
1803
+ "trivy fs --quiet --format cyclonedx --output "__sbom.json" app",
1804
+ ],
1805
+ "stage": "build",
1806
+ "variables": {},
1807
+ },
1808
+ },
1809
+ "stages": [
1810
+ "setup",
1811
+ "setup dev",
1812
+ "setup review",
1813
+ "setup stage",
1814
+ "setup prod",
1815
+ "setup local",
1816
+ "test",
1817
+ "test dev",
1818
+ "test review",
1819
+ "test stage",
1820
+ "test prod",
1821
+ "test local",
1822
+ "build",
1823
+ "build dev",
1824
+ "build review",
1825
+ "build stage",
1826
+ "build prod",
1827
+ "build local",
1828
+ "deploy",
1829
+ "deploy dev",
1830
+ "deploy review",
1831
+ "deploy stage",
1832
+ "deploy prod",
1833
+ "deploy local",
1834
+ "verify",
1835
+ "verify dev",
1836
+ "verify review",
1837
+ "verify stage",
1838
+ "verify prod",
1839
+ "verify local",
1840
+ "rollback",
1841
+ "rollback dev",
1842
+ "rollback review",
1843
+ "rollback stage",
1844
+ "rollback prod",
1845
+ "rollback local",
1846
+ "stop",
1847
+ "stop dev",
1848
+ "stop review",
1849
+ "stop stage",
1850
+ "stop prod",
1851
+ "stop local",
1852
+ ],
1853
+ "variables": {
1854
+ "FF_USE_FASTZIP": "true",
1855
+ "GIT_DEPTH": 1,
1856
+ },
1857
+ "workflow": {
1858
+ "rules": [
1859
+ {
1860
+ "if": "$CI_COMMIT_TAG",
1861
+ },
1862
+ {
1863
+ "if": "$CI_COMMIT_MESSAGE =~ /^chore\\(release\\).*/",
1864
+ "when": "never",
1865
+ },
1866
+ {
1867
+ "if": "$CI_COMMIT_BRANCH =~ /^[0-9]+.([0-9]+|x).x$/",
1868
+ },
1869
+ {
1870
+ "if": "$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH",
1871
+ },
1872
+ {
1873
+ "if": "$CI_MERGE_REQUEST_ID",
1874
+ },
1875
+ ],
1876
+ },
1877
+ },
1878
+ }
1879
+ `;