mirror of
https://github.com/ChainSafe/lodestar.git
synced 2026-01-09 15:48:08 -05:00
**Motivation** Use more secure way publish a release. **Description** - Use `npm` [trusted publishing](https://docs.npmjs.com/trusted-publishers) --------- Co-authored-by: Matthew Keil <me@matthewkeil.com>
151 lines
5.7 KiB
YAML
151 lines
5.7 KiB
YAML
name: Publish dev release
|
|
|
|
# only one per github sha can be run
|
|
concurrency:
|
|
group: cd-publish-dev
|
|
|
|
on:
|
|
workflow_call:
|
|
|
|
permissions:
|
|
contents: write # Required for OIDC
|
|
id-token: write # Required to create a Github release
|
|
pull-requests: write # Required to add tags to pull requests
|
|
|
|
jobs:
|
|
npm:
|
|
name: Publish to NPM Registry
|
|
runs-on: buildjet-4vcpu-ubuntu-2204
|
|
steps:
|
|
# <common-build> - Uses YAML anchors in the future
|
|
- uses: actions/checkout@v6
|
|
with:
|
|
fetch-depth: 0
|
|
- uses: actions/setup-node@v4
|
|
with:
|
|
node-version: 24
|
|
registry-url: "https://registry.npmjs.org"
|
|
check-latest: true
|
|
cache: yarn
|
|
- name: Node.js version
|
|
id: node
|
|
run: echo "v8CppApiVersion=$(node --print "process.versions.modules")" >> $GITHUB_OUTPUT
|
|
- name: Restore dependencies
|
|
uses: actions/cache@v4
|
|
id: cache-deps
|
|
with:
|
|
path: |
|
|
node_modules
|
|
packages/*/node_modules
|
|
key: ${{ runner.os }}-${{ steps.node.outputs.v8CppApiVersion }}-${{ hashFiles('**/yarn.lock', '**/package.json') }}
|
|
- name: Install & build
|
|
if: steps.cache-deps.outputs.cache-hit != 'true'
|
|
run: yarn install --frozen-lockfile && yarn build
|
|
- name: Build
|
|
run: yarn build
|
|
if: steps.cache-deps.outputs.cache-hit == 'true'
|
|
# </common-build>
|
|
- name: Get version
|
|
id: version
|
|
run: |
|
|
PACKAGE_VERSION=$(node -p "require('./packages/cli/package.json').version")
|
|
NEXT_VERSION=$(npx --yes semver --increment minor $PACKAGE_VERSION)
|
|
export VERSION=${NEXT_VERSION}-dev.${GITHUB_SHA:0:10}
|
|
echo "version=$VERSION" >> $GITHUB_OUTPUT
|
|
echo PACKAGE_VERSION $PACKAGE_VERSION GITHUB_SHA $GITHUB_SHA VERSION $VERSION
|
|
|
|
- name: Change and commit version
|
|
# Write version before publishing so it's picked up by `lerna publish from-package`.
|
|
# It must also be committed to ensure a clean git tree, otherwise `lerna publish` errors.
|
|
# This "temp" commit doesn't change the actually release commit which is captured above.
|
|
# git-data is also correct, since it's generated at build time, before `lerna version` run.
|
|
run: |
|
|
yarn lerna version ${{ steps.version.outputs.version }} \
|
|
--force-publish \
|
|
--exact \
|
|
--yes \
|
|
--no-git-tag-version
|
|
|
|
git config user.name 'temp'
|
|
git config user.email 'temp@github.com'
|
|
git commit -am "${{ steps.version.outputs.version }}"
|
|
|
|
- name: Publish to npm registry
|
|
# Note: before https://github.com/ChainSafe/lodestar/commit/28e2c74cf0f1bede8b09c8c9fec26f54b367e3fd
|
|
# We used `lerna publish --canary` option. However, since we now publish must version on branches,
|
|
# i.e. v0.35.x branch, lerna fails to detect the latest version and publishes canary versions as
|
|
# `0.34.0-dev.173+28e2c74cf0` instead of `0.36.0-dev.4+28e2c74cf0`, which creates confusion.
|
|
#
|
|
# --no-git-reset:
|
|
# Do not delete code version artifacts so the next step can pick the version
|
|
#
|
|
# --dist-tag next:
|
|
# Make this dev version installable with `@next`
|
|
#
|
|
# --preid dev:
|
|
# Tag version with `dev` instead of `alpha`
|
|
#
|
|
# --force-publish:
|
|
# lerna doesn't want to publish anything otherwise - "lerna success No changed packages
|
|
# to publish"
|
|
# --exact
|
|
# lerna will link the dependencies of monorepo packages without ^ operator as npm
|
|
# is apparently bad at resolving ^ dependencies of the canary versions. For e.g
|
|
# @chainsafe/lodestar@^0.34.0-dev.4 resolves to => 0.34.0
|
|
#
|
|
# NOTE: Using --preid dev.$(git rev-parse --short=7 HEAD) results in `0.24.3-dev.3ddb91d.0+3ddb91d`
|
|
run: |
|
|
yarn lerna publish from-package \
|
|
--yes \
|
|
--no-verify-access \
|
|
--dist-tag next \
|
|
--no-git-reset \
|
|
--force-publish \
|
|
--exact
|
|
outputs:
|
|
version: ${{ steps.version.outputs.version }}
|
|
|
|
docker:
|
|
name: Publish to Docker Hub
|
|
runs-on: buildjet-4vcpu-ubuntu-2204
|
|
needs: npm
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
# https://github.com/docker/setup-qemu-action
|
|
- name: Set up QEMU
|
|
uses: docker/setup-qemu-action@v3
|
|
# https://github.com/docker/setup-buildx-action
|
|
- name: Set up Docker Buildx
|
|
uses: docker/setup-buildx-action@v3
|
|
- name: Login to Docker Hub
|
|
uses: docker/login-action@v3
|
|
with:
|
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
- name: Build and push lodestar
|
|
run: >
|
|
docker buildx build . --push
|
|
--tag chainsafe/lodestar:next
|
|
--platform linux/amd64,linux/arm64
|
|
--build-arg COMMIT=$(git rev-parse HEAD)
|
|
|
|
- run: docker run chainsafe/lodestar:next --help
|
|
# Display history to know byte size of each layer
|
|
# Image is available only because of the previous `docker run` command
|
|
- run: docker image history chainsafe/lodestar:next
|
|
|
|
- name: Build and push custom Grafana
|
|
run: >
|
|
docker buildx build ./docker/grafana/ --push
|
|
--file ./docker/grafana/Dockerfile
|
|
--build-context dashboards=./dashboards
|
|
--tag chainsafe/lodestar-grafana:next
|
|
--platform linux/amd64,linux/arm64
|
|
|
|
- name: Build and push custom Prometheus
|
|
run: >
|
|
docker buildx build ./docker/prometheus/ --push
|
|
--file ./docker/prometheus/Dockerfile
|
|
--tag chainsafe/lodestar-prometheus:next
|
|
--platform linux/amd64,linux/arm64
|