-
Notifications
You must be signed in to change notification settings - Fork 9
256 lines (210 loc) · 7.48 KB
/
publish-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
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
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
name: publish-pages
on:
# Runs on pushes targeting the default branch
push:
branches:
- main
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
# run every 6 hours
schedule:
- cron: "0 */6 * * *"
# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
permissions:
contents: read
pages: write
id-token: write
# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued.
# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete.
concurrency:
group: pages
cancel-in-progress: false
jobs:
# download the redis dump from s3
# create the json files for the redis data
# upload the json files to github artifacts
publish_pages:
runs-on: ubuntu-latest
timeout-minutes: 10
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
steps:
# https://github.com/actions/toolkit/issues/946#issuecomment-1590016041
- name: root suid tar
run: sudo chown root:root /bin/tar && sudo chmod u+s /bin/tar
- uses: actions/checkout@v3
- name: Setup Pages
uses: actions/configure-pages@v3
- name: Use Node.js 18.15.0
uses: actions/setup-node@v3
with:
node-version: 18.15.0
- name: get current hour for cache busting
id: cache-hour
run: echo "hour=$(date +'%Y-%m-%d-%H')" >>$GITHUB_OUTPUT
- name: Cache Redis Dump
id: cache-redis
uses: actions/cache@v3
env:
cache-name: cache-redis
with:
path: ./.redis/
key: cache-redis-${{ steps.cache-hour.outputs.hour }}
# download redis db dump from s3
- name: Download the Redis Dump
if: steps.cache-redis.outputs.cache-hit != 'true'
uses: keithweaver/aws-s3-github-action@v1.0.0
with:
command: cp
source: s3://${{ vars.BUILD_S3_BUCKET }}/checkpoint/dump.rdb
destination: ./.redis/dump.rdb
aws_access_key_id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws_secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws_region: ap-southeast-2
# start redis & check if it is running
- name: Start Redis
working-directory: ./crawler
run: docker compose -f "docker-compose.github.yaml" up -d redis
- working-directory: ./crawler
run: docker ps -a
- working-directory: ./crawler
run: docker compose -f "docker-compose.github.yaml" logs redis
# install npm dependencies
- name: Cache NPM Modules
id: cache-crawler-npm
uses: actions/cache@v3
env:
cache-name: cache-crawler-npm
with:
path: ./crawler/node_modules/
key: cache-crawler-npm-${{ hashFiles('crawler/package-lock.json') }}
- name: Install Dependencies
if: steps.cache-crawler-npm.outputs.cache-hit != 'true'
run: npm ci
working-directory: ./crawler
- name: Run Health Script
run: node index.js --health
working-directory: ./crawler
- name: Run Output Script
run: node index.js --out
working-directory: ./crawler
# store the json files as artifacts
# - name: archive json artifacts
# uses: actions/upload-artifact@v3
# with:
# name: dist-json-bundle
# path: |
# ./frontend/public/data/
- name: copy the json files to github pages
working-directory: ./
run: cp -r ./frontend/public/data/ ./pages/public/
# build pages frontend
- name: Cache NPM Modules
id: cache-pages-npm
uses: actions/cache@v3
env:
cache-name: cache-pages-npm
with:
path: ./pages/node_modules/
key: cache-pages-npm-${{ hashFiles('pages/package-lock.json') }}
- name: Install Dependencies
if: steps.cache-pages-npm.outputs.cache-hit != 'true'
run: npm ci
working-directory: ./pages
- name: Build the Frontend for Pages
run: npm run build
working-directory: ./pages
# upload pages
- name: upload github pages artifacts
uses: actions/upload-pages-artifact@v1
with:
path: ./pages/dist/
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v2
# stop redis
- name: Stop Redis
working-directory: ./crawler
if: always()
run: docker compose -f "docker-compose.github.yaml" down
# download the json files from the generate_jsons job
# install npm dependencies
# build the frontend
# store the frontend bundle as artifact
# build_frontend:
# runs-on: ubuntu-latest
# timeout-minutes: 30
# needs: generate_jsons
# steps:
# - uses: actions/checkout@v3
# # download the artifacts from the generate_jsons job
# - name: Download the JSON Bundle
# uses: actions/download-artifact@v2
# with:
# name: dist-json-bundle
# path: ./frontend/public/data/
# # bundle the frontend
# - name: Use Node.js 18.15.0
# uses: actions/setup-node@v3
# with:
# node-version: 18.15.0
# - name: List the JSON Bundle
# run: ls -lah ./public/data
# working-directory: ./frontend
# - name: Cache NPM Modules
# id: cache-frontend-npm
# uses: actions/cache@v3
# env:
# cache-name: cache-frontend-npm
# with:
# path: ./frontend/node_modules/
# key: cache-frontend-npm-${{ hashFiles('frontend/package-lock.json') }}
# - name: Install Dependencies
# if: steps.cache-frontend-npm.outputs.cache-hit != 'true'
# run: npm ci
# working-directory: ./frontend
# - name: Build the Frontend
# run: npm run build
# working-directory: ./frontend
# # store the frontend bundle as artifact
# - name: Archive production artifacts
# uses: actions/upload-artifact@v3
# with:
# name: dist-frontend-bundle
# path: |
# ./frontend/dist/
# download the artifacts generated from the other jobs
# zip the json files
# generate a release tag
# create a release with artifacts zip attached
# create_release:
# runs-on: ubuntu-latest
# timeout-minutes: 10
# needs: [generate_jsons, build_frontend]
# steps:
# - uses: actions/checkout@v3
# # download the artifacts from the generate_jsons job
# - name: Download the JSON Bundle
# uses: actions/download-artifact@v2
# with:
# name: dist-json-bundle
# path: ./dist-json-bundle/
# - name: Zip artifact for deployment
# run: zip dist-json-bundle.zip ./dist-json-bundle/* -r
# - name: Generate release tag
# id: generate_release_tag
# uses: amitsingh-007/next-release-tag@v4.0.0
# with:
# github_token: ${{ github.token }}
# tag_prefix: 'v'
# tag_template: 'yyyy.mm.dd.i'
# - name: Create Release
# uses: softprops/action-gh-release@v1
# with:
# tag_name: ${{ steps.generate_release_tag.outputs.next_release_tag }}
# name: Release ${{ steps.generate_release_tag.outputs.next_release_tag }}
# prerelease: false
# generate_release_notes: true
# fail_on_unmatched_files: true
# files: ./dist-json-bundle.zip