-
Notifications
You must be signed in to change notification settings - Fork 0
191 lines (161 loc) · 5.59 KB
/
docs.yml
File metadata and controls
191 lines (161 loc) · 5.59 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
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
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
# .github/workflows/docs.yml
name: Build and Deploy Docs
on:
push:
branches:
- main
workflow_dispatch:
permissions:
contents: read
pages: write
id-token: write
concurrency:
group: "pages"
cancel-in-progress: false
jobs:
# Build job for GitHub
build-github:
name: Build Documentation (GitHub)
runs-on: ubuntu-latest
if: ${{ github.server_url == 'https://github.com' }}
env:
NODE_EXTRA_CA_CERTS: /etc/ssl/certs/ca-certificates.crt
SSL_CERT_FILE: /etc/ssl/certs/ca-certificates.crt
REQUESTS_CA_BUNDLE: /etc/ssl/certs/ca-certificates.crt
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Install Act dependencies
if: ${{ env.ACT }}
run: |
if ! command -v apt-get &> /dev/null; then
echo "apt-get not found, cannot proceed"
exit 1
fi
DEBIAN_FRONTEND=noninteractive apt-get update && \
DEBIAN_FRONTEND=noninteractive apt-get install -y apt-utils sudo
- name: Install Runner Dependencies & Configure CA
run: |
sudo apt-get update
sudo DEBIAN_FRONTEND=noninteractive apt-get install -y lsb-release nodejs ca-certificates
sudo update-ca-certificates
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.10'
- name: Install dependencies
run: |
pip install --upgrade pip setuptools wheel
pip install -e ".[dev]"
- name: Build Sphinx documentation
run: sphinx-build -b html docs/source docs/build/html
- name: Upload artifact for GitHub Pages
if: ${{ !env.ACT }}
uses: actions/upload-pages-artifact@v3
with:
path: docs/build/html
- name: Upload artifact for GitHub
uses: actions/upload-artifact@v4
with:
name: docs-artifact
path: docs/build/html
# Build job for Gitea
build-gitea:
name: Build Documentation (Gitea)
runs-on: ubuntu-latest
if: ${{ github.server_url != 'https://github.com' }}
env:
NODE_EXTRA_CA_CERTS: /etc/ssl/certs/ca-certificates.crt
SSL_CERT_FILE: /etc/ssl/certs/ca-certificates.crt
REQUESTS_CA_BUNDLE: /etc/ssl/certs/ca-certificates.crt
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Install Act dependencies
if: ${{ env.ACT }}
run: |
if ! command -v apt-get &> /dev/null; then
echo "apt-get not found, cannot proceed"
exit 1
fi
DEBIAN_FRONTEND=noninteractive apt-get update && \
DEBIAN_FRONTEND=noninteractive apt-get install -y apt-utils sudo
- name: Install Runner Dependencies & Configure CA
run: |
sudo apt-get update
sudo DEBIAN_FRONTEND=noninteractive apt-get install -y lsb-release nodejs ca-certificates
sudo update-ca-certificates
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.10'
- name: Install dependencies
run: |
pip install --upgrade pip setuptools wheel
pip install -e ".[dev]"
- name: Build Sphinx documentation
run: sphinx-build -b html docs/source docs/build/html
- name: Upload artifact for Gitea
uses: actions/upload-artifact@v3
with:
name: docs-artifact
path: docs/build/html
# Deploy job for GitHub Pages
deploy-github:
name: Deploy to GitHub Pages
needs: build-github
if: ${{ github.server_url == 'https://github.com' }}
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: ubuntu-latest
env:
NODE_EXTRA_CA_CERTS: /etc/ssl/certs/ca-certificates.crt
steps:
- name: Install Act dependencies
if: ${{ env.ACT }}
run: |
apt-get update && apt-get install -y sudo
- name: Install Runner Dependencies & Configure CA
run: |
sudo apt-get update
sudo DEBIAN_FRONTEND=noninteractive apt-get install -y nodejs ca-certificates
sudo update-ca-certificates
- name: Deploy to GitHub Pages
id: deployment
if: ${{ !env.ACT }}
uses: actions/deploy-pages@v4
# Deploy job for Gitea
deploy-gitea:
name: Deploy to Gitea Pages
needs: build-gitea
if: ${{ github.server_url != 'https://github.com' }}
runs-on: ubuntu-latest
env:
NODE_EXTRA_CA_CERTS: /etc/ssl/certs/ca-certificates.crt
steps:
- name: Install Act dependencies
if: ${{ env.ACT }}
run: |
apt-get update && apt-get install -y sudo
- name: Install Runner Dependencies & Configure CA
run: |
sudo apt-get update
sudo DEBIAN_FRONTEND=noninteractive apt-get install -y nodejs ca-certificates
sudo update-ca-certificates
- name: Download artifact
uses: actions/download-artifact@v3
with:
name: docs-artifact
path: ./docs-site
- name: Deploy to Gitea docs location
run: |
echo "Deploying documentation to Gitea's special directory..."
# The '/pages' directory is a mounted volume on the Gitea runner for serving static content.
# Deploy to a subfolder named after the repository
TARGET_DIR="/pages/docs/${{ github.event.repository.name }}"
# Clean, recreate, copy, and set permissions
sudo rm -rf "$TARGET_DIR"
sudo mkdir -p "$TARGET_DIR"
sudo cp -r ./docs-site/. "$TARGET_DIR/"
sudo chmod -R 755 "$TARGET_DIR"