Skip to content

release

release #114

Workflow file for this run

name: release
on:
release:
types: [created]
workflow_dispatch:
jobs:
deploy-npm-module:
runs-on: ubuntu-latest
outputs:
VERSION: ${{ steps.set-project.outputs.version }}
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: '18.x'
registry-url: 'https://registry.npmjs.org'
- name: Check released tag matches ALICE O2 naming pattern
run: |
if ! [[ $GITHUB_REF =~ @aliceo2\/[a-z]+-*[a-z]*@*.* ]]; then
echo "TAG: ${GITHUB_REF} does not match expected pattern";
exit 1;
else
echo "TAG is correct"
fi
- name: Set variables PROJECT and VERSION for what is being released
id: set-project
run: |
VERSION=$( echo "${GITHUB_REF/refs\/tags\/@aliceo2\/}" | cut -f2 -d"@")
PROJECT="Bookkeeping"
echo "Identified project: $PROJECT with version: $VERSION"
echo "version=$VERSION" >> $GITHUB_OUTPUT
echo "PROJECT=$PROJECT" >> $GITHUB_ENV
- run: npm publish
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_DEPLOY_TOKEN }}
upload-asset:
runs-on: ubuntu-latest
needs: deploy-npm-module
outputs:
ASSET_URL: ${{ steps.upload.outputs.asset_url }}
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: '18.x'
registry-url: 'https://registry.npmjs.org'
- name: Install production dependencies
run: npm install --only=production
- name: Create package tarball
run: echo "tgz_name=$(npm pack)" >> $GITHUB_OUTPUT
id: tgz
- name: Upload tarball to release assets via GH CLI
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: gh release upload @aliceo2/bookkeeping@${{ needs.deploy-npm-module.outputs.VERSION }} ${{ steps.tgz.outputs.tgz_name }}
- name: Upload TARball to S3
uses: awegrzyn/s3-put-action@v1
with:
file: ./${{ steps.tgz.outputs.tgz_name }}
bucket: 's3://system-configuration/TARS/'
env:
ACCESS_KEY: ${{ secrets.S3_ACCESS_KEY }}
SECRET_KEY: ${{ secrets.S3_SECRET_KEY }}