-
Notifications
You must be signed in to change notification settings - Fork 567
63 lines (50 loc) · 1.74 KB
/
build-docs.yaml
File metadata and controls
63 lines (50 loc) · 1.74 KB
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
name: OpenAPI Build Documentation
on:
push:
branches:
- main
paths:
- 'specs/swagger/**'
permissions:
contents: write
jobs:
lint-and-build:
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Setup Node.js
uses: actions/setup-node@v4
- name: Install Redocly CLI
run: npm install -g @redocly/cli
- name: Switch to gh-pages and copy OpenAPI source
run: |
git config --local user.email "action@github.com"
git config --local user.name "GitHub Action"
mkdir tmp-api
cp specs/swagger/openapi.yaml tmp-api/
git checkout gh-pages
cp tmp-api/openapi.yaml specs/swagger/openapi.yaml
rm -rf /tmp-api
- name: Build OpenAPI documentation
run: |
cd specs/swagger
echo "Building OpenAPI documentation..."
redocly build-docs openapi.yaml --output=openapi.html
echo "Documentation built successfully!"
- name: Commit and push documentation
run: |
git config --local user.email "action@github.com"
git config --local user.name "GitHub Action"
git add specs/swagger/openapi.html specs/swagger/openapi.yaml
if git diff --staged --quiet; then
echo "No changes to commit"
else
git commit -m "Update OpenAPI documentation from main branch"
git push origin gh-pages
echo "Documentation pushed to gh-pages branch!"
fi
env:
GITHUB_TOKEN: ${{ secrets.GH_SYSTEMSDT_TOKEN }}