# Simple workflow for deploying static content to GitHub Pages name: Publish Docs to GH Pages on: release: types: [ created ] # Allows you to run this workflow manually from the Actions tab workflow_dispatch: # Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages permissions: contents: read pages: write id-token: write packages: write # Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued. # However, do NOT cancel in-progress runs as we want to allow these production deployments to complete. concurrency: group: "pages" cancel-in-progress: false jobs: # Single deploy job since we're just deploying deploy: runs-on: ubuntu-latest environment: name: github-pages url: ${{ steps.deployment.outputs.page_url }} steps: - uses: actions/checkout@v5 - name: Set up JDK 21 uses: actions/setup-java@v5 with: java-version: '21' distribution: 'oracle' server-id: github # Value of the distributionManagement/repository/id field of the pom.xml settings-path: ${{ github.workspace }} # location for the settings.xml file - uses: actions/checkout@v5 - name: Use Node.js uses: actions/setup-node@v6 with: node-version: '20.x' - run: cd docs && npm ci - run: cd docs && npm run build - name: Find and Replace uses: jacobtomlinson/gha-find-replace@v3 with: find: "ollama4j-revision" replace: ${{ github.ref_name }} regex: false - name: Build with Maven run: mvn --file pom.xml -U clean package -Dgpg.skip=true -DskipTests && cp -r ./target/apidocs/. ./docs/build/apidocs - name: Doxygen Action uses: mattnotmitt/doxygen-action@v1.12.0 with: doxyfile-path: "./Doxyfile" working-directory: "." - name: Setup Pages uses: actions/configure-pages@v5 - name: Upload artifact uses: actions/upload-pages-artifact@v4 with: # Upload entire repository path: './docs/build/.' - name: Deploy to GitHub Pages id: deployment uses: actions/deploy-pages@v4