Skip to content

ci: use GH_PACKAGES_TOKEN fallback for publish workflows (#16) #8

ci: use GH_PACKAGES_TOKEN fallback for publish workflows (#16)

ci: use GH_PACKAGES_TOKEN fallback for publish workflows (#16) #8

Workflow file for this run

name: Release
on:
push:
branches: [main]
concurrency:
group: release-${{ github.ref }}
cancel-in-progress: true
permissions:
contents: write
packages: write
jobs:
release:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Setup Bun
uses: oven-sh/setup-bun@v2
with:
bun-version: 1.2.22
- name: Install dependencies
run: bun install --frozen-lockfile
- name: Build
run: bun run build
- name: Detect pending changesets
id: changesets
run: |
COUNT=$(find .changeset -maxdepth 1 -name '*.md' ! -name 'README.md' | wc -l | tr -d ' ')
echo "count=$COUNT" >> "$GITHUB_OUTPUT"
if [ "$COUNT" -eq 0 ]; then
echo "No pending changesets found. Skipping publish."
fi
- name: Version packages from changesets
if: steps.changesets.outputs.count != '0'
env:
GITHUB_TOKEN: ${{ secrets.GH_PACKAGES_TOKEN || secrets.GITHUB_TOKEN }}
run: bun run changeset:version
- name: Commit version updates to main
if: steps.changesets.outputs.count != '0'
run: |
git config user.name "github-actions[bot]"
git config user.email "41898282+github-actions[bot]@users.noreply.github.com"
git add -A
git commit -m "chore(release): version packages [skip ci]" || exit 0
git push
- name: Configure npm auth for GitHub Packages
if: steps.changesets.outputs.count != '0'
env:
NODE_AUTH_TOKEN: ${{ secrets.GH_PACKAGES_TOKEN || secrets.GITHUB_TOKEN }}
run: |
echo "@dotgithub:registry=https://npm.pkg.github.com" >> ~/.npmrc
echo "//npm.pkg.github.com/:_authToken=${NODE_AUTH_TOKEN}" >> ~/.npmrc
- name: Publish packages
if: steps.changesets.outputs.count != '0'
env:
GITHUB_TOKEN: ${{ secrets.GH_PACKAGES_TOKEN || secrets.GITHUB_TOKEN }}
NODE_AUTH_TOKEN: ${{ secrets.GH_PACKAGES_TOKEN || secrets.GITHUB_TOKEN }}
run: bun run changeset:publish