Skip to content

Prepare release v0.2.0 #1

Prepare release v0.2.0

Prepare release v0.2.0 #1

Workflow file for this run

name: Release
on:
push:
tags:
- 'v*.*.*'
workflow_dispatch:
inputs:
version:
description: 'Version to release (e.g., v0.1.0)'
required: true
type: string
env:
CARGO_TERM_COLOR: always
jobs:
create-release:
name: Create Release
runs-on: ubuntu-latest
outputs:
upload_url: ${{ steps.create_release.outputs.upload_url }}
version: ${{ steps.get_version.outputs.version }}
steps:
- name: Checkout code
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Get version
id: get_version
run: |
if [ "${{ github.event_name }}" == "workflow_dispatch" ]; then
VERSION="${{ github.event.inputs.version }}"
else
VERSION=${GITHUB_REF#refs/tags/}
fi
echo "version=$VERSION" >> $GITHUB_OUTPUT
echo "Version: $VERSION"
- name: Generate changelog
id: changelog
run: |
if [ -f CHANGELOG.md ]; then
CHANGELOG=$(awk '/^## \['"${VERSION#v}"'\]/,/^## \[/' CHANGELOG.md | sed '$d' | tail -n +2)
else
CHANGELOG="Release ${VERSION}"
fi
echo "changelog<<EOF" >> $GITHUB_OUTPUT
echo "$CHANGELOG" >> $GITHUB_OUTPUT
echo "EOF" >> $GITHUB_OUTPUT
- name: Create Release
id: create_release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: ${{ steps.get_version.outputs.version }}
release_name: Release ${{ steps.get_version.outputs.version }}
body: |
${{ steps.changelog.outputs.changelog }}
## Installation
### From source
```bash
cargo install --git https://github.com/raibid-labs/sigilforge --tag ${{ steps.get_version.outputs.version }}
```
See the [README](https://github.com/raibid-labs/sigilforge#getting-started) for more installation options.
draft: false
prerelease: ${{ contains(steps.get_version.outputs.version, '-') }}
build-release:
name: Build Release (${{ matrix.target }})
needs: create-release
runs-on: ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
include:
- os: ubuntu-latest
target: x86_64-unknown-linux-gnu
artifact_name: sigilforge
asset_name: sigilforge-linux-x86_64
- os: ubuntu-latest
target: x86_64-unknown-linux-musl
artifact_name: sigilforge
asset_name: sigilforge-linux-x86_64-musl
- os: macos-latest
target: x86_64-apple-darwin
artifact_name: sigilforge
asset_name: sigilforge-macos-x86_64
- os: macos-latest
target: aarch64-apple-darwin
artifact_name: sigilforge
asset_name: sigilforge-macos-aarch64
- os: windows-latest
target: x86_64-pc-windows-msvc
artifact_name: sigilforge.exe
asset_name: sigilforge-windows-x86_64.exe
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Install Rust
uses: dtolnay/rust-toolchain@stable
with:
targets: ${{ matrix.target }}
- name: Install musl tools
if: matrix.target == 'x86_64-unknown-linux-musl'
run: sudo apt-get update && sudo apt-get install -y musl-tools
- name: Build CLI
run: cargo build --release --target ${{ matrix.target }} -p sigilforge-cli
- name: Build Daemon
run: cargo build --release --target ${{ matrix.target }} -p sigilforge-daemon
- name: Create archive (Unix)
if: runner.os != 'Windows'
run: |
cd target/${{ matrix.target }}/release
tar czf ${{ matrix.asset_name }}.tar.gz \
sigilforge \
sigilforged
sha256sum ${{ matrix.asset_name }}.tar.gz > ${{ matrix.asset_name }}.tar.gz.sha256
mv ${{ matrix.asset_name }}.tar.gz* ../../../
- name: Create archive (Windows)
if: runner.os == 'Windows'
run: |
cd target/${{ matrix.target }}/release
7z a ${{ matrix.asset_name }}.zip sigilforge.exe sigilforged.exe
Get-FileHash -Algorithm SHA256 ${{ matrix.asset_name }}.zip | Select-Object -ExpandProperty Hash > ${{ matrix.asset_name }}.zip.sha256
Move-Item ${{ matrix.asset_name }}.zip* ../../../
shell: pwsh
- name: Upload Release Asset (Unix)
if: runner.os != 'Windows'
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ needs.create-release.outputs.upload_url }}
asset_path: ./${{ matrix.asset_name }}.tar.gz
asset_name: ${{ matrix.asset_name }}.tar.gz
asset_content_type: application/gzip
- name: Upload Checksum (Unix)
if: runner.os != 'Windows'
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ needs.create-release.outputs.upload_url }}
asset_path: ./${{ matrix.asset_name }}.tar.gz.sha256
asset_name: ${{ matrix.asset_name }}.tar.gz.sha256
asset_content_type: text/plain
- name: Upload Release Asset (Windows)
if: runner.os == 'Windows'
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ needs.create-release.outputs.upload_url }}
asset_path: ./${{ matrix.asset_name }}.zip
asset_name: ${{ matrix.asset_name }}.zip
asset_content_type: application/zip
- name: Upload Checksum (Windows)
if: runner.os == 'Windows'
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ needs.create-release.outputs.upload_url }}
asset_path: ./${{ matrix.asset_name }}.zip.sha256
asset_name: ${{ matrix.asset_name }}.zip.sha256
asset_content_type: text/plain
publish-crate:
name: Publish to crates.io
needs: build-release
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Install Rust
uses: dtolnay/rust-toolchain@stable
- name: Publish sigilforge-core
run: cargo publish -p sigilforge-core --token ${{ secrets.CARGO_TOKEN }}
continue-on-error: true
- name: Wait for crates.io index update
run: sleep 30
- name: Publish sigilforge-daemon
run: cargo publish -p sigilforge-daemon --token ${{ secrets.CARGO_TOKEN }}
continue-on-error: true
- name: Wait for crates.io index update
run: sleep 30
- name: Publish sigilforge-cli
run: cargo publish -p sigilforge-cli --token ${{ secrets.CARGO_TOKEN }}
continue-on-error: true