on: push: branches: - main pull_request: release: types: [published] jobs: build: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - uses: actions/setup-node@v4 with: node-version: 18 cache: npm - run: npm ci - run: npm run build publish: runs-on: ubuntu-latest if: github.event_name == 'release' environment: release needs: build permissions: contents: read id-token: write steps: - uses: actions/checkout@v4 - uses: actions/setup-node@v4 with: node-version: 18 cache: npm registry-url: 'https://registry.npmjs.org' - run: npm ci # TODO: Add --provenance once the repo is public - run: npm publish --access public env: NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}