Skip to content

Publish documentation #25

Publish documentation

Publish documentation #25

name: Publish documentation
on:
workflow_dispatch:
inputs:
documentation_tag:
type: string
required: false
default: "latest"
description: "Label of the documentation"
publish_to_prod:
type: boolean
default: true
publish_to_dev:
type: boolean
default: true
workflow_call:
inputs:
documentation_tag:
type: string
required: true
default: "latest"
publish_to_prod:
type: boolean
default: true
publish_to_dev:
type: boolean
default: true
jobs:
Publish_Documentation:
env:
ARCHIVE: "sidewalk_${{inputs.documentation_tag}}.zip"
runs-on: ubuntu-latest
container:
image: ghcr.io/nrfconnect/sdk-sidewalk:main
options: --cpus 2
defaults:
run:
shell: nrfutil toolchain-manager launch --install-dir /root/ncs bash -- {0}
steps:
- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0
path: sidewalk
- name: Build documentation
run: |
cd sidewalk/doc
./build_local.sh
cp custom.properties build/html
sed -i 's/__VERSION__/'"${{inputs.documentation_tag}}"'/g' build/html/custom.properties
cp tags.yml build/html
sed -i 's/__VERSION__/'"${{inputs.documentation_tag}}"'/g' build/html/tags.yml
cd build/html
zip -rq "${{env.ARCHIVE}}" .
mv "${{env.ARCHIVE}}" /workdir/${{env.ARCHIVE}}
ls -lah /workdir
- name: Upload build artifacts
uses: actions/upload-artifact@v4
with:
name: documentation
path: |
/workdir/${{env.ARCHIVE}}
- name: Prepare Key
run: |
mkdir -p /root/.ssh
ssh-keyscan upload-v1.zoominsoftware.io >> /root/.ssh/known_hosts
echo "${{ secrets.NCS_ZOOMIN_KEY }}" > zoomin_key
chmod 600 zoomin_key
- name: Publish documentation - dev
if: ${{inputs.publish_to_dev}}
run: |
sftp -v -i zoomin_key ${{ vars.NCS_ZOOMIN_SERVER }} <<EOF
cd ${{ vars.NCS_ZOOMIN_DEPLOY_DEV_PATH}}
put /workdir/${{env.ARCHIVE}}
EOF
- name: Publish documentation - prod
if: ${{inputs.publish_to_prod}}
run: |
sftp -v -i zoomin_key ${{ vars.NCS_ZOOMIN_SERVER }} <<EOF
cd ${{ vars.NCS_ZOOMIN_DEPLOY_PROD_PATH}}
put /workdir/${{env.ARCHIVE}}
EOF