added keychain setup #2
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: MacOS (x86_64/arm) Nightly Build | |
on: | |
push: | |
branches: | |
- pr-29 | |
workflow_dispatch: # Allows manual triggering | |
env: | |
CARGO_TERM_COLOR: always | |
jobs: | |
build: | |
name: Build MacOS Apps | |
runs-on: macos-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Setup Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
cache: 'npm' | |
- name: Install Rust | |
uses: dtolnay/rust-toolchain@stable | |
- name: Install Dependencies | |
run: | | |
rustup target add x86_64-apple-darwin | |
rustup target add aarch64-apple-darwin | |
npm install | |
- name: Set up keychain | |
run: | | |
security create-keychain -p "" build.keychain | |
security default-keychain -s build.keychain | |
security unlock-keychain -p "" build.keychain | |
security import <(echo "$MACOS_CERTIFICATE" | base64 --decode) -k build.keychain -P "$MACOS_CERTIFICATE_PASSWORD" -T /usr/bin/codesign | |
security set-key-partition-list -S apple-tool:,apple: -s -k "" build.keychain | |
env: | |
MACOS_CERTIFICATE: ${{ secrets.MACOS_CERTIFICATE }} | |
MACOS_CERTIFICATE_PASSWORD: ${{ secrets.MACOS_CERTIFICATE_PASSWORD }} | |
- name: Build Frontend | |
run: npm run build | |
- name: Build for Intel Mac | |
run: | | |
echo "Building for x86_64..." | |
npm run tauri build -- --target x86_64-apple-darwin --bundles dmg | |
- name: Build for Apple Silicon | |
run: | | |
echo "Building for aarch64..." | |
npm run tauri build -- --target aarch64-apple-darwin --bundles dmg | |
- name: Upload Intel Build | |
uses: actions/upload-artifact@v4 | |
with: | |
name: macos-intel-build | |
path: src-tauri/target/x86_64-apple-darwin/release/bundle/dmg/*.dmg | |
- name: Upload Apple Silicon Build | |
uses: actions/upload-artifact@v4 | |
with: | |
name: macos-apple-silicon-build | |
path: src-tauri/target/aarch64-apple-darwin/release/bundle/dmg/*.dmg | |
- name: Create Release | |
if: github.event_name == 'schedule' # Only create release for scheduled builds | |
uses: softprops/action-gh-release@v1 | |
with: | |
name: Nightly Build ${{ github.sha }} | |
tag_name: nightly-${{ github.sha }} | |
files: | | |
src-tauri/target/x86_64-apple-darwin/release/bundle/dmg/*.dmg | |
src-tauri/target/aarch64-apple-darwin/release/bundle/dmg/*.dmg | |
prerelease: true | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |