mirror of
https://github.com/Xahau/xahau.js.git
synced 2026-06-03 08:46:40 +00:00
Add npm trusted publishing workflow
Add GitHub Actions workflow for npm trusted publishing via OIDC. The workflow validates package version bumps on PRs with npm publish dry-runs, publishes changed workspace packages from main-xahau, and creates matching GitHub releases. Shared npm publish logic is implemented as a local composite action used by both dry-run and publish jobs.
This commit is contained in:
87
.github/workflows/npm-publish.yml
vendored
Normal file
87
.github/workflows/npm-publish.yml
vendored
Normal file
@@ -0,0 +1,87 @@
|
||||
name: Publish npm packages
|
||||
|
||||
on:
|
||||
pull_request:
|
||||
branches: [main-xahau]
|
||||
paths:
|
||||
- packages/xahau/package.json
|
||||
- packages/xahau-address-codec/package.json
|
||||
- packages/xahau-binary-codec/package.json
|
||||
- packages/xahau-keypairs/package.json
|
||||
push:
|
||||
branches: [main-xahau]
|
||||
paths:
|
||||
- packages/xahau/package.json
|
||||
- packages/xahau-address-codec/package.json
|
||||
- packages/xahau-binary-codec/package.json
|
||||
- packages/xahau-keypairs/package.json
|
||||
|
||||
concurrency:
|
||||
group: npm-publish-${{ github.ref }}
|
||||
cancel-in-progress: false
|
||||
|
||||
jobs:
|
||||
dry-run:
|
||||
name: Dry-run ${{ matrix.package.name }}
|
||||
if: github.event_name == 'pull_request'
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
contents: read
|
||||
strategy:
|
||||
fail-fast: false
|
||||
matrix:
|
||||
package:
|
||||
- name: xahau-address-codec
|
||||
path: packages/xahau-address-codec
|
||||
- name: xahau-binary-codec
|
||||
path: packages/xahau-binary-codec
|
||||
- name: xahau-keypairs
|
||||
path: packages/xahau-keypairs
|
||||
- name: xahau
|
||||
path: packages/xahau
|
||||
steps:
|
||||
- uses: actions/checkout@v6
|
||||
with:
|
||||
fetch-depth: 0
|
||||
|
||||
- name: Fetch pull request base
|
||||
env:
|
||||
BASE_REF: ${{ github.base_ref }}
|
||||
run: git fetch --no-tags --depth=1 origin "$BASE_REF"
|
||||
|
||||
- uses: ./.github/actions/npm-publish-package
|
||||
with:
|
||||
package-path: ${{ matrix.package.path }}
|
||||
base-ref: origin/${{ github.base_ref }}
|
||||
dry-run: "true"
|
||||
|
||||
publish:
|
||||
name: Publish ${{ matrix.package.name }}
|
||||
if: github.event_name == 'push' && github.ref == 'refs/heads/main-xahau'
|
||||
runs-on: ubuntu-latest
|
||||
environment: npm
|
||||
permissions:
|
||||
contents: write
|
||||
id-token: write
|
||||
strategy:
|
||||
fail-fast: false
|
||||
matrix:
|
||||
package:
|
||||
- name: xahau-address-codec
|
||||
path: packages/xahau-address-codec
|
||||
- name: xahau-binary-codec
|
||||
path: packages/xahau-binary-codec
|
||||
- name: xahau-keypairs
|
||||
path: packages/xahau-keypairs
|
||||
- name: xahau
|
||||
path: packages/xahau
|
||||
steps:
|
||||
- uses: actions/checkout@v6
|
||||
with:
|
||||
fetch-depth: 0
|
||||
|
||||
- uses: ./.github/actions/npm-publish-package
|
||||
with:
|
||||
package-path: ${{ matrix.package.path }}
|
||||
base-ref: ${{ github.event.before }}
|
||||
target-commitish: ${{ github.sha }}
|
||||
18
.github/workflows/scripts/check-npm-version-unpublished.sh
vendored
Normal file
18
.github/workflows/scripts/check-npm-version-unpublished.sh
vendored
Normal file
@@ -0,0 +1,18 @@
|
||||
#!/usr/bin/env bash
|
||||
set -euo pipefail
|
||||
|
||||
package_spec="$1"
|
||||
stderr_file="$(mktemp)"
|
||||
|
||||
if npm view "$package_spec" version --registry "https://registry.npmjs.org" 2>"$stderr_file"; then
|
||||
echo "$package_spec is already published." >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if grep -Eq "E404|404 Not Found|is not in this registry" "$stderr_file"; then
|
||||
echo "$package_spec is not published yet."
|
||||
exit 0
|
||||
fi
|
||||
|
||||
cat "$stderr_file" >&2
|
||||
exit 1
|
||||
23
.github/workflows/scripts/check-package-version-changed.sh
vendored
Normal file
23
.github/workflows/scripts/check-package-version-changed.sh
vendored
Normal file
@@ -0,0 +1,23 @@
|
||||
#!/usr/bin/env bash
|
||||
set -euo pipefail
|
||||
|
||||
package_path="$1"
|
||||
package_file="$package_path/package.json"
|
||||
current_version="$(jq -r .version "$package_file")"
|
||||
changed="false"
|
||||
|
||||
if [[ -z "${BASE_REF:-}" || "${BASE_REF:-}" =~ ^0+$ ]]; then
|
||||
BASE_REF="HEAD^"
|
||||
fi
|
||||
|
||||
if previous_package="$(git show "$BASE_REF:$package_file" 2>/dev/null)"; then
|
||||
previous_version="$(jq -r .version <<<"$previous_package")"
|
||||
if [[ "$current_version" != "$previous_version" ]]; then
|
||||
changed="true"
|
||||
fi
|
||||
else
|
||||
changed="true"
|
||||
fi
|
||||
|
||||
echo "changed=$changed" >> "$GITHUB_OUTPUT"
|
||||
echo "$package_path version changed: $changed"
|
||||
11
.github/workflows/scripts/read-package-metadata.sh
vendored
Normal file
11
.github/workflows/scripts/read-package-metadata.sh
vendored
Normal file
@@ -0,0 +1,11 @@
|
||||
#!/usr/bin/env bash
|
||||
set -euo pipefail
|
||||
|
||||
package_path="$1"
|
||||
package_file="$package_path/package.json"
|
||||
name="$(jq -r .name "$package_file")"
|
||||
version="$(jq -r .version "$package_file")"
|
||||
|
||||
echo "name=$name" >> "$GITHUB_OUTPUT"
|
||||
echo "version=$version" >> "$GITHUB_OUTPUT"
|
||||
echo "tag=$name@$version" >> "$GITHUB_OUTPUT"
|
||||
Reference in New Issue
Block a user