cap_access 0.3.0

Provide basic capability-based access control to objects
Documentation
name: Deploy

on:
  push:
    branches: [ main ]
  pull_request:
    branches: [ main ]

permissions:
  contents: read
  pages: write
  id-token: write

concurrency:
  group: 'pages'
  cancel-in-progress: false

jobs:
  check:
    uses: ./.github/workflows/check.yml

  test:
    uses: ./.github/workflows/test.yml

  build-doc:
    name: Build documentation
    runs-on: ubuntu-latest
    needs: [check, test]
    env:
      RUSTDOCFLAGS: "-D rustdoc::broken_intra_doc_links -D missing-docs"
    steps:
      - name: Checkout code
        uses: actions/checkout@v4

      - name: Install Rust toolchain
        uses: dtolnay/rust-toolchain@nightly

      - name: Build docs
        run: cargo doc --no-deps --all-features

      - name: Create index redirect
        run: |
          printf '<meta http-equiv="refresh" content="0;url=cap_access/index.html">' > target/doc/index.html

      - name: Upload artifact
        uses: actions/upload-pages-artifact@v3
        with:
          path: target/doc

  deploy-doc:
    name: Deploy to GitHub Pages
    environment:
      name: github-pages
      url: ${{ steps.deployment.outputs.page_url }}
    runs-on: ubuntu-latest
    needs: build-doc
    if: github.ref == format('refs/heads/{0}', github.event.repository.default_branch)
    steps:
      - name: Deploy to GitHub Pages
        id: deployment
        uses: actions/deploy-pages@v4