Skip to content

Publish a Techdocs Site

Preface

This how-to will take you through the steps of building and publishing a techdocs site for inclusion in the developer portal catalog. In order to do this we must build the site and push it to a S3 compatible object store.

Setup & Configure Mkdocs

To begin, follow the getting started guide for Mkdocs. You should include techdocs-core in plugins list and subsequently mkdocs-techdocs-core in your python requirements definition.

Warning

Beware, techdocs-core overrides various mkdocs configuration options including theme.

Example

site_name: Developer Portal
site_url: https://0.0.0.0/
repo_url: https://github.com/DiamondLightSource/developer-portal
edit_uri: edit/main/docs/
plugins:
  - techdocs-core

Build Docs

We will use the Techdocs command line interface node package to build our docs site locally. To do this we will run:

npx @techdocs/cli generate --no-docker

At this point you should see a site directory, the contents of which can be viewed in your browser.

Publish Docs

We will use the Techdocs command line interface node package to publish our docs site to the S3 bucket.

In order to do this we will require the necessary credentials for the bucket. The necessary credentials should be made available as the environment variables AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY. These credentials are made available in GitHub Workflows in the DiamondLightSource organisation as TECHDOCS_S3_ACCESS_KEY_ID and TECHDOCS_S3_SECRET_ACCESS_KEY respectively or can be attained by contacting the owner of developer-portal-techdocs-bucket. Further to this, the AWS_REGION environment variable should be set to a valid region code, e.g. eu-west-2.

We will now run:

npx @techdocs/cli publish --entity <NAMESPACE/KIND/NAME> --publisher-type awsS3 --storage-name techdocs --awsEndpoint https://s3.echo.stfc.ac.uk --awsS3ForcePathStyle

Example GitHub Workflow

name: Docs CI

on:
  push:
    - main

jobs:
  publish_techdocs:
    runs-on: ubuntu-latest
    steps:
    - name: Checkout
      uses: actions/checkout@v3
      with:
      fetch-depth: 0

    - name: Setup python
      uses: actions/setup-python@v4
      with:
      python-version: 3.11

    - name: Install docs dependencies
      run: pip install -r docs-requirements.txt

    - name: Set node
      uses: actions/setup-node@v3
      with:
      node-version: 18.x

    - name: Generate docs
      run: npx @techdocs/cli generate --no-docker

    - name: Publish docs to s3 bucket
      run: >
        npx @techdocs/cli publish
        --entity default/component/developer-portal-backend
        --publisher-type awsS3
        --storage-name techdocs
        --awsEndpoint https://s3.echo.stfc.ac.uk
        --awsS3ForcePathStyle
      env:
        AWS_ACCESS_KEY_ID: ${{ secrets.TECHDOCS_S3_ACCESS_KEY_ID }}
        AWS_SECRET_ACCESS_KEY: ${{ secrets.TECHDOCS_S3_SECRET_ACCESS_KEY }}
        AWS_REGION: "eu-west-2"

Example GitLab Workflow

image: node:18-bullseye

variables:
  GIT_SUBMODULE_STRATEGY: recursive

stages:
  - publish_techdocs

before_script:
  - apt-get update
  - apt-get install -y --no-install-recommends python3-pip
  - pip install -r requirements.txt

publish_techdocs:
  stage: publish_techdocs
  rules:
    - if: $CI_COMMIT_REF_NAME == "main"
  tags:
    - argus
  script:
    - npx @techdocs/cli generate --no-docker
    - >
      npx @techdocs/cli publish
      --entity default/component/developer-guide
      --publisher-type awsS3
      --storage-name techdocs
      --awsEndpoint https://s3.echo.stfc.ac.uk
      --awsS3ForcePathStyle
  variables:
    AWS_REGION: "eu-west-2"

Annotate Entity

Finally, we will add the backstage.io/techdocs-ref annotation to the metadata.annotations field of the entity descriptor. This should point to the root directory of the documentation (i.e. the directory containing the mkdocs.yaml file).

Example Entity Descriptor

apiVersion: backstage.io/v1alpha1
kind: Component
metadata:
  name: developer-guide
  annotations:
    backstage.io/techdocs-ref: dir:.
spec:
  type: website
  lifecycle: experimental
  owner: user:enu43627