Files
common/npm/npm-push/action.yaml
2026-01-05 10:02:50 -08:00

64 lines
2.0 KiB
YAML

name: npm-push
description: "Publish an NPM package to a registry."
inputs:
tgz:
description: "Path to the tarball file to publish."
required: true
registry:
description: "NPM registry URL."
required: false
default: ${{ github.server_url }}/api/packages/${{ github.repository_owner }}/npm/
apiKey:
description: "NPM authentication token."
required: true
nodeVersion:
description: "Node.js version to use."
required: false
default: "20"
access:
description: "Package access level: public or restricted."
required: false
default: "public"
runs:
using: "composite"
steps:
- name: "Setup Node.js"
uses: https://github.com/actions/setup-node@v4
with:
node-version: ${{ inputs.nodeVersion }}
- name: "Publish package"
run: |
# Ensure path starts with ./ so npm recognizes it as a file path
TGZ_PATH="${{ inputs.tgz }}"
# Trim whitespace
TGZ_PATH=$(echo "$TGZ_PATH" | xargs)
echo "Original path: '${{ inputs.tgz }}'"
echo "Trimmed path: '$TGZ_PATH'"
echo "First character: '${TGZ_PATH:0:1}'"
if [[ ! "$TGZ_PATH" =~ ^[./~] ]]; then
echo "Path does not start with . / or ~, adding ./ prefix"
TGZ_PATH="./$TGZ_PATH"
else
echo "Path already starts with . / or ~, no prefix needed"
fi
echo "Final path: '$TGZ_PATH'"
# Configure npm authentication for the registry (scoped to project)
REGISTRY_PATH=$(echo "${{ inputs.registry }}" | sed -E 's|https?://||')
npm config set --location=project registry "${{ inputs.registry }}"
npm config set --location=project "//${REGISTRY_PATH}:_apiKey" "${{ inputs.apiKey }}"
echo "Publishing $TGZ_PATH to ${{ inputs.registry }}"
npm publish --location=project "$TGZ_PATH" --access ${{ inputs.access }}
echo "Package published successfully"
shell: bash
- name: "Clean up npm authentication"
if: always()
run: |
# Clean up project .npmrc in case of early exit
rm -f .npmrc
shell: bash