Skip to content
This repository was archived by the owner on Jun 15, 2021. It is now read-only.

Commit 8273f45

Browse files
authored
Merge pull request #137 from linuxserver/master-workflows
add trigger workflows
2 parents 258c56e + eba6177 commit 8273f45

File tree

4 files changed

+175
-0
lines changed

4 files changed

+175
-0
lines changed
+70
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,70 @@
1+
name: External Trigger Main
2+
3+
on:
4+
workflow_dispatch:
5+
6+
jobs:
7+
external-trigger-master:
8+
runs-on: ubuntu-latest
9+
steps:
10+
- uses: actions/[email protected]
11+
12+
- name: External Trigger
13+
if: github.ref == 'refs/heads/master'
14+
run: |
15+
if [ -n "${{ secrets.PAUSE_EXTERNAL_TRIGGER_OPENVPN_AS_MASTER }}" ]; then
16+
echo "Github secret PAUSE_EXTERNAL_TRIGGER_OPENVPN_AS_MASTER is set; skipping trigger."
17+
exit 0
18+
fi
19+
echo "External trigger running off of master branch. To disable this trigger, set a Github secret named \"PAUSE_EXTERNAL_TRIGGER_OPENVPN_AS_MASTER\"."
20+
echo "Retrieving external version"
21+
EXT_RELEASE=$(curl -sX GET http://as-repository.openvpn.net/as/debian/dists/bionic/main/binary-amd64/Packages.gz | gunzip -c |grep -A 7 -m 1 'Package: openvpn-as' | awk -F ': ' '/Version/{print $2;exit}')
22+
if [ -z "${EXT_RELEASE}" ]; then
23+
echo "Can't retrieve external version, exiting"
24+
FAILURE_REASON="Can't retrieve external version for openvpn-as branch master"
25+
curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 16711680,
26+
"description": "**Trigger Failed** \n**Reason:** '"${FAILURE_REASON}"' \n"}],
27+
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
28+
exit 1
29+
fi
30+
echo "External version: ${EXT_RELEASE}"
31+
echo "Retrieving last pushed version"
32+
image="linuxserver/openvpn-as"
33+
tag="latest"
34+
token=$(curl -sX GET \
35+
"https://ghcr.io/token?scope=repository%3Alinuxserver%2Fopenvpn-as%3Apull" \
36+
| jq -r '.token')
37+
digest=$(curl -s \
38+
--header "Accept: application/vnd.docker.distribution.manifest.v2+json" \
39+
--header "Authorization: Bearer ${token}" \
40+
"https://ghcr.io/v2/${image}/manifests/${tag}" \
41+
| jq -r '.config.digest')
42+
image_info=$(curl -sL \
43+
--header "Authorization: Bearer ${token}" \
44+
"https://ghcr.io/v2/${image}/blobs/${digest}" \
45+
| jq -r '.container_config')
46+
IMAGE_RELEASE=$(echo ${image_info} | jq -r '.Labels.build_version' | awk '{print $3}')
47+
IMAGE_VERSION=$(echo ${IMAGE_RELEASE} | awk -F'-ls' '{print $1}')
48+
if [ -z "${IMAGE_VERSION}" ]; then
49+
echo "Can't retrieve last pushed version, exiting"
50+
FAILURE_REASON="Can't retrieve last pushed version for openvpn-as tag latest"
51+
curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 16711680,
52+
"description": "**Trigger Failed** \n**Reason:** '"${FAILURE_REASON}"' \n"}],
53+
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
54+
exit 1
55+
fi
56+
echo "Last pushed version: ${IMAGE_VERSION}"
57+
if [ "${EXT_RELEASE}" == "${IMAGE_VERSION}" ]; then
58+
echo "Version ${EXT_RELEASE} already pushed, exiting"
59+
exit 0
60+
else
61+
echo "New version ${EXT_RELEASE} found; old version was ${IMAGE_VERSION}. Triggering new build"
62+
curl -X POST \
63+
https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-openvpn-as/job/master/buildWithParameters?PACKAGE_CHECK=false \
64+
--user ${{ secrets.JENKINS_USER }}:${{ secrets.JENKINS_TOKEN }}
65+
echo "Notifying Discord"
66+
TRIGGER_REASON="A version change was detected for openvpn-as tag latest. Old version:${IMAGE_VERSION} New version:${EXT_RELEASE}"
67+
curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 9802903,
68+
"description": "**Build Triggered** \n**Reason:** '"${TRIGGER_REASON}"' \n"}],
69+
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
70+
fi
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,41 @@
1+
name: External Trigger Scheduler
2+
3+
on:
4+
schedule:
5+
- cron: '45 * * * *'
6+
workflow_dispatch:
7+
8+
jobs:
9+
external-trigger-scheduler:
10+
runs-on: ubuntu-latest
11+
steps:
12+
- uses: actions/[email protected]
13+
with:
14+
fetch-depth: '0'
15+
16+
- name: External Trigger Scheduler
17+
run: |
18+
git for-each-ref --format='%(refname:short)' refs/remotes
19+
docker pull ghcr.io/linuxserver/yq
20+
for br in $(git for-each-ref --format='%(refname:short)' refs/remotes)
21+
do
22+
br=$(echo "$br" | sed 's|origin/||g')
23+
echo "Evaluating branch ${br}"
24+
ls_branch=$(curl -sX GET https://raw.githubusercontent.com/linuxserver/docker-openvpn-as/${br}/jenkins-vars.yml \
25+
| docker run --rm -i --entrypoint yq ghcr.io/linuxserver/yq -r .ls_branch)
26+
if [ "$br" == "$ls_branch" ]; then
27+
echo "${br} is a live branch, checking workflow."
28+
if curl -sfX GET https://raw.githubusercontent.com/linuxserver/docker-openvpn-as/${br}/.github/workflows/external_trigger.yml > /dev/null 2>&1; then
29+
echo "Workflow exists. Triggering external trigger workflow for branch ${br}."
30+
curl -iX POST \
31+
-H "Authorization: token ${{ secrets.CR_PAT }}" \
32+
-H "Accept: application/vnd.github.v3+json" \
33+
-d "{\"ref\":\"refs/heads/${br}\"}" \
34+
https://api.github.com/repos/linuxserver/docker-openvpn-as/actions/workflows/external_trigger.yml/dispatches
35+
else
36+
echo "Workflow doesn't exist; skipping trigger."
37+
fi
38+
else
39+
echo "${br} appears to be a dev branch; skipping trigger."
40+
fi
41+
done

.github/workflows/package_trigger.yml

+22
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
name: Package Trigger Main
2+
3+
on:
4+
workflow_dispatch:
5+
6+
jobs:
7+
package-trigger-master:
8+
runs-on: ubuntu-latest
9+
steps:
10+
- uses: actions/[email protected]
11+
12+
- name: Package Trigger
13+
if: github.ref == 'refs/heads/master'
14+
run: |
15+
if [ -n "${{ secrets.PAUSE_PACKAGE_TRIGGER_OPENVPN_AS_MASTER }}" ]; then
16+
echo "Github secret PAUSE_PACKAGE_TRIGGER_OPENVPN_AS_MASTER is set; skipping trigger."
17+
exit 0
18+
fi
19+
echo "Package trigger running off of master branch. To disable, set a Github secret named \"PAUSE_PACKAGE_TRIGGER_OPENVPN_AS_MASTER\"."
20+
curl -X POST \
21+
https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-openvpn-as/job/master/buildWithParameters?PACKAGE_CHECK=true \
22+
--user ${{ secrets.JENKINS_USER }}:${{ secrets.JENKINS_TOKEN }}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,42 @@
1+
name: Package Trigger Scheduler
2+
3+
on:
4+
schedule:
5+
- cron: '40 4 * * 4'
6+
workflow_dispatch:
7+
8+
jobs:
9+
package-trigger-scheduler:
10+
runs-on: ubuntu-latest
11+
steps:
12+
- uses: actions/[email protected]
13+
with:
14+
fetch-depth: '0'
15+
16+
- name: Package Trigger Scheduler
17+
run: |
18+
git for-each-ref --format='%(refname:short)' refs/remotes
19+
docker pull ghcr.io/linuxserver/yq
20+
for br in $(git for-each-ref --format='%(refname:short)' refs/remotes)
21+
do
22+
br=$(echo "$br" | sed 's|origin/||g')
23+
echo "Evaluating branch ${br}"
24+
ls_branch=$(curl -sX GET https://raw.githubusercontent.com/linuxserver/docker-openvpn-as/${br}/jenkins-vars.yml \
25+
| docker run --rm -i --entrypoint yq ghcr.io/linuxserver/yq -r .ls_branch)
26+
if [ "${br}" == "${ls_branch}" ]; then
27+
echo "Branch ${br} appears to be live; triggering."
28+
if curl -sfX GET https://raw.githubusercontent.com/linuxserver/docker-openvpn-as/${br}/.github/workflows/package_trigger.yml > /dev/null 2>&1; then
29+
echo "Workflow exists. Triggering package trigger workflow for branch ${br}."
30+
curl -iX POST \
31+
-H "Authorization: token ${{ secrets.CR_PAT }}" \
32+
-H "Accept: application/vnd.github.v3+json" \
33+
-d "{\"ref\":\"refs/heads/${br}\"}" \
34+
https://api.github.com/repos/linuxserver/docker-openvpn-as/actions/workflows/package_trigger.yml/dispatches
35+
sleep 30
36+
else
37+
echo "Workflow doesn't exist; skipping trigger."
38+
fi
39+
else
40+
echo "${br} appears to be a dev branch; skipping trigger."
41+
fi
42+
done

0 commit comments

Comments
 (0)