Skip to content

chore(ci): test build workflow #6

chore(ci): test build workflow

chore(ci): test build workflow #6

Workflow file for this run

name: Release
'on':
push:
branches:
- test
concurrency:
group: '${{ github.workflow }}'
cancel-in-progress: false
permissions:
contents: read
pages: write
id-token: write
jobs:
build:
name: Build
strategy:
fail-fast: false
matrix:
platform:
- macos-latest
- windows-latest
- ubuntu-22.04
runs-on: '${{ matrix.platform }}'
steps:
- uses: actions/checkout@v4
- name: Rust setup (mac)
if: 'startsWith(matrix.platform, ''macos'')'
uses: dtolnay/rust-toolchain@stable
with:
components: 'rustfmt, clippy'
targets: 'aarch64-apple-darwin, x86_64-apple-darwin'
- name: Rust setup
if: '!startsWith(matrix.platform, ''macos'')'
uses: dtolnay/rust-toolchain@stable
with:
components: 'rustfmt, clippy'
- name: Setup rust cache
uses: actions/cache@v4
with:
path: |
target/**
!target/*/release/bundle/*/*.dmg
!target/*/release/bundle/*/*.app.tar.gz
!target/*/release/bundle/*/*.app.tar.gz.sig
!target/release/bundle/*/*.dmg
!target/release/bundle/*/*.app.tar.gz
!target/release/bundle/*/*.app.tar.gz.sig
!target/release/bundle/appimage/*.AppImage
!target/release/bundle/appimage/*.AppImage.tar.gz
!target/release/bundle/appimage/*.AppImage.tar.gz.sig
!target/release/bundle/deb/*.deb
!target/release/bundle/rpm/*.rpm
!target/release/bundle/msi/*.msi
!target/release/bundle/msi/*.msi.zip
!target/release/bundle/msi/*.msi.zip.sig
!target/release/bundle/nsis/*.exe
!target/release/bundle/nsis/*.nsis.zip
!target/release/bundle/nsis/*.nsis.zip.sig
key: '${{ runner.os }}-rust-target-${{ hashFiles(''**/Cargo.lock'') }}'
restore-keys: |
${{ runner.os }}-rust-target-
- name: Use Node.js
uses: actions/setup-node@v4
with:
node-version: 20
- name: Install pnpm via corepack
shell: bash
run: |
corepack enable
corepack prepare --activate
- name: Get pnpm store directory
id: pnpm-cache
shell: bash
run: |
echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT
- name: Setup pnpm cache
uses: actions/cache@v4
with:
path: '${{ steps.pnpm-cache.outputs.STORE_PATH }}'
key: '${{ runner.os }}-pnpm-store-${{ hashFiles(''**/pnpm-lock.yaml'') }}'
restore-keys: |
${{ runner.os }}-pnpm-store-
- name: install dependencies (ubuntu only)
if: 'startsWith(matrix.platform, ''ubuntu'')'
run: >
sudo apt-get update
sudo apt-get install -y libwebkit2gtk-4.1-dev build-essential curl
wget file libxdo-dev libssl-dev pkg-config
libayatana-appindicator3-dev librsvg2-dev
- name: Install frontend dependencies
run: pnpm install
- name: build app (macos)
run: >-
pnpm --filter=@modrinth/app run tauri build --target
universal-apple-darwin --config "tauri-release.conf.json"
if: 'startsWith(matrix.platform, ''macos'')'
env:
GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}'
ENABLE_CODE_SIGNING: '${{ secrets.CSC_LINK }}'
APPLE_CERTIFICATE: '${{ secrets.CSC_LINK }}'
APPLE_CERTIFICATE_PASSWORD: '${{ secrets.CSC_KEY_PASSWORD }}'
APPLE_SIGNING_IDENTITY: '${{ secrets.APPLE_SIGNING_IDENTITY }}'
APPLE_ID: '${{ secrets.APPLE_ID }}'
APPLE_TEAM_ID: '${{ secrets.APPLE_TEAM_ID }}'
APPLE_PASSWORD: '${{ secrets.APPLE_APP_SPECIFIC_PASSWORD }}'
TAURI_SIGNING_PRIVATE_KEY: '${{ secrets.TAURI_PRIVATE_KEY }}'
TAURI_SIGNING_PRIVATE_KEY_PASSWORD: '${{ secrets.TAURI_KEY_PASSWORD }}'
- name: build app
run: >-
pnpm --filter=@modrinth/app run tauri build --config
"tauri-release.conf.json"
id: build_os
if: '!startsWith(matrix.platform, ''macos'')'
env:
GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}'
TAURI_SIGNING_PRIVATE_KEY: '${{ secrets.TAURI_PRIVATE_KEY }}'
TAURI_SIGNING_PRIVATE_KEY_PASSWORD: '${{ secrets.TAURI_KEY_PASSWORD }}'
- name: Sign files with Trusted Signing
if: startsWith(matrix.platform, 'windows')
uses: azure/trusted-signing-action@v0.5.1
with:
azure-tenant-id: ${{ secrets.AZURE_TENANT_ID }}
azure-client-id: ${{ secrets.AZURE_CLIENT_ID }}
azure-client-secret: ${{ secrets.AZURE_CLIENT_SECRET }}
endpoint: https://weu.codesigning.azure.net/
trusted-signing-account-name: marcusklauncher
certificate-profile-name: MarcuskStudioLauncher
files-folder: ${{ github.workspace }}\target\release\bundle
files-folder-filter: msi,exe
files-folder-recurse: true
file-digest: SHA256
timestamp-rfc3161: http://timestamp.acs.microsoft.com
timestamp-digest: SHA256
- name: 'upload ${{ matrix.platform }}'
uses: actions/upload-artifact@v4
with:
name: '${{ matrix.platform }}'
path: |
target/*/release/bundle/*/*.dmg
target/*/release/bundle/*/*.app.tar.gz
target/*/release/bundle/*/*.app.tar.gz.sig
target/release/bundle/*/*.dmg
target/release/bundle/*/*.app.tar.gz
target/release/bundle/*/*.app.tar.gz.sig
target/release/bundle/*/*.AppImage
target/release/bundle/*/*.AppImage.tar.gz
target/release/bundle/*/*.AppImage.tar.gz.sig
target/release/bundle/*/*.deb
target/release/bundle/*/*.rpm
target/release/bundle/msi/*.msi
target/release/bundle/msi/*.msi.zip
target/release/bundle/msi/*.msi.zip.sig
target/release/bundle/nsis/*.exe
target/release/bundle/nsis/*.nsis.zip
target/release/bundle/nsis/*.nsis.zip.sig
upload-s3:
needs: build
runs-on: ubuntu-latest
steps:
- name: Download all artifacts
uses: actions/download-artifact@v4
with:
path: artifacts
- name: Print directory structure
run: ls -R artifacts
- name: Extract version from Windows binary
id: extract_version
run: |
exe_path=$(find artifacts/windows-latest/release/bundle/nsis -name "MARCUSK Launcher_*_x64-setup.exe" | head -1)
filename=$(basename "$exe_path")
version=$(echo "$filename" | sed -E 's/MARCUSK Launcher_([0-9]+\.[0-9]+\.[0-9]+)_x64-setup.exe/\1/')
echo "version=$version" >> $GITHUB_OUTPUT
- name: Generate update manifest
id: generate_manifest
env:
DOWNLOAD_URL_BASE: 'https://cdn.marcuskstudio.live'
VERSION: ${{ steps.extract_version.outputs.version }}
run: |
# Function to find first file matching pattern
find_file() {
find "$1" -name "$2" -print -quit
}
# Windows
WIN_NSIS_ZIP=$(find_file "artifacts/windows-latest" "*.nsis.zip")
WIN_SIG=$(find_file "artifacts/windows-latest" "*.nsis.zip.sig")
WIN_EXE=$(find_file "artifacts/windows-latest" "*.exe")
# macOS
MACOS_TAR_GZ=$(find_file "artifacts/macos-latest" "*.app.tar.gz")
MACOS_SIG=$(find_file "artifacts/macos-latest" "*.app.tar.gz.sig")
MACOS_DMG=$(find_file "artifacts/macos-latest" "*.dmg")
# Linux
LINUX_APPIMAGE_TAR_GZ=$(find_file "artifacts/ubuntu-22.04" "*.AppImage.tar.gz")
LINUX_SIG=$(find_file "artifacts/ubuntu-22.04" "*.AppImage.tar.gz.sig")
LINUX_DEB=$(find_file "artifacts/ubuntu-22.04" "*.deb")
LINUX_APPIMAGE=$(find_file "artifacts/ubuntu-22.04" "*.AppImage")
LINUX_RPM=$(find_file "artifacts/ubuntu-22.04" "*.rpm")
# Create JSON using jq
jq -n \
--arg version "$VERSION" \
--arg pub_date "$(date -u +"%Y-%m-%dT%H:%M:%S.%NZ")" \
--arg win_sig "$(cat "$WIN_SIG")" \
--arg win_url "${DOWNLOAD_URL_BASE}/releases/latest/$(basename "$WIN_NSIS_ZIP")" \
--arg win_exe "${DOWNLOAD_URL_BASE}/releases/latest/$(basename "$WIN_EXE")" \
--arg macos_sig "$(cat "$MACOS_SIG")" \
--arg macos_url "${DOWNLOAD_URL_BASE}/releases/latest/$(basename "$MACOS_TAR_GZ")" \
--arg macos_dmg "${DOWNLOAD_URL_BASE}/releases/latest/$(basename "$MACOS_DMG")" \
--arg linux_sig "$(cat "$LINUX_SIG")" \
--arg linux_url "${DOWNLOAD_URL_BASE}/releases/latest/$(basename "$LINUX_APPIMAGE_TAR_GZ")" \
--arg linux_deb "${DOWNLOAD_URL_BASE}/releases/latest/$(basename "$LINUX_DEB")" \
--arg linux_appimage "${DOWNLOAD_URL_BASE}/releases/latest/$(basename "$LINUX_APPIMAGE")" \
--arg linux_rpm "${DOWNLOAD_URL_BASE}/releases/latest/$(basename "$LINUX_RPM")" \
'{
version: $version,
notes: "A new version of the MARCUSK Launcher has been released!",
pub_date: $pub_date,
platforms: {
"windows-x86_64": {
signature: $win_sig,
url: $win_url,
install_urls: [$win_exe]
},
"darwin-aarch64": {
signature: $macos_sig,
url: $macos_url,
install_urls: [$macos_dmg]
},
"darwin-x86_64": {
signature: $macos_sig,
url: $macos_url,
install_urls: [$macos_dmg]
},
"linux-x86_64": {
signature: $linux_sig,
url: $linux_url,
install_urls: [$linux_deb, $linux_appimage, $linux_rpm]
}
}
}' > update-manifest.json
- name: Upload artifacts to R2
uses: ryand56/r2-upload-action@latest
with:
r2-account-id: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }}
r2-access-key-id: ${{ secrets.CLOUDFLARE_R2_ACCESS_KEY_ID }}
r2-secret-access-key: ${{ secrets.CLOUDFLARE_R2_SECRET_ACCESS_KEY }}
r2-bucket: launcherbinaries
destination-dir: releases/latest
source-dir: artifacts
keep-file-fresh: true
- name: Upload update manifest to R2
uses: ryand56/r2-upload-action@latest
with:
r2-account-id: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }}
r2-access-key-id: ${{ secrets.CLOUDFLARE_R2_ACCESS_KEY_ID }}
r2-secret-access-key: ${{ secrets.CLOUDFLARE_R2_SECRET_ACCESS_KEY }}
r2-bucket: launcherbinaries
source-dir: update-manifest.json
destination-dir: ./
keep-file-fresh: true