Skip to content
Merged
84 changes: 84 additions & 0 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,84 @@
name: Manual Release

on:
workflow_dispatch:
inputs:
bump:
description: 'Version bump type (used if release_version is empty)'
type: choice
options:
- major
- minor
- patch
- prerelease
required: false
release_version:
description: 'Semver version to release (must be > current root version)'
required: false

permissions:
contents: write
pull-requests: write
id-token: write
packages: write

jobs:
release:
# Allow only on master, spring*, summer*, winter*;
if: ${{ github.repository_owner == 'salesforce' && (github.ref_name == 'master' || startsWith(github.ref_name, 'spring') || startsWith(github.ref_name, 'summer') || startsWith(github.ref_name, 'winter')) }}
environment: release
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0

- name: Setup Node
uses: actions/setup-node@v4
with:
node-version: '20'
registry-url: 'https://registry.npmjs.org'
cache: 'yarn'

- name: Install dependencies
run: yarn install --frozen-lockfile

- name: Resolve version input
id: resolve_version
run: |
RELEASE_VERSION='${{ inputs.release_version }}'
if [ -z "$RELEASE_VERSION" ]; then
RELEASE_VERSION='${{ inputs.bump }}'
fi
echo "resolved=$RELEASE_VERSION" >> "$GITHUB_OUTPUT"

- name: Bump versions and commit
env:
INPUT_VERSION: ${{ steps.resolve_version.outputs.resolved }}
run: |
git config user.name "github-actions[bot]"
git config user.email "41898282+github-actions[bot]@users.noreply.github.com"
node ./scripts/release/version.js "$INPUT_VERSION"
RESOLVED_VERSION=$(jq -r .version package.json)
git commit -am "chore: release v$RESOLVED_VERSION"
git push origin HEAD

- name: Build
run: yarn build

- name: Tag and create GitHub release
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
VERSION=$(jq -r .version package.json)
git tag -a "v$VERSION" -m "Release v$VERSION"
git push origin tag "v$VERSION"
gh release create "v$VERSION" --title "v$VERSION" --generate-notes

- name: Publish to npm
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
run: |
TAG=$([ "$GITHUB_REF_NAME" = "master" ] && echo latest || echo "$GITHUB_REF_NAME")
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

How do we ensure that we only release using winter*/spring*/summer* tags, and we don't accidentally release a tag called rave/github-action-publish?

How do we ensure that only repo maintainers can trigger the workflow?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Added a conditional for branch validation.

How do we ensure that only repo maintainers can trigger the workflow?

This should help with only lwc-admin members should be able to approve workflow run requests.

yarn nx release publish --yes --registry https://registry.npmjs.org --tag "$TAG"
77 changes: 0 additions & 77 deletions .nucleus.yaml

This file was deleted.