Skip to content

Workflow file for this run

name: Release
on:
release:
types: [published]
workflow_dispatch:
inputs:
release-id:
type: string
description: Optional release-id (only used when running worklfow manually)
jobs:
release-app:
permissions:
contents: write
strategy:
fail-fast: false
matrix:
include:
- platform: "macos-latest"
target: "aarch64-apple-darwin"
- platform: "macos-latest"
target: "x86_64-apple-darwin"
# - platform: "ubuntu-22.04"
# target: "aarch64-unknown-linux-gnu"
- platform: "ubuntu-22.04"
target: "x86_64-unknown-linux-gnu"
- platform: "windows-latest"
target: "aarch64-pc-windows-msvc"
- platform: "windows-latest"
target: "x86_64-pc-windows-msvc"
runs-on: ${{ matrix.platform }}
steps:
- uses: actions/checkout@v4
with:
sparse-checkout: |
apps/core
crates
packages
scripts
- name: Checkout MetaX's repo
uses: actions/checkout@v4
with:
repository: kareemmahlees/meta-x
path: apps/meta-x
- name: Install dependencies (ubuntu only)
if: matrix.platform == 'ubuntu-22.04'
run: |
sudo apt-get update
sudo apt-get install -y libwebkit2gtk-4.1-dev libappindicator3-dev librsvg2-dev patchelf
- name: Install Rust stable
uses: dtolnay/rust-toolchain@stable
with:
targets: ${{ matrix.target }}
- name: Rust cache
uses: swatinem/rust-cache@v2
- uses: oven-sh/setup-bun@v2
with:
bun-version: latest
- name: Install dependencies
run: bun install --frozen-lock
- name: Setup Go
uses: actions/setup-go@v5
with:
cache: true
cache-dependency-path: "**/go.sum"
go-version: "stable"
- name: Build MetaX
run: go build -C ./apps/meta-x/ -o ../bin/meta-x -ldflags "-w -s"
- name: Prepare MetaX (windows)
if: matrix.platform == 'windows-latest'
run: ./scripts/prepare_metax.ps1 -target ${{matrix.target}}
- name: Prepare MetaX (mac, linux)
if: matrix.platform != 'windows-latest'
run: |
chmod +x ./scripts/prepare_metax.sh
./scripts/prepare_metax.sh ${{matrix.target}}
- uses: tauri-apps/tauri-action@v0
env:
GITHUB_TOKEN: ${{ secrets.RELEASE_TOKEN }}
TAURI_SIGNING_PRIVATE_KEY: ${{ secrets.TAURI_SIGNING_PRIVATE_KEY }}
TAURI_SIGNING_PRIVATE_KEY_PASSWORD: ${{ secrets.TAURI_SIGNING_PRIVATE_KEY_PASSWORD }}
with:
releaseId: ${{ github.event.release.id || github.event.inputs.release-id }}
includeUpdaterJson: true
projectPath: ./apps/core
tauriScript: bunx tauri
args: --config src-tauri/tauri.conf.prod.json --features metax --target ${{matrix.target}} ${{ matrix.target == 'aarch64-pc-windows-msvc' && '--bundles nsis' || ''}}