Skip to content

v2.12.0

v2.12.0 #50

Workflow file for this run

name: Release
on:
release:
types:
- released
permissions: {}
jobs:
release:
name: Version & Publish
permissions:
contents: write
pull-requests: write
id-token: write
runs-on: ubuntu-latest
steps:
- name: Check out repo
uses: actions/checkout@v3
with:
fetch-depth: 0
- name: Set up Node.js 20.x
uses: actions/setup-node@v3
with:
node-version: 20.x
registry-url: 'https://registry.npmjs.org'
- name: Install dependencies
run: yarn install --frozen-lockfile
- name: Create Release Branch
run: |
git config user.name github-actions[bot]
git config user.email 41898282+github-actions[bot]@users.noreply.github.com
git checkout -b release
git push --force origin release --set-upstream
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Version Package
run: npm version ${{ github.event.release.tag_name }} --git-tag-version=false
- name: Push package.json and tags
run: |
sha=$(gh api --method PUT /repos/:owner/:repo/contents/$FILE_TO_COMMIT \
-f message="Release ${{ github.event.release.tag_name }}" \
-f content="$( base64 -i $FILE_TO_COMMIT )" \
-f encoding="base64" \
-f branch="$DESTINATION_BRANCH" \
-f sha="$( git rev-parse $DESTINATION_BRANCH:$FILE_TO_COMMIT )" --jq '.commit.sha')
gh api --method PATCH /repos/:owner/:repo/git/refs/tags/${{ github.event.release.tag_name }} \
-f sha="$sha" -F force=true
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
FILE_TO_COMMIT: package.json
DESTINATION_BRANCH: release
- name: Raise Release PR
run: |
gh pr create -H release -B master --title "Release ${{ github.event.release.tag_name }}" --body "Please merge this with a Merge Request to update master<br><br>[${{ github.event.release.tag_name }}](${{ github.event.release.html_url }})<br><br>${{ github.event.release.body }}" -l "chore"
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Publish to npm
run: yarn build && npm publish --provenance
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}