64 lines
1.8 KiB
YAML
64 lines
1.8 KiB
YAML
name: Deploy Docs on new release
|
|
|
|
on:
|
|
release:
|
|
types:
|
|
- published
|
|
- edited
|
|
- released
|
|
|
|
jobs:
|
|
deploy:
|
|
name: Deploy to CloudFlare Pages
|
|
env:
|
|
CLOUDFLARE_PROJECT_NAME: docs
|
|
runs-on: ubuntu-latest
|
|
permissions:
|
|
contents: write
|
|
deployments: write
|
|
pull-requests: write
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
with:
|
|
ref: dev
|
|
- uses: actions/setup-node@v3
|
|
with:
|
|
node-version: 18
|
|
|
|
- name: Install jq
|
|
uses: dcarbone/install-jq-action@v2.0.1
|
|
|
|
- name: Fill env vars
|
|
working-directory: docs
|
|
run: |
|
|
env_example_file=".env.example"
|
|
touch .env
|
|
while IFS= read -r line || [[ -n "$line" ]]; do
|
|
if [[ "$line" == *"="* ]]; then
|
|
var_name=$(echo $line | cut -d '=' -f 1)
|
|
echo $var_name
|
|
var_value="$(jq -r --arg key "$var_name" '.[$key]' <<< "$SECRETS")"
|
|
echo "$var_name=$var_value" >> .env
|
|
fi
|
|
done < "$env_example_file"
|
|
env:
|
|
SECRETS: '${{ toJson(secrets) }}'
|
|
|
|
- name: Install dependencies
|
|
working-directory: docs
|
|
run: yarn install
|
|
- name: Build website
|
|
working-directory: docs
|
|
run: export NODE_ENV=production && yarn build && cp _redirects out/_redirects
|
|
|
|
- name: Publish to Cloudflare Pages Production
|
|
uses: cloudflare/pages-action@v1
|
|
with:
|
|
apiToken: ${{ secrets.CLOUDFLARE_API_TOKEN }}
|
|
accountId: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }}
|
|
projectName: ${{ env.CLOUDFLARE_PROJECT_NAME }}
|
|
directory: ./docs/out
|
|
branch: dev
|
|
# Optional: Enable this if you want to have GitHub Deployments triggered
|
|
gitHubToken: ${{ secrets.GITHUB_TOKEN }}
|