-
-
Notifications
You must be signed in to change notification settings - Fork 399
91 lines (78 loc) · 3.07 KB
/
generate-doc.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
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
name: 📖 Documentation
on:
pull_request:
# on pull request we just want to build
paths:
- "docs/**"
- ".github/workflows/generate-doc.yml"
- "mkdocs.yml"
push:
# on merge to main, build and publish
branches: [ "main" ]
jobs:
documentation:
name: Documentation
runs-on: ubuntu-latest
steps:
- name: Checkout sources
uses: actions/checkout@v4
with:
fetch-depth: 1
# generating project documentation
- name: Build documentation with MkDocs
run: |
scripts/build_mkdocs.sh
# generating perl documentation
- name: 🐪 Install Perl requirements
run: |
sudo apt-get update
sudo apt-get install perl perl-doc cpanminus libmodern-perl-perl
- name: "Setup local::lib"
run: |
cpanm --local-lib=~/perl5 local::lib && eval $(perl -I ~/perl5/lib/perl5/ -Mlocal::lib)
- name: Run generate_perl_html_doc_from_pod.pl
run: |
rm -rf gh_pages/dev/ref-perl-pod && \
mkdir gh_pages/dev/ref-perl-pod && \
cp docs/assets/simple.min.css gh_pages/dev/ref-perl-pod && \
perl -CS -I lib scripts/generate_perl_html_doc_from_pod.pl gh_pages/dev/ref-perl-pod
# DISABLED: in favor of rapidoc
# generating OpenAPI documentation with redocly
# we do this after mkdocs to overwrite api.html file
# - name: Generate openapi html with ghcr.io/redocly/redoc/cli:latest
# run : |
# docker run --rm \
# -v $(pwd)/docs/api/ref:/data -v $(pwd)/gh_pages/:/output \
# ghcr.io/redocly/redoc/cli:latest \
# build -o /output/api/ref-v2/index.html api.yml && \
# sudo chown $UID -R gh_pages
# - name: Generate openapi html for v3 with ghcr.io/redocly/redoc/cli:latest
# run : |
# docker run --rm \
# -v $(pwd)/docs/api/ref:/data -v $(pwd)/gh_pages/:/output \
# ghcr.io/redocly/redoc/cli:latest \
# build -o /output/api/ref-v3/index.html api-v3.yml && \
# sudo chown $UID -R gh_pages
- name: Validate OpenAPI
run: |
make check_openapi
# generate OpenAPI documentation with rapidoc
# we do this after mkdocs to overwrite api.html file
- name: Generate OpenAPI doc using rapidoc
# this is a simple copy of the html file as all is static there
run : |
# v2 api
cp docs/assets/api-rapidoc.html gh_pages/api/ref-v2/index.html
# v3 api - change yaml and link to api-v3
cat docs/assets/api-rapidoc.html | \
sed -e "s/api.yml/api-v3.yml/" -e 's|ref-v3/">API v3|ref-v2/">API v2|' \
> gh_pages/api/ref-v3/index.html
- name: Deploy API documentation to GitHub Pages
uses: JamesIves/github-pages-deploy-action@v4.7.2
# we only deploy on push to main
if: |
github.event_name == 'push' && github.event.ref == 'refs/heads/main'
with:
token: ${{ secrets.GITHUB_TOKEN }}
branch: "gh-pages"
folder: gh_pages