Skip to content

Deploy docs

Deploy docs #2740

Workflow file for this run

# Copyright (c) godot-rust; Bromeon and contributors.
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at https://mozilla.org/MPL/2.0/.
name: 'Deploy website'
on:
push:
branches: [master]
pull_request:
repository_dispatch:
types: ['Deploy docs']
env:
ZOLA_VERSION: 0.19.2
# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
permissions:
contents: write # for mutex branch
pages: write
id-token: write
jobs:
check-website:
runs-on: ubuntu-latest
if: github.event_name == 'pull_request'
steps:
- name: "Checkout"
uses: actions/checkout@v4
- name: "Build website"
uses: shalzz/zola-deploy-action@v0.19.2
env:
BUILD_DIR: website
TOKEN: fake-token
BUILD_ONLY: true
deploy-website:
runs-on: ubuntu-latest
if: github.event_name != 'pull_request'
steps:
- name: "Workflow triggered by push to master"
if: github.event_name == 'push'
run: echo "Triggered by commit SHA ${{ github.sha }}"
- name: "Workflow triggered by docs (${{ github.event.client_payload.op }} ${{ github.event.client_payload.repo }}/${{ github.event.client_payload.num }})"
if: github.event_name == 'repository_dispatch'
env:
JSON: ${{ toJson(github.event.client_payload) }}
run: echo "$JSON"
- name: "Wait for concurrent workflows to finish..."
uses: ben-z/gh-action-mutex@v1.0-alpha-7
with:
branch: ci-mutex-website
- name: "Checkout"
uses: actions/checkout@v4
# Note: if this is run the first time, this job fails because there is no doc-output branch.
# Easy enough to fix by deploying docs for both masters.
- name: "Fetch references to doc pages"
run: |
git fetch
git restore --source origin/doc-output website-docs-md
mv website-docs-md/* website/content/docs/
rm -r website-docs-md
# - name: "Build and deploy Zola"
# uses: shalzz/zola-deploy-action@master
# env:
# PAGES_BRANCH: gh-pages-prepared
# BUILD_DIR: website
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: "Install Zola ${{ env.ZOLA_VERSION }}"
run: |
wget -q -O - "https://github.com/getzola/zola/releases/download/v$ZOLA_VERSION/zola-v${ZOLA_VERSION}-x86_64-unknown-linux-gnu.tar.gz" \
| tar xzf - -C /usr/local/bin
- name: "Build Zola website"
working-directory: website
run: zola build
- name: "Integrate docs (triggered by push), push to gh-pages"
if: github.event_name == 'push'
run: |
bash documentation/fetch-website-docs.sh || {
echo "::warning::Could not fetch documentation"
}
- name: "Integrate docs (triggered by repo-dispatch)"
if: github.event_name == 'repository_dispatch'
env:
REPO: '${{ github.event.client_payload.repo }}'
NUM: '${{ github.event.client_payload.num }}'
run: |
bash documentation/fetch-website-docs.sh "$REPO" "$NUM"
- name: "Upload Pages artifact"
uses: actions/upload-pages-artifact@v3
with:
path: website/public
- name: "Deploy to GitHub Pages"
uses: actions/deploy-pages@v4
- name: "Comment on GitHub PR"
if: github.event_name == 'repository_dispatch' && github.event.client_payload.put_status == 'Create' && github.event.client_payload.num != 'master'
run: |
url="${{ github.event.client_payload.docs_full_url }}"
repo="${{ github.event.client_payload.repo }}"
num="${{ github.event.client_payload.num }}"
body="API docs are being generated and will be shortly available at: $url"
echo "cURL to https://api.github.com/repos/godot-rust/$repo/issues/$num/comments"
echo "Body: $body"
curl -L \
--fail-with-body \
-X POST \
-H "Accept: application/vnd.github+json" \
-H "Authorization: Bearer ${{ secrets.DOCS_COMMENTER_PAT }}" \
-H "X-GitHub-Api-Version: 2022-11-28" \
-d "{\"body\":\"$body\"}" \
https://api.github.com/repos/godot-rust/$repo/issues/$num/comments
license-guard:
# not on repo dispatch
if: github.event_name != 'repository_dispatch'
runs-on: ubuntu-20.04
steps:
- uses: actions/checkout@v4
- name: "Check license headers"
uses: apache/skywalking-eyes/header@v0.6.0
with:
# log: debug # optional: set the log level. The default value is `info`.
config: .github/external-config/licenserc.yml
# token: # optional: the token that license eye uses when it needs to comment on the pull request.
# Set to empty ("") to disable commenting on pull request. The default value is ${{ github.token }}
# mode: # optional: Which mode License-Eye should be run in. Choices are `check` or `fix`. The default value is `check`.
mode: check
- name: "Commit changes"
uses: EndBug/add-and-commit@v9
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
author_name: 'Godot-Rust Automation'
author_email: 'actions@github.com'
message: 'Auto-apply license headers'