Generate & deploy docs to GitHub Pages #9
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: Generate & deploy docs to GitHub Pages | |
on: | |
push: | |
tags: | |
- '*' | |
# To make it able to run manually, TODO remove when we're sure it's working | |
workflow_dispatch: | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
outputs: | |
last-tag: ${{ steps.last-tag.outputs.tag }} | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
- name: Set up JDK 17 | |
uses: actions/setup-java@v3 | |
with: | |
distribution: temurin | |
java-version: 17 | |
- name: Setup Gradle | |
uses: gradle/gradle-build-action@v2 | |
# Setting up pages and generating the docs | |
- name: Setup Pages | |
id: pages | |
uses: actions/configure-pages@v4 | |
- name: 'Get Previous tag' | |
id: last-tag | |
uses: "WyriHaximus/github-action-get-previous-tag@v1" | |
- name: Generate API documentation | |
run: | | |
./gradlew -PdocVersion=${{ steps.last-tag.outputs.tag }} dokkaHtml | |
# Uploading the generated files as build artifacts | |
- name: Upload artifact | |
uses: actions/upload-pages-artifact@v3 | |
with: | |
path: ./build/dokka/html | |
deploy: | |
needs: build | |
# Grant GITHUB_TOKEN the permissions required to make a Pages deployment | |
permissions: | |
pages: write | |
id-token: write # to verify the deployment originates from an appropriate source | |
outputs: | |
docs-url: ${{ steps.deployment.outputs.page_url }} | |
environment: | |
name: github-pages | |
url: ${{ steps.deployment.outputs.page_url }} | |
runs-on: ubuntu-latest | |
steps: | |
- name: Deploy to GitHub Pages | |
id: deployment | |
uses: actions/deploy-pages@v4 | |
notify: | |
needs: [ build, deploy ] | |
runs-on: ubuntu-latest | |
steps: | |
- name: Notify Slack | |
id: slack | |
uses: slackapi/[email protected] | |
env: | |
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }} | |
SLACK_WEBHOOK_TYPE: INCOMING_WEBHOOK | |
with: | |
payload: | | |
{ | |
"blocks": [ | |
{ | |
"type": "section", | |
"text": { | |
"type": "mrkdwn", | |
"text": "Hello Lovelies,\n Version `${{needs.build.outputs.last-tag}}` of *<${{github.server_url}}/${{github.repository}}|${{github.repository}}>* was released just now!" | |
} | |
}, | |
{ | |
"type": "divider" | |
}, | |
{ | |
"type": "actions", | |
"elements": [ | |
{ | |
"type": "button", | |
"text": { | |
"type": "plain_text", | |
"text": ":page_facing_up: Read the docs", | |
"emoji": true | |
}, | |
"url": "${{needs.deploy.outputs.docs-url}}" | |
}, | |
{ | |
"type": "button", | |
"text": { | |
"type": "plain_text", | |
"text": ":clipboard: Changelog", | |
"emoji": true | |
}, | |
"url": "${{github.server_url}}/${{github.repository}}/blob/master/CHANGES.md" | |
}, | |
{ | |
"type": "button", | |
"text": { | |
"type": "plain_text", | |
"text": ":package: Commits", | |
"emoji": true | |
}, | |
"url": "${{github.server_url}}/${{github.repository}}/commits/${{needs.build.outputs.last-tag}}" | |
} | |
] | |
} | |
] | |
} |