@@ -3,6 +3,9 @@ name: External Trigger Main
3
3
on :
4
4
workflow_dispatch :
5
5
6
+ permissions :
7
+ contents : read
8
+
6
9
jobs :
7
10
external-trigger-master :
8
11
runs-on : ubuntu-latest
@@ -11,44 +14,75 @@ jobs:
11
14
12
15
- name : External Trigger
13
16
if : github.ref == 'refs/heads/master'
17
+ env :
18
+ SKIP_EXTERNAL_TRIGGER : ${{ vars.SKIP_EXTERNAL_TRIGGER }}
14
19
run : |
15
- if [ -n "${{ secrets.PAUSE_EXTERNAL_TRIGGER_CODE_SERVER_MASTER }}" ]; then
16
- echo "**** Github secret PAUSE_EXTERNAL_TRIGGER_CODE_SERVER_MASTER is set; skipping trigger. ****"
17
- echo "Github secret \`PAUSE_EXTERNAL_TRIGGER_CODE_SERVER_MASTER\` is set; skipping trigger." >> $GITHUB_STEP_SUMMARY
20
+ printf "# External trigger for docker-code-server\n\n" >> $GITHUB_STEP_SUMMARY
21
+ if grep -q "^code-server_master_" <<< "${SKIP_EXTERNAL_TRIGGER}"; then
22
+ echo "> [!NOTE]" >> $GITHUB_STEP_SUMMARY
23
+ echo "> Github organizational variable \`SKIP_EXTERNAL_TRIGGER\` contains \`code-server_master_\`; will skip trigger if version matches." >> $GITHUB_STEP_SUMMARY
24
+ elif grep -q "^code-server_master" <<< "${SKIP_EXTERNAL_TRIGGER}"; then
25
+ echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
26
+ echo "> Github organizational variable \`SKIP_EXTERNAL_TRIGGER\` contains \`code-server_master\`; skipping trigger." >> $GITHUB_STEP_SUMMARY
18
27
exit 0
19
28
fi
20
- echo "**** External trigger running off of master branch. To disable this trigger, set a Github secret named \"PAUSE_EXTERNAL_TRIGGER_CODE_SERVER_MASTER\". ****"
21
- echo "External trigger running off of master branch. To disable this trigger, set a Github secret named \`PAUSE_EXTERNAL_TRIGGER_CODE_SERVER_MASTER\` " >> $GITHUB_STEP_SUMMARY
22
- echo "**** Retrieving external version ****"
29
+ echo "> [!NOTE]" >> $GITHUB_STEP_SUMMARY
30
+ echo "> External trigger running off of master branch. To disable this trigger, add \`code-server_master\` into the Github organizational variable \`SKIP_EXTERNAL_TRIGGER\`. " >> $GITHUB_STEP_SUMMARY
31
+ printf "\n## Retrieving external version\n\n" >> $GITHUB_STEP_SUMMARY
23
32
EXT_RELEASE=$(curl -u ${{ secrets.CR_USER }}:${{ secrets.CR_PAT }} -sX GET https://api.github.com/repos/coder/code-server/releases/latest | jq -r '.tag_name' | sed 's|^v||')
33
+ echo "Type is \`custom_version_command\`" >> $GITHUB_STEP_SUMMARY
34
+ if grep -q "^code-server_master_${EXT_RELEASE}" <<< "${SKIP_EXTERNAL_TRIGGER}"; then
35
+ echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
36
+ echo "> Github organizational variable \`SKIP_EXTERNAL_TRIGGER\` matches current external release; skipping trigger." >> $GITHUB_STEP_SUMMARY
37
+ exit 0
38
+ fi
24
39
if [ -z "${EXT_RELEASE}" ] || [ "${EXT_RELEASE}" == "null" ]; then
25
- echo "**** Can't retrieve external version, exiting ****"
40
+ echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
41
+ echo "> Can't retrieve external version, exiting" >> $GITHUB_STEP_SUMMARY
26
42
FAILURE_REASON="Can't retrieve external version for code-server branch master"
27
43
GHA_TRIGGER_URL="https://github.com/linuxserver/docker-code-server/actions/runs/${{ github.run_id }}"
28
44
curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 16711680,
29
45
"description": "**Trigger Failed** \n**Reason:** '"${FAILURE_REASON}"' \n**Trigger URL:** '"${GHA_TRIGGER_URL}"' \n"}],
30
46
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
31
47
exit 1
32
48
fi
33
- EXT_RELEASE=$(echo ${EXT_RELEASE} | sed 's/[~,%@+;:/]//g')
34
- echo "**** External version: ${EXT_RELEASE} ****"
35
- echo "External version: ${EXT_RELEASE}" >> $GITHUB_STEP_SUMMARY
36
- echo "**** Retrieving last pushed version ****"
49
+ EXT_RELEASE_SANITIZED=$(echo ${EXT_RELEASE} | sed 's/[~,%@+;:/]//g')
50
+ echo "Sanitized external version: \`${EXT_RELEASE_SANITIZED}\`" >> $GITHUB_STEP_SUMMARY
51
+ echo "Retrieving last pushed version" >> $GITHUB_STEP_SUMMARY
37
52
image="linuxserver/code-server"
38
53
tag="latest"
39
54
token=$(curl -sX GET \
40
55
"https://ghcr.io/token?scope=repository%3Alinuxserver%2Fcode-server%3Apull" \
41
56
| jq -r '.token')
42
- multidigest=$(curl -s \
43
- --header "Accept: application/vnd.docker.distribution.manifest.v2+json" \
44
- --header "Authorization: Bearer ${token}" \
45
- "https://ghcr.io/v2/${image}/manifests/${tag}" \
46
- | jq -r 'first(.manifests[].digest)')
47
- digest=$(curl -s \
57
+ multidigest=$(curl -s \
58
+ --header "Accept: application/vnd.docker.distribution.manifest.v2+json" \
59
+ --header "Accept: application/vnd.oci.image.index.v1+json" \
60
+ --header "Authorization: Bearer ${token}" \
61
+ "https://ghcr.io/v2/${image}/manifests/${tag}")
62
+ if jq -e '.layers // empty' <<< "${multidigest}" >/dev/null 2>&1; then
63
+ # If there's a layer element it's a single-arch manifest so just get that digest
64
+ digest=$(jq -r '.config.digest' <<< "${multidigest}")
65
+ else
66
+ # Otherwise it's multi-arch or has manifest annotations
67
+ if jq -e '.manifests[]?.annotations // empty' <<< "${multidigest}" >/dev/null 2>&1; then
68
+ # Check for manifest annotations and delete if found
69
+ multidigest=$(jq 'del(.manifests[] | select(.annotations))' <<< "${multidigest}")
70
+ fi
71
+ if [[ $(jq '.manifests | length' <<< "${multidigest}") -gt 1 ]]; then
72
+ # If there's still more than one digest, it's multi-arch
73
+ multidigest=$(jq -r ".manifests[] | select(.platform.architecture == \"amd64\").digest?" <<< "${multidigest}")
74
+ else
75
+ # Otherwise it's single arch
76
+ multidigest=$(jq -r ".manifests[].digest?" <<< "${multidigest}")
77
+ fi
78
+ if digest=$(curl -s \
48
79
--header "Accept: application/vnd.docker.distribution.manifest.v2+json" \
80
+ --header "Accept: application/vnd.oci.image.manifest.v1+json" \
49
81
--header "Authorization: Bearer ${token}" \
50
- "https://ghcr.io/v2/${image}/manifests/${multidigest}" \
51
- | jq -r '.config.digest')
82
+ "https://ghcr.io/v2/${image}/manifests/${multidigest}"); then
83
+ digest=$(jq -r '.config.digest' <<< "${digest}");
84
+ fi
85
+ fi
52
86
image_info=$(curl -sL \
53
87
--header "Authorization: Bearer ${token}" \
54
88
"https://ghcr.io/v2/${image}/blobs/${digest}")
@@ -60,45 +94,54 @@ jobs:
60
94
IMAGE_RELEASE=$(echo ${image_info} | jq -r '.Labels.build_version' | awk '{print $3}')
61
95
IMAGE_VERSION=$(echo ${IMAGE_RELEASE} | awk -F'-ls' '{print $1}')
62
96
if [ -z "${IMAGE_VERSION}" ]; then
63
- echo "**** Can't retrieve last pushed version, exiting ****"
97
+ echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
98
+ echo "Can't retrieve last pushed version, exiting" >> $GITHUB_STEP_SUMMARY
64
99
FAILURE_REASON="Can't retrieve last pushed version for code-server tag latest"
65
100
curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 16711680,
66
101
"description": "**Trigger Failed** \n**Reason:** '"${FAILURE_REASON}"' \n"}],
67
102
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
68
103
exit 1
69
104
fi
70
- echo "**** Last pushed version: ${IMAGE_VERSION} ****"
71
- echo "Last pushed version: ${IMAGE_VERSION}" >> $GITHUB_STEP_SUMMARY
72
- if [ "${EXT_RELEASE}" == "${IMAGE_VERSION}" ]; then
73
- echo "**** Version ${EXT_RELEASE} already pushed, exiting ****"
74
- echo "Version ${EXT_RELEASE} already pushed, exiting" >> $GITHUB_STEP_SUMMARY
105
+ echo "Last pushed version: \`${IMAGE_VERSION}\`" >> $GITHUB_STEP_SUMMARY
106
+ if [ "${EXT_RELEASE_SANITIZED}" == "${IMAGE_VERSION}" ]; then
107
+ echo "Sanitized version \`${EXT_RELEASE_SANITIZED}\` already pushed, exiting" >> $GITHUB_STEP_SUMMARY
75
108
exit 0
76
109
elif [ $(curl -s https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-code-server/job/master/lastBuild/api/json | jq -r '.building') == "true" ]; then
77
- echo "**** New version ${EXT_RELEASE} found; but there already seems to be an active build on Jenkins; exiting ****"
78
- echo "New version ${EXT_RELEASE} found; but there already seems to be an active build on Jenkins; exiting" >> $GITHUB_STEP_SUMMARY
110
+ echo "New version \`${EXT_RELEASE}\` found; but there already seems to be an active build on Jenkins; exiting" >> $GITHUB_STEP_SUMMARY
79
111
exit 0
80
112
else
81
- echo "**** New version ${EXT_RELEASE} found; old version was ${IMAGE_VERSION}. Triggering new build ****"
82
- echo "New version ${EXT_RELEASE} found; old version was ${IMAGE_VERSION}. Triggering new build" >> $GITHUB_STEP_SUMMARY
83
- response=$(curl -iX POST \
84
- https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-code-server/job/master/buildWithParameters?PACKAGE_CHECK=false \
85
- --user ${{ secrets.JENKINS_USER }}:${{ secrets.JENKINS_TOKEN }} | grep -i location | sed "s|^[L|l]ocation: \(.*\)|\1|")
86
- echo "**** Jenkins job queue url: ${response%$'\r'} ****"
87
- echo "**** Sleeping 10 seconds until job starts ****"
88
- sleep 10
89
- buildurl=$(curl -s "${response%$'\r'}api/json" | jq -r '.executable.url')
90
- buildurl="${buildurl%$'\r'}"
91
- echo "**** Jenkins job build url: ${buildurl} ****"
92
- echo "Jenkins job build url: ${buildurl}" >> $GITHUB_STEP_SUMMARY
93
- echo "**** Attempting to change the Jenkins job description ****"
94
- curl -iX POST \
95
- "${buildurl}submitDescription" \
96
- --user ${{ secrets.JENKINS_USER }}:${{ secrets.JENKINS_TOKEN }} \
97
- --data-urlencode "description=GHA external trigger https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}" \
98
- --data-urlencode "Submit=Submit"
99
- echo "**** Notifying Discord ****"
100
- TRIGGER_REASON="A version change was detected for code-server tag latest. Old version:${IMAGE_VERSION} New version:${EXT_RELEASE}"
101
- curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 9802903,
102
- "description": "**Build Triggered** \n**Reason:** '"${TRIGGER_REASON}"' \n**Build URL:** '"${buildurl}display/redirect"' \n"}],
103
- "username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
113
+ if [[ "${artifacts_found}" == "false" ]]; then
114
+ echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
115
+ echo "> New version detected, but not all artifacts are published yet; skipping trigger" >> $GITHUB_STEP_SUMMARY
116
+ FAILURE_REASON="New version ${EXT_RELEASE} for code-server tag latest is detected, however not all artifacts are uploaded to upstream release yet. Will try again later."
117
+ curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 9802903,
118
+ "description": "**Trigger Failed** \n**Reason:** '"${FAILURE_REASON}"' \n"}],
119
+ "username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
120
+ else
121
+ printf "\n## Trigger new build\n\n" >> $GITHUB_STEP_SUMMARY
122
+ echo "New sanitized version \`${EXT_RELEASE_SANITIZED}\` found; old version was \`${IMAGE_VERSION}\`. Triggering new build" >> $GITHUB_STEP_SUMMARY
123
+ if [[ "${artifacts_found}" == "true" ]]; then
124
+ echo "All artifacts seem to be uploaded." >> $GITHUB_STEP_SUMMARY
125
+ fi
126
+ response=$(curl -iX POST \
127
+ https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-code-server/job/master/buildWithParameters?PACKAGE_CHECK=false \
128
+ --user ${{ secrets.JENKINS_USER }}:${{ secrets.JENKINS_TOKEN }} | grep -i location | sed "s|^[L|l]ocation: \(.*\)|\1|")
129
+ echo "Jenkins [job queue url](${response%$'\r'})" >> $GITHUB_STEP_SUMMARY
130
+ echo "Sleeping 10 seconds until job starts" >> $GITHUB_STEP_SUMMARY
131
+ sleep 10
132
+ buildurl=$(curl -s "${response%$'\r'}api/json" | jq -r '.executable.url')
133
+ buildurl="${buildurl%$'\r'}"
134
+ echo "Jenkins job [build url](${buildurl})" >> $GITHUB_STEP_SUMMARY
135
+ echo "Attempting to change the Jenkins job description" >> $GITHUB_STEP_SUMMARY
136
+ curl -iX POST \
137
+ "${buildurl}submitDescription" \
138
+ --user ${{ secrets.JENKINS_USER }}:${{ secrets.JENKINS_TOKEN }} \
139
+ --data-urlencode "description=GHA external trigger https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}" \
140
+ --data-urlencode "Submit=Submit"
141
+ echo "**** Notifying Discord ****"
142
+ TRIGGER_REASON="A version change was detected for code-server tag latest. Old version:${IMAGE_VERSION} New version:${EXT_RELEASE_SANITIZED}"
143
+ curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 9802903,
144
+ "description": "**Build Triggered** \n**Reason:** '"${TRIGGER_REASON}"' \n**Build URL:** '"${buildurl}display/redirect"' \n"}],
145
+ "username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
146
+ fi
104
147
fi
0 commit comments