name: Release Automation
on:
push:
tags:
- 'v*.*.*'
jobs:
release:
runs-on: ubuntu-latest
permissions:
contents: write
id-token: write
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: '20'
registry-url: 'https://registry.npmjs.org'
cache: 'npm'
- name: Install dependencies
run: npm ci
- name: Build
run: npm run build
- name: Run linter
run: npm run lint
- name: Type check
run: npm run type-check
- name: Extract version from tag
id: extract_version
run: echo "VERSION=${GITHUB_REF#refs/tags/v}" >> $GITHUB_OUTPUT
- name: Verify version matches package.json
run: |
PACKAGE_VERSION=$(node -p "require('./package.json').version")
if [ "$PACKAGE_VERSION" != "${{ steps.extract_version.outputs.VERSION }}" ]; then
echo "Error: package.json version ($PACKAGE_VERSION) doesn't match tag (${{ steps.extract_version.outputs.VERSION }})"
exit 1
fi
- name: Update server.json version
run: |
node -e "
const fs = require('fs');
const server = JSON.parse(fs.readFileSync('server.json', 'utf8'));
server.version = '${{ steps.extract_version.outputs.VERSION }}';
server.packages[0].version = '${{ steps.extract_version.outputs.VERSION }}';
fs.writeFileSync('server.json', JSON.stringify(server, null, 2) + '\n');
"
- name: Publish to npm
run: npm publish --access public --provenance
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
- name: Create GitHub Release
uses: softprops/action-gh-release@v2
with:
generate_release_notes: true
files: |
dist/**/*
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Update MCP Registry
run: |
curl -X POST https://registry.modelcontextprotocol.io/api/submit \
-H "Content-Type: application/json" \
-d @server.json || echo "MCP Registry update queued"
continue-on-error: true