Skip to content

πŸ”– Release package #32

πŸ”– Release package

πŸ”– Release package #32

Workflow file for this run

name: πŸ”– Release package
on:
workflow_dispatch:
inputs:
version:
description: "Version number (e.g. 1.0.0)"
required: true
env:
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
jobs:
release:
runs-on: ubuntu-22.04
permissions:
contents: write
id-token: write
strategy:
matrix:
node-version: [20]
steps:
- uses: actions/checkout@v4
- name: Install pnpm
uses: pnpm/action-setup@v3
with:
version: 9
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node-version }}
cache: "pnpm"
- name: Install dependencies
run: pnpm install
# Configure Git
- name: Git configuration
run: |
git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com"
git config --global user.name "GitHub Actions"
# Bump package version
# Use tag latest
- name: Bump release version
run: |
echo "NEW_VERSION=$(npm --no-git-tag-version version $RELEASE_TYPE)" >> $GITHUB_ENV
echo "RELEASE_TAG=latest" >> $GITHUB_ENV
env:
RELEASE_TYPE: "v${{ github.event.inputs.version }}"
# Commit changes
- name: Commit package.json changes and create tag
run: |
git add "package.json"
git commit -m "πŸ”– release ${{ env.NEW_VERSION }}"
git tag ${{ env.NEW_VERSION }}
# Configure npm registry
- name: configure registry
run: pnpm config set '//registry.npmjs.org/:_authToken' "${NPM_TOKEN}"
# Publish version to public repository
- name: Publish
run: pnpm publish --verbose --access public --tag ${{ env.RELEASE_TAG }}
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
# Push repository changes
- name: Push changes to repository
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
git push origin && git push --tags
# Update GitHub release with changelog
- name: Update GitHub release documentation
uses: softprops/action-gh-release@v1
with:
tag_name: ${{ env.NEW_VERSION }}
generate_release_notes: true
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}