Release #10
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Release | |
on: | |
push: | |
tags: | |
- "v*" | |
workflow_dispatch: | |
inputs: | |
build-docker: | |
description: "Build Docker" | |
required: false | |
type: boolean | |
default: false | |
build-binary: | |
description: "Build Binary" | |
required: false | |
type: boolean | |
default: true | |
draft-release: | |
description: "Draft Release" | |
required: false | |
type: boolean | |
default: false | |
jobs: | |
extract-version: | |
name: Extract version | |
runs-on: warp-ubuntu-latest-x64-16x | |
outputs: | |
VERSION: ${{ steps.extract_version.outputs.VERSION }} | |
steps: | |
- name: Extract version | |
id: extract_version | |
run: | | |
if [[ "${GITHUB_REF_TYPE}" == "tag" ]]; then | |
VERSION="${GITHUB_REF#refs/tags/}" | |
else | |
SHA_SHORT="$(echo ${GITHUB_SHA} | cut -c1-7)" | |
BRANCH_NAME_SAFE="${GITHUB_REF_NAME//\//-}" # replaces "/" in branch name with "-" | |
VERSION="${BRANCH_NAME_SAFE}-${SHA_SHORT}" | |
fi | |
echo "VERSION=${VERSION}" >> $GITHUB_OUTPUT | |
echo "${VERSION}" | |
echo "### Version: \`${VERSION}\`" >> $GITHUB_STEP_SUMMARY | |
echo "| | |" >> $GITHUB_STEP_SUMMARY | |
echo "| ------------------- | ---------------------- |" >> $GITHUB_STEP_SUMMARY | |
echo "| \`GITHUB_REF_TYPE\` | \`${GITHUB_REF_TYPE}\` |" >> $GITHUB_STEP_SUMMARY | |
echo "| \`GITHUB_REF_NAME\` | \`${GITHUB_REF_NAME}\` |" >> $GITHUB_STEP_SUMMARY | |
echo "| \`GITHUB_REF\` | \`${GITHUB_REF}\` |" >> $GITHUB_STEP_SUMMARY | |
echo "| \`GITHUB_SHA\` | \`${GITHUB_SHA}\` |" >> $GITHUB_STEP_SUMMARY | |
echo "| \`VERSION\` | \`${VERSION}\` |" >> $GITHUB_STEP_SUMMARY | |
build-binary: | |
name: Build binary | |
needs: extract-version | |
if: ${{ github.event.inputs.build-binary == 'true' || github.event_name == 'push'}} # when manually triggered or version tagged | |
runs-on: ${{ matrix.configs.runner }} | |
env: | |
VERSION: ${{ needs.extract-version.outputs.VERSION }} | |
permissions: | |
contents: write | |
packages: write | |
strategy: | |
matrix: | |
configs: | |
- target: x86_64-unknown-linux-gnu | |
runner: warp-ubuntu-latest-x64-16x | |
- target: aarch64-unknown-linux-gnu | |
runner: warp-ubuntu-latest-arm64-16x | |
- target: aarch64-apple-darwin | |
runner: warp-macos-14-arm64-6x | |
features: | |
- "" | |
- "redact_sensitive" | |
steps: | |
- name: Checkout sources | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 # needed for built.rs to get GIT_HEAD_REF | |
- name: Setup rust toolchain | |
uses: dtolnay/rust-toolchain@stable | |
with: | |
target: ${{ matrix.configs.target }} | |
- name: Run WarpBuilds/rust-cache | |
uses: WarpBuilds/rust-cache@v2 | |
with: | |
cache-on-failure: true | |
- name: Setup sccache-action | |
uses: mozilla-actions/[email protected] | |
- name: Set env vars | |
run: | | |
echo "SCCACHE_GHA_ENABLED=true" >> $GITHUB_ENV | |
echo "RUSTC_WRAPPER=sccache" >> $GITHUB_ENV | |
- name: Build rbuilder binary | |
run: cargo build --release --features=${{ matrix.features }} --target ${{ matrix.configs.target }} | |
- name: Upload rbuilder artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: rbuilder-${{ matrix.configs.target }}${{ matrix.features && '-' }}${{ matrix.features }} | |
path: target/${{ matrix.configs.target }}/release/rbuilder | |
- name: Upload reth-rbuilder artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: reth-rbuilder-${{ matrix.configs.target }}${{ matrix.features && '-' }}${{ matrix.features }} | |
path: target/${{ matrix.configs.target }}/release/reth-rbuilder | |
draft-release: | |
name: Draft release | |
if: ${{ github.event.inputs.draft-release == 'true' || github.event_name == 'push'}} # when manually triggered or version tagged | |
needs: [extract-version, build-binary] | |
runs-on: warp-ubuntu-latest-x64-16x | |
env: | |
VERSION: ${{ needs.extract-version.outputs.VERSION }} | |
permissions: | |
contents: write | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Download artifacts | |
uses: actions/download-artifact@v4 | |
with: | |
merge-multiple: true | |
path: artifacts | |
- name: Record artifacts checksums | |
working-directory: artifacts | |
run: | | |
find ./ || true | |
for file in *; do sha256sum "$file" >> sha256sums.txt; done; | |
cat sha256sums.txt | |
- name: Create release draft | |
uses: softprops/[email protected] | |
id: create-release-draft | |
with: | |
draft: true | |
files: artifacts/* | |
generate_release_notes: true | |
name: ${{ env.VERSION }} | |
tag_name: ${{ env.VERSION }} | |
- name: Write Github Step Summary | |
run: | | |
echo "---" | |
echo "### Release Draft: ${{ env.VERSION }}" >> $GITHUB_STEP_SUMMARY | |
echo "${{ steps.create-release-draft.outputs.url }}" >> $GITHUB_STEP_SUMMARY | |
build-docker: | |
if: ${{ github.event.inputs.build-docker == 'true' }} | |
name: Build and publish Docker image | |
needs: extract-version | |
runs-on: warp-ubuntu-latest-x64-16x | |
env: | |
VERSION: ${{ needs.extract-version.outputs.VERSION }} | |
permissions: | |
contents: read | |
packages: write | |
steps: | |
- name: checkout sources | |
uses: actions/checkout@v4 | |
- name: docker qemu | |
uses: docker/setup-qemu-action@v3 | |
- name: docker buildx | |
uses: docker/setup-buildx-action@v3 | |
# https://github.com/docker/metadata-action | |
- name: docker metadata | |
uses: docker/metadata-action@v5 | |
id: meta | |
with: | |
images: ghcr.io/${{ github.repository }} | |
labels: org.opencontainers.image.source=${{ github.repositoryUrl }} | |
tags: | | |
type=sha | |
type=semver,pattern={{version}},value=${{ env.VERSION }} | |
type=semver,pattern={{major}}.{{minor}},value=${{ env.VERSION }} | |
type=semver,pattern={{major}},value=${{ env.VERSION }} | |
# Push latest tag for full version only, not for prerelease versions (i.e. not for v1.2.3-rc1) | |
type=raw,value=latest,enable=${{ !contains(env.VERSION, '-') }} | |
- name: docker login | |
uses: docker/login-action@v3 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: docker build and push | |
uses: docker/build-push-action@v5 | |
with: | |
cache-from: type=gha | |
cache-to: type=gha,mode=max | |
context: . | |
labels: ${{ steps.meta.outputs.labels }} | |
platforms: linux/amd64,linux/arm64 | |
push: true | |
tags: ${{ steps.meta.outputs.tags }} |