-
Notifications
You must be signed in to change notification settings - Fork 0
58 lines (47 loc) · 1.74 KB
/
release.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
name: release
on:
push:
tags:
- '*'
jobs:
check-tag:
runs-on: ubuntu-latest
steps:
- name: Check tag format
run: |
if [[ ${{ github.ref_name }} =~ ^(?P<major>0|[1-9]\d*)\.(?P<minor>0|[1-9]\d*)\.(?P<patch>0|[1-9]\d*)(?:-(?P<prerelease>(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+(?P<buildmetadata>[0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?$ ]]; then
echo "Tag format is valid: ${{ github.ref_name }}"
else
echo "Invalid tag format: ${{ github.ref_name }}"
exit 1
fi
release-gh:
name: Release on GitHub
runs-on: ubuntu-latest
needs: check-tag
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Download firewall build artifact
uses: dawidd6/action-download-artifact@v3
with:
workflow: firewall-build.yml
workflow_conclusion: success
name: cerbero
path: firewall/
- name: Release on GitHub
run: |
latest_tag=$(git describe --tags --abbrev=0)
is_prerelease=false
release_attachments="firewall/cerbero"
if [[ $latest_tag == *"alpha"* || $latest_tag == *"beta"* ]]; then
is_prerelease=true
fi
command="gh release create $(git describe --tags --abbrev=0) -t $(git describe --tags --abbrev=0) --target main --generate-notes"
if [ $is_prerelease = true ]; then
command="$command --prerelease"
fi
command="$command $release_attachments"
$command
env:
GITHUB_TOKEN: ${{ secrets.CUSTOM_TOKEN }} # A custom token is needed to chain workflows after this one (e.g. docker builds)