Skip to content

Update GitHub Actions to handle existing tags and permissions #12

Update GitHub Actions to handle existing tags and permissions

Update GitHub Actions to handle existing tags and permissions #12

Workflow file for this run

name: Publish to npm
on:
push:
tags:
- 'v*.*.*'
jobs:
publish:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Use Node.js
uses: actions/setup-node@v3
with:
node-version: 'lts/*'
- name: Install dependencies
run: yarn install
- name: Build the package
run: yarn build
- name: Configure Git
run: |
git config --local user.email "sarmaged@gmail.com"
git config --local user.name "Sarmaged"
- name: Delete existing tag
run: |
git tag -d ${GITHUB_REF#refs/tags/} || true
git push origin :refs/tags/${GITHUB_REF#refs/tags/} || true
- name: Bump version and publish to npm
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
run: |
yarn version --new-version ${GITHUB_REF#refs/tags/v}
echo "//registry.npmjs.org/:_authToken=${NODE_AUTH_TOKEN}" > .npmrc
yarn publish --new-version ${GITHUB_REF#refs/tags/v}
- name: Push changes back to GitHub
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
git push --follow-tags
- name: Create GitHub Release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: ${{ github.ref }}
release_name: Release ${{ github.ref }}
body: |
## Changes
- Describe your changes here
draft: false
prerelease: false