name: Publish
on:
push:
tags:
- 'v*.*.*'
paths-ignore:
- '**.md'
- '**.txt'
- 'docs/**'
- 'LICENSE'
- '.gitignore'
workflow_dispatch: {}
permissions:
contents: read
jobs:
# Read package metadata once so multiple jobs can reuse it
get-package-meta:
runs-on: ubuntu-latest
outputs:
pkg_name: ${{ steps.read.outputs.pkg_name }}
pkg_version: ${{ steps.read.outputs.pkg_version }}
steps:
- name: Checkout
uses: actions/checkout@v5
- name: Read package.json
id: read
run: |
echo "Reading package.json"
PKG_NAME=$(jq -r .name package.json)
PKG_VERSION=$(jq -r .version package.json)
echo "pkg_name=$PKG_NAME" >> $GITHUB_OUTPUT
echo "pkg_version=$PKG_VERSION" >> $GITHUB_OUTPUT
test:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v5
- name: Setup Node.js
uses: actions/setup-node@v5
with:
node-version: '24.9.0'
registry-url: 'https://registry.npmjs.org'
- name: Install dependencies
run: npm install
- name: Run tests
run: npm test
# NPM publish job: run only for semver-like tags (vX.Y.Z or other tags containing a dot)
publish-npm:
needs:
- get-package-meta
- test
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v5
- name: Setup Node.js
uses: actions/setup-node@v5
with:
node-version: '24.9.0'
registry-url: 'https://registry.npmjs.org'
- name: Install dependencies
run: npm install
- name: Build
run: npm run build
- name: Publish package
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
PKG_NAME: ${{ needs.get-package-meta.outputs.pkg_name }}
PKG_VERSION: ${{ needs.get-package-meta.outputs.pkg_version }}
run: |
echo "Publishing package to npm..."
if [[ "$PKG_VERSION" == *"snapshot"* ]]; then
SNAP_VERSION="${PKG_VERSION}.${{ github.sha }}"
echo "Detected snapshot version, final publish version: $SNAP_VERSION"
npm version --no-git-tag-version "$SNAP_VERSION"
npm publish --tag snapshot --access public
else
npm publish --access public
echo "Tagging published package as 'latest'"
echo "Adding dist-tag: $PKG_NAME@$PKG_VERSION -> latest"
npm dist-tag add "$PKG_NAME@$PKG_VERSION" latest
fi
# Docker: build-and-push on any v* tag (includes vX or vX.Y.Z)
publish-docker:
needs:
- get-package-meta
- test
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v5
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3.11.1
- name: Log in to Docker Hub
uses: docker/login-action@v3.6.0
with:
username: "kanghouchao"
password: ${{ secrets.DOCKER_HUB_TOKEN }}
- name: Compute docker tags
id: docker_tags
run: |
VERSION=${{ needs.get-package-meta.outputs.pkg_version }}
echo "Generating tags for VERSION=$VERSION"
echo "tag_lines<<EOF" >> $GITHUB_OUTPUT
echo "type=raw,value=$VERSION" >> $GITHUB_OUTPUT
if [[ "$VERSION" != *"snapshot"* ]]; then
echo "type=raw,value=latest" >> $GITHUB_OUTPUT
fi
echo "EOF" >> $GITHUB_OUTPUT
- name: Extract metadata
id: meta
uses: docker/metadata-action@v5.8.0
with:
images: kanghouchao/band-mcp-server
tags: |
${{ steps.docker_tags.outputs.tag_lines }}
- name: Build and push Docker image
uses: docker/build-push-action@v6.18.0
with:
context: .
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
platforms: linux/amd64,linux/arm64
cache-from: type=gha
cache-to: type=gha,mode=max
target: production