[Single] Build Linux #6
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: "[Single] Build Linux" | |
on: | |
workflow_dispatch: | |
inputs: | |
nightly: | |
description: "Nightly prepare" | |
required: true | |
type: boolean | |
default: false | |
tag: | |
description: "Release Tag" | |
required: true | |
type: string | |
aarch64: | |
description: "Build for aarch64" | |
required: false | |
type: boolean | |
default: false | |
workflow_call: | |
inputs: | |
nightly: | |
description: "Nightly prepare" | |
required: true | |
type: boolean | |
default: false | |
tag: | |
description: "Release Tag" | |
required: true | |
type: string | |
aarch64: | |
description: "Build for aarch64" | |
required: false | |
type: boolean | |
default: false | |
jobs: | |
build: | |
runs-on: ubuntu-22.04 # 需要手动升级到 24.04 | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Install Rust stable | |
run: | | |
rustup install stable --profile minimal --no-self-update | |
rustup default stable | |
- name: Setup aarch64 Toolchain | |
if: ${{ inputs.aarch64 == true }} | |
run: | | |
rustup target add aarch64-unknown-linux-gnu | |
sudo apt install gcc-aarch64-linux-gnu -y | |
sudo dpkg --add-architecture arm64 | |
cat <<EOF | |
deb [arch=armhf,arm64] http://ports.ubuntu.com/ubuntu-ports jammy main restricted | |
deb [arch=armhf,arm64] http://ports.ubuntu.com/ubuntu-ports jammy-updates main restricted | |
deb [arch=armhf,arm64] http://ports.ubuntu.com/ubuntu-ports jammy universe | |
deb [arch=armhf,arm64] http://ports.ubuntu.com/ubuntu-ports jammy-updates universe | |
deb [arch=armhf,arm64] http://ports.ubuntu.com/ubuntu-ports jammy multiverse | |
deb [arch=armhf,arm64] http://ports.ubuntu.com/ubuntu-ports jammy-updates multiverse | |
deb [arch=armhf,arm64] http://ports.ubuntu.com/ubuntu-ports jammy-backports main restricted universe multiverse | |
deb [arch=armhf,arm64] http://ports.ubuntu.com/ubuntu-ports jammy-security main restricted | |
deb [arch=armhf,arm64] http://ports.ubuntu.com/ubuntu-ports jammy-security universe | |
deb [arch=armhf,arm64] http://ports.ubuntu.com/ubuntu-ports jammy-security multiverse | |
EOF | sudo tee /etc/apt/sources.list.d/arm64.list | |
sudo apt update -y && sudo apt upgrade -y | |
apt-get install -y libncurses6:arm64 libtinfo6:arm64 linux-libc-dev:arm64 libncursesw6:arm64 libssl3:arm64 libcups2:arm64 | |
apt-get install -y --no-install-recommends g++-aarch64-linux-gnu libc6-dev-arm64-cross libwebkit2gtk-4.0-dev:arm64 libgtk-3-dev:arm64 patchelf:arm64 librsvg2-dev:arm64 libayatana-appindicator3-dev:arm64 | |
- name: Setup x86_64 Toolchain | |
if: ${{ inputs.aarch64 == false }} | |
run: | | |
sudo apt-get update | |
sudo apt-get install -y libgtk-3-dev webkit2gtk-4.0 libappindicator3-dev librsvg2-dev patchelf openssl | |
- uses: Swatinem/rust-cache@v2 | |
with: | |
workspaces: "./backend/" | |
prefix-key: "rust-stable" | |
key: ubuntu-latest | |
shared-key: "release" | |
- name: Install Node latest | |
uses: actions/setup-node@v4 | |
with: | |
node-version: latest | |
- uses: pnpm/action-setup@v4 | |
name: Install pnpm | |
with: | |
run_install: false | |
- name: Pnpm install deps and download resources | |
run: | | |
pnpm i | |
${{ inputs.aarch64 == true && 'pnpm check --arch arm64 --sidecar-host aarch64-unknown-linux-gnu' || 'pnpm check' }} | |
- name: Nightly Prepare | |
if: ${{ inputs.nightly == true }} | |
run: | | |
pnpm prepare:nightly | |
- name: Build UI | |
run: | | |
pnpm -F ui build | |
- name: Tauri build | |
uses: tauri-apps/tauri-action@v0 | |
if: ${{ inputs.aarch64 == false }} | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
TAURI_PRIVATE_KEY: ${{ secrets.TAURI_PRIVATE_KEY }} | |
TAURI_KEY_PASSWORD: ${{ secrets.TAURI_KEY_PASSWORD }} | |
NIGHTLY: ${{ inputs.nightly == true && 'true' || 'false' }} | |
with: | |
tagName: ${{ inputs.tag }} | |
releaseName: "Clash Nyanpasu Dev" | |
releaseBody: "More new features are now supported." | |
releaseDraft: false | |
prerelease: true | |
tauriScript: pnpm tauri | |
args: ${{ inputs.nightly == true && '-f nightly -c ./backend/tauri/tauri.nightly.conf.json' || '-f default-meta -c ./backend/tauri/tauri.conf.json' }} | |
- name: Tauri build and upload (aarch64) | |
if: ${{ inputs.aarch64 == true }} | |
shell: bash | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
TAURI_PRIVATE_KEY: ${{ secrets.TAURI_PRIVATE_KEY }} | |
TAURI_KEY_PASSWORD: ${{ secrets.TAURI_KEY_PASSWORD }} | |
NIGHTLY: ${{ inputs.nightly == true && 'true' || 'false' }} | |
run: | | |
${{ inputs.nightly == true && 'pnpm build:nightly --target aarch64-unknown-linux-gnu -b "rpm,deb,updater"' || 'pnpm build --target aarch64-unknown-linux-gnu -b "rpm,deb,updater"' }} | |
gh release upload ${{ inputs.tag }} ./backend/target/release/bundle/*.deb ./backend/target/release/bundle/*.rpm --clobber | |
- name: Calc the archive signature | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
run: | | |
TAG_NAME=${{ inputs.tag }} | |
find ./backend/target/release/bundle \( -name "*.deb" -o -name "*.rpm" \) | while read file; do | |
sha_file="$file.sha256" | |
if [[ ! -f "$sha_file" ]]; then | |
sha256sum "$file" > "$sha_file" | |
echo "Created checksum file for: $file" | |
fi | |
gh release upload $TAG_NAME "$sha_file" --clobber | |
echo "Uploaded $sha_file to release $TAG_NAME" | |
done |