Skip to content

Release

Release #29

Workflow file for this run

name: Release
on:
push:
tags:
- 'v[0-9]+.*'
env:
CARGO_TERM_COLOR: always
permissions:
contents: write
jobs:
build-release:
name: Build ${{ matrix.artifact }}
runs-on: ${{ matrix.os }}
strategy:
matrix:
include:
- os: ubuntu-latest
target: x86_64-unknown-linux-gnu
artifact: predicate-authorityd-linux-x64
extension: ""
- os: ubuntu-24.04-arm
target: aarch64-unknown-linux-gnu
artifact: predicate-authorityd-linux-arm64
extension: ""
- os: macos-latest
target: x86_64-apple-darwin
artifact: predicate-authorityd-darwin-x64
extension: ""
- os: macos-latest
target: aarch64-apple-darwin
artifact: predicate-authorityd-darwin-arm64
extension: ""
- os: windows-latest
target: x86_64-pc-windows-msvc
artifact: predicate-authorityd-windows-x64
extension: ".exe"
steps:
- uses: actions/checkout@v4
- name: Install Rust toolchain
uses: dtolnay/rust-toolchain@master
with:
toolchain: stable
targets: ${{ matrix.target }}
- name: Cache cargo registry
uses: actions/cache@v4
with:
path: |
~/.cargo/registry
~/.cargo/git
target
key: ${{ runner.os }}-cargo-release-${{ matrix.target }}-${{ hashFiles('**/Cargo.lock') }}
restore-keys: |
${{ runner.os }}-cargo-release-${{ matrix.target }}-
- name: Build release binary
run: cargo build --release --target ${{ matrix.target }}
- name: Prepare binary (Unix)
if: runner.os != 'Windows'
run: |
cd target/${{ matrix.target }}/release
strip predicate-authorityd || true
chmod +x predicate-authorityd
tar -czvf ${{ matrix.artifact }}.tar.gz predicate-authorityd
shasum -a 256 ${{ matrix.artifact }}.tar.gz > ${{ matrix.artifact }}.tar.gz.sha256
- name: Prepare binary (Windows)
if: runner.os == 'Windows'
shell: pwsh
run: |
cd target/${{ matrix.target }}/release
Compress-Archive -Path predicate-authorityd.exe -DestinationPath ${{ matrix.artifact }}.zip
(Get-FileHash -Algorithm SHA256 ${{ matrix.artifact }}.zip).Hash.ToLower() + " " + "${{ matrix.artifact }}.zip" | Out-File -Encoding utf8 ${{ matrix.artifact }}.zip.sha256
- name: Upload artifacts
uses: actions/upload-artifact@v4
with:
name: ${{ matrix.artifact }}
path: |
target/${{ matrix.target }}/release/${{ matrix.artifact }}.tar.gz
target/${{ matrix.target }}/release/${{ matrix.artifact }}.tar.gz.sha256
target/${{ matrix.target }}/release/${{ matrix.artifact }}.zip
target/${{ matrix.target }}/release/${{ matrix.artifact }}.zip.sha256
if-no-files-found: ignore
create-release:
name: Create GitHub Release
needs: build-release
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Download all artifacts
uses: actions/download-artifact@v4
with:
path: artifacts
- name: Collect release files
run: |
mkdir -p release-files
find artifacts -type f \( -name "*.tar.gz" -o -name "*.zip" -o -name "*.sha256" \) -exec cp {} release-files/ \;
ls -la release-files/
- name: Create Release
uses: softprops/action-gh-release@v2
with:
files: release-files/*
generate_release_notes: false
prerelease: ${{ contains(github.ref_name, '-') }}
body: |
## Predicate Authority Daemon ${{ github.ref_name }}
### Installation
Download the appropriate binary for your platform:
- **Linux x64**: `predicate-authorityd-linux-x64.tar.gz`
- **Linux ARM64**: `predicate-authorityd-linux-arm64.tar.gz`
- **macOS x64**: `predicate-authorityd-darwin-x64.tar.gz`
- **macOS ARM64**: `predicate-authorityd-darwin-arm64.tar.gz`
- **Windows x64**: `predicate-authorityd-windows-x64.zip`
### Quick Start
```bash
# Extract (Linux/macOS)
tar -xzf predicate-authorityd-*.tar.gz
chmod +x predicate-authorityd
# Generate example config
./predicate-authorityd init-config
# Run the daemon
./predicate-authorityd --port 8787
```
See the [README](https://github.com/PredicateSystems/predicate-authority-sidecar#readme) for full documentation.
# Trigger SDK repos to update their bundled binaries
trigger-sdk-releases:
name: Trigger SDK Binary Updates
needs: create-release
runs-on: ubuntu-latest
steps:
- name: Trigger TypeScript SDK binary update
uses: peter-evans/repository-dispatch@v3
with:
token: ${{ secrets.SDK_DISPATCH_TOKEN }}
repository: PredicateSystems/predicate-authority-ts
event-type: sidecar-release
client-payload: |
{
"version": "${{ github.ref_name }}",
"release_url": "https://github.com/${{ github.repository }}/releases/tag/${{ github.ref_name }}"
}
- name: Trigger Python SDK binary update
uses: peter-evans/repository-dispatch@v3
with:
token: ${{ secrets.SDK_DISPATCH_TOKEN }}
repository: PredicateSystems/predicate-authority
event-type: sidecar-release
client-payload: |
{
"version": "${{ github.ref_name }}",
"release_url": "https://github.com/${{ github.repository }}/releases/tag/${{ github.ref_name }}"
}