2022-09-10 08:18:35 +08:00
|
|
|
name: Deploy documentation
|
2022-09-08 11:46:13 +08:00
|
|
|
on:
|
|
|
|
push:
|
|
|
|
branches:
|
2022-09-09 11:37:40 +08:00
|
|
|
- main
|
2023-10-08 15:10:27 +08:00
|
|
|
- docs-snapshot
|
2023-10-11 19:03:26 +08:00
|
|
|
- docs-ci-test
|
2023-10-08 15:10:27 +08:00
|
|
|
workflow_dispatch: {}
|
2023-10-07 20:26:11 +08:00
|
|
|
release:
|
|
|
|
types:
|
|
|
|
- released
|
2022-09-09 11:37:40 +08:00
|
|
|
|
|
|
|
concurrency:
|
2023-10-11 19:03:26 +08:00
|
|
|
group: "pages-cf"
|
2022-09-09 11:37:40 +08:00
|
|
|
cancel-in-progress: true
|
2023-10-11 19:03:26 +08:00
|
|
|
|
2022-09-08 11:46:13 +08:00
|
|
|
jobs:
|
2023-10-08 15:10:27 +08:00
|
|
|
snapshot-docs:
|
|
|
|
name: Snapshot documentation
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
permissions:
|
|
|
|
contents: write
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
2023-10-09 14:48:25 +08:00
|
|
|
uses: actions/checkout@v4
|
2023-10-08 15:10:27 +08:00
|
|
|
# Run on releases only
|
|
|
|
if: ${{ github.event.release }}
|
|
|
|
with:
|
|
|
|
ref: ${{ github.ref }}
|
|
|
|
fetch-depth: 0
|
|
|
|
fetch-tags: true
|
|
|
|
- name: Merge with existing branch
|
|
|
|
# Run on releases only
|
|
|
|
if: ${{ github.event.release }}
|
|
|
|
run: |
|
|
|
|
git config --global user.name "GitHub Actions"
|
|
|
|
git config --global user.email "github-actions@nadena.dev"
|
|
|
|
git merge -s ours origin/docs-snapshot
|
|
|
|
git push origin HEAD:docs-snapshot
|
2023-07-30 11:28:18 +08:00
|
|
|
|
2022-09-09 12:01:14 +08:00
|
|
|
build-docs:
|
2023-07-30 11:28:18 +08:00
|
|
|
name: Build documentation (latest release)
|
2023-03-25 13:54:29 +08:00
|
|
|
uses: bdunderscore/modular-avatar/.github/workflows/build-test-docs.yml@main
|
2023-10-08 15:10:27 +08:00
|
|
|
needs:
|
|
|
|
- snapshot-docs
|
2023-05-05 12:50:45 +08:00
|
|
|
with:
|
2023-10-08 15:10:27 +08:00
|
|
|
ref: docs-snapshot
|
2023-05-05 12:50:45 +08:00
|
|
|
|
2023-03-25 13:22:48 +08:00
|
|
|
build-docs-dev:
|
2023-07-30 11:28:18 +08:00
|
|
|
name: Build documentation (main branch)
|
2023-03-25 13:54:29 +08:00
|
|
|
uses: bdunderscore/modular-avatar/.github/workflows/build-test-docs.yml@main
|
2023-03-25 13:22:48 +08:00
|
|
|
with:
|
2023-07-30 11:28:18 +08:00
|
|
|
ref: main
|
2023-03-25 13:22:48 +08:00
|
|
|
path: dev
|
|
|
|
artifact: docs-dev
|
2023-10-11 19:03:26 +08:00
|
|
|
|
2022-09-10 08:18:35 +08:00
|
|
|
deploy-docs:
|
2022-09-10 08:57:52 +08:00
|
|
|
name: Deploy documentation
|
2023-03-25 13:22:48 +08:00
|
|
|
needs:
|
|
|
|
- build-docs
|
|
|
|
- build-docs-dev
|
2022-09-08 11:46:13 +08:00
|
|
|
runs-on: ubuntu-latest
|
2022-09-10 08:18:35 +08:00
|
|
|
|
2022-09-08 11:46:13 +08:00
|
|
|
steps:
|
2023-11-01 18:01:18 +08:00
|
|
|
- uses: actions/setup-node@v4
|
2023-10-11 19:03:26 +08:00
|
|
|
with:
|
|
|
|
node-version: 18
|
|
|
|
|
|
|
|
- uses: actions/checkout@v4
|
|
|
|
with:
|
|
|
|
ref: ${{ inputs.ref || github.ref }}
|
|
|
|
|
|
|
|
- name: Download artifact (tagged)
|
2023-12-20 19:41:47 +08:00
|
|
|
uses: actions/download-artifact@v4
|
2022-09-08 11:46:13 +08:00
|
|
|
with:
|
2022-09-10 08:18:35 +08:00
|
|
|
name: docs
|
|
|
|
path: docs/build
|
2023-10-11 19:03:26 +08:00
|
|
|
|
|
|
|
- name: Download artifact (latest)
|
2023-12-20 19:41:47 +08:00
|
|
|
uses: actions/download-artifact@v4
|
2023-03-25 13:22:48 +08:00
|
|
|
with:
|
|
|
|
name: docs-dev
|
|
|
|
path: docs/build/dev
|
2023-03-25 13:57:38 +08:00
|
|
|
|
|
|
|
- name: Dump file listing
|
2023-03-25 13:22:48 +08:00
|
|
|
run: |
|
|
|
|
ls -lR docs/build
|
2022-09-08 11:46:13 +08:00
|
|
|
|
2023-10-08 15:23:16 +08:00
|
|
|
- name: Unpack documentation
|
|
|
|
run: |
|
2023-10-11 19:03:26 +08:00
|
|
|
mkdir -p docs-site~/public/dev
|
|
|
|
tar -xf docs/build/docs.tar -C docs-site~/public
|
|
|
|
tar -xf docs/build/dev/docs.tar -C docs-site~/public/dev
|
|
|
|
|
|
|
|
- name: Setup yarn 2.0
|
|
|
|
run: |
|
|
|
|
corepack enable
|
|
|
|
corepack prepare yarn@stable --activate
|
|
|
|
|
|
|
|
- name: Get yarn cache directory path
|
|
|
|
id: yarn-cache-dir-path
|
|
|
|
run: echo "dir=$(cd docs-site~; yarn config get cacheFolder)" >> $GITHUB_OUTPUT
|
2022-09-08 11:46:13 +08:00
|
|
|
|
2024-01-28 19:13:49 +08:00
|
|
|
- uses: actions/cache@v4
|
2023-10-11 19:03:26 +08:00
|
|
|
id: yarn-cache # use this to check for `cache-hit` (`steps.yarn-cache.outputs.cache-hit != 'true'`)
|
2022-09-08 11:46:13 +08:00
|
|
|
with:
|
2023-10-11 19:03:26 +08:00
|
|
|
path: ${{ steps.yarn-cache-dir-path.outputs.dir }}
|
|
|
|
key: ${{ runner.os }}-yarn-site-${{ hashFiles('**/yarn.lock') }}
|
|
|
|
restore-keys: |
|
|
|
|
${{ runner.os }}-yarn-site-
|
|
|
|
|
|
|
|
- name: Build CF site
|
|
|
|
run: |
|
|
|
|
cd docs-site~
|
2024-01-07 13:30:32 +08:00
|
|
|
YARN_ENABLE_IMMUTABLE_INSTALLS=false yarn install
|
2023-10-11 19:03:26 +08:00
|
|
|
|
|
|
|
- name: Deploy to Cloudflare Pages
|
|
|
|
uses: cloudflare/wrangler-action@v3
|
|
|
|
with:
|
|
|
|
apiToken: ${{ secrets.CF_API_TOKEN }}
|
2024-02-12 12:30:20 +08:00
|
|
|
command: deploy --name modular-avatar-docs
|
2023-10-11 19:03:26 +08:00
|
|
|
workingDirectory: docs-site~
|
|
|
|
|
|
|
|
- name: Purge cache
|
2024-10-16 10:13:24 +08:00
|
|
|
uses: nathanvaughn/actions-cloudflare-purge@992cc4e96422fb8ddf077281678373fe41e7736c
|
2023-10-11 19:03:26 +08:00
|
|
|
continue-on-error: true
|
|
|
|
with:
|
|
|
|
cf_zone: ${{ secrets.CF_ZONE_ID }}
|
2024-02-12 12:30:20 +08:00
|
|
|
cf_auth: ${{ secrets.CF_API_TOKEN }}
|