Skip to content

Release

Release #2

Workflow file for this run

name: Release
on:
release:
types: [published]
permissions:
contents: read
jobs:
version:
runs-on: ubuntu-latest
outputs:
result: ${{ steps.version.outputs.result }}
steps:
- id: version
uses: actions/github-script@d7906e4ad0b1822421a7e6a35d5ca353c962f410 # v6.4.1
with:
script: |
const tag = "${{ github.event.release.tag_name }}";
const semver = tag.replace('v', '');
if (semver.match(/^[0-9]+\.[0-9]+\.[0-9]+$/)) {
return semver
}
throw new Error('not semver, ref: ${context.ref}')
result-encoding: string
npm:
name: Release NPM
runs-on: ubuntu-latest
needs: version
environment: NPM Packages
permissions:
contents: read
id-token: write
steps:
- uses: actions/checkout@8ade135a41bc03ea155e62e844d188df1ea18608 # v4.1.0
- uses: actions/setup-node@5e21ff4d9bc1a8cf6de233a3057d20ec6b3fb69d # v3.8.1
with:
node-version-file: '.nvmrc'
- run: corepack enable pnpm
- run: pnpm install --frozen-lockfile
- run: pnpm -r exec pnpm version ${{ needs.Version.outputs.result }} --git-tag-version=false
- run: pnpm turbo run build
- run: npm config set "//registry.npmjs.org/:_authToken" "\${NPM_PACKAGES_TOKEN}" --location=global
- run: pnpm -r publish --access public --tag latest --no-git-checks
env:
NPM_PACKAGES_TOKEN: ${{ secrets.NPM_PACKAGES_TOKEN }}
NPM_CONFIG_PROVENANCE: true
- run: npm config delete "//registry.npmjs.org/:_authToken" --location=global
if: always()