-
Notifications
You must be signed in to change notification settings - Fork 13
114 lines (114 loc) · 3.94 KB
/
gh-pages.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
name: github pages
on:
push:
branches:
- main
paths-ignore:
- .github/workflows/*.yml
- .github/workflows/*.yaml
repository_dispatch:
types: [samm-core-released]
workflow_dispatch:
env:
hugo_version: '0.81.0'
jobs:
updateHugoMod:
runs-on: ubuntu-latest
outputs:
goMod: ${{ steps.modFiles.outputs.goMod }}
goSum: ${{ steps.modFiles.outputs.goSum }}
steps:
- name: Parse semver string
if: github.event_name == 'repository_dispatch'
id: semver_parser
uses: booxmedialtd/ws-action-parse-semver@v1
with:
input_string: ${{ github.event.client_payload.release }}
version_extractor_regex: 'v(.*)$'
- name: Check release semver sanity
if: github.event_name == 'repository_dispatch'
env:
RELEASE: "v${{ steps.semver_parser.outputs.fullversion }}"
run: |
if [ "${RELEASE}" = "v" ]; then
echo "::error title={Bad Semver}::{Release version is not semver compatible}"
exit 1
fi
- uses: actions/checkout@v3
with:
submodules: true # Fetch Hugo themes (true OR recursive)
fetch-depth: 0 # Fetch all history for .GitInfo and .Lastmod
- name: Setup Hugo
uses: peaceiris/actions-hugo@v2
with:
hugo-version: ${{ env.hugo_version }}
extended: true
- name: Get new release and commit to main
if: github.event_name == 'repository_dispatch'
env:
RELEASE: "v${{ steps.semver_parser.outputs.fullversion }}"
run: |
echo "We got a new SAMM release: v${{ steps.semver_parser.outputs.fullversion }}${RELEASE}"
hugo mod get "github.com/owaspsamm/core@markdown/${RELEASE}"
cat go.mod
- name: Get translations
run: |
hugo mod get "github.com/owaspsamm/i18n-FR@markdown"
- name: Passing hugo mod files
id: modFiles
run: |
{
echo 'goMod<<EOF'
cat go.mod
echo EOF
} >> "$GITHUB_OUTPUT"
{
echo 'goSum<<EOF'
cat go.sum
echo EOF
} >> "$GITHUB_OUTPUT"
- name: Set commit message
run: |
if [ -z "${{ github.event.client_payload.release }}" ]; then
echo "COMMIT_MESSAGE='Updated translations'" >> $GITHUB_ENV
else
echo "COMMIT_MESSAGE='New SAMM release: ${{ github.event.client_payload.release }}'" >> $GITHUB_ENV
fi
- name: Commit updated files to git
uses: EndBug/add-and-commit@v9
with:
add: '["go.mod", "go.sum"]'
default_author: github_actions
message: "${{ env.COMMIT_MESSAGE }}"
deploy:
runs-on: ubuntu-latest
needs: updateHugoMod
if: ${{ always() && (needs.updateHugoMod.result == 'success' || needs.updateHugoMod.result == 'skipped') }}
steps:
- uses: actions/checkout@v3
with:
submodules: true # Fetch Hugo themes (true OR recursive)
fetch-depth: 0 # Fetch all history for .GitInfo and .Lastmodd
- name: Get hugo mod files
if: ${{ needs.updateHugoMod.result == 'success' }}
run: |
echo "${{needs.updateHugoMod.outputs.goMod}}" > go.mod
echo "${{needs.updateHugoMod.outputs.goSum}}" > go.sum
- uses: actions/cache@v3
with:
path: /tmp/hugo_cache
key: ${{ runner.os }}-hugomod-${{ hashFiles('**/go.sum') }}
restore-keys: |
${{ runner.os }}-hugomod-
- name: Setup Hugo
uses: peaceiris/actions-hugo@v2
with:
hugo-version: ${{ env.hugo_version }}
extended: true
- name: Build
run: hugo --gc --minify -v --cleanDestinationDir --environment production
- name: Deploy
uses: peaceiris/actions-gh-pages@v3
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
publish_dir: ./public