Build a static website on GH pages #8886
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
--- | |
name: Build a static website on GH pages | |
on: # yamllint disable-line rule:truthy | |
push: | |
pull_request: | |
schedule: | |
# https://crontab.guru/#23_*/4_*_*_* | |
- cron: 23 */4 * * * # At minute 23 past every 4th hour. | |
workflow_dispatch: | |
jobs: | |
build: | |
name: 👷 | |
runs-on: ubuntu-latest | |
steps: | |
- name: Switch to Python 3.11 | |
uses: actions/setup-python@v4 | |
with: | |
python-version: 3.11 | |
- name: Install packaging-related dists from PyPI | |
run: python -m pip install -U setuptools pip wheel --user | |
- name: Install jinja2, PyYAML and Sphinx dists from PyPI | |
run: python -m pip install jinja2 pyyaml sphinx --user | |
- name: Fetch the config from the repo | |
uses: actions/checkout@v3 | |
- name: Generate a static website | |
run: | | |
from collections import defaultdict | |
from functools import partial | |
from pathlib import Path | |
from unittest.mock import Mock | |
from urllib.parse import urljoin, urlparse | |
import jinja2 | |
import yaml | |
from sphinx.builders.html import INVENTORY_FILENAME | |
from sphinx.ext.intersphinx import fetch_inventory | |
sphinx_app_mock = Mock() | |
sphinx_app_mock.config.intersphinx_timeout = None | |
sphinx_app_mock.config.tls_verify = False | |
sphinx_app_mock.config.user_agent = None | |
sphinx_app_mock.srcdir = '' | |
fetch_sphinx_inventory = partial(fetch_inventory, sphinx_app_mock, '') | |
config = yaml.safe_load(Path('sphinx-websites.yml').read_text()) | |
websites = defaultdict(set) | |
for url in config: | |
websites[urlparse(url).netloc].add(url) | |
env = jinja2.Environment( | |
loader=jinja2.FileSystemLoader(searchpath='templates/'), | |
) | |
index_template = env.get_template('index.html.j2') | |
table_template = env.get_template('table.html.j2') | |
rendered_pages = {} | |
for host, urls in websites.items(): | |
inventories = { | |
url: fetch_sphinx_inventory( | |
urljoin(f'{url !s}/', INVENTORY_FILENAME), | |
) | |
for url in map(lambda s: s.rstrip('/'), urls) | |
} | |
rendered_pages[host] = table_template.render(locals()) | |
rendered_index = index_template.render(sites=websites.keys()) | |
www_dir = Path('www') | |
www_dir.mkdir() | |
for host in websites: | |
(www_dir / host).mkdir() | |
(www_dir / host / 'index.html').write_text( | |
rendered_pages[host], | |
) | |
(www_dir / 'index.html').write_text(rendered_index) | |
shell: python | |
- name: Save the generated HTML output as a GitHub Actions artifact | |
uses: actions/upload-pages-artifact@v2 | |
with: | |
path: www | |
publish: | |
name: 📢 | |
needs: | |
- build | |
if: github.event_name != 'pull_request' | |
runs-on: ubuntu-latest | |
environment: | |
name: gh-pages | |
url: https://webknjaz.github.io/intersphinx-untangled/ | |
permissions: | |
pages: write # This allows to publish a GitHub Pages site | |
# `id-token` allows GitHub Pages to verify the deployment originates | |
# from an appropriate source through OpenID Connect, according to the | |
# README of the `actions/deploy-pages` action. | |
id-token: write | |
steps: | |
- name: Publish the website to GH Pages | |
uses: actions/deploy-pages@v2 | |
... |