Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 3012f84663 | |||
| c7a0272df3 |
@@ -2,7 +2,7 @@ name: Android Build Final Fixed
|
||||
on:
|
||||
push:
|
||||
branches: [main]
|
||||
tags: ["v*"] # Triggert bei v0.1.0, v1.0, etc.
|
||||
tags: ["v*"]
|
||||
|
||||
jobs:
|
||||
build-android:
|
||||
@@ -31,13 +31,15 @@ jobs:
|
||||
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y
|
||||
echo "$HOME/.cargo/bin" >> $GITHUB_PATH
|
||||
export PATH="$HOME/.cargo/bin:$PATH"
|
||||
rustup target add aarch64-linux-android wasm32-unknown-unknown
|
||||
rustup target add aarch64-linux-android armv7-linux-androideabi i686-linux-android x86_64-linux-android
|
||||
rustup target add wasm32-unknown-unknown
|
||||
|
||||
- name: Install Trunk & Tauri-CLI
|
||||
- name: Install Trunk & Tauri-CLI (Fixed)
|
||||
run: |
|
||||
wget -qO- https://github.com/trunk-rs/trunk/releases/latest/download/trunk-x86_64-unknown-linux-gnu.tar.gz | tar -xzf- -C /usr/local/bin
|
||||
wget -qO- https://github.com/tauri-apps/tauri/releases/latest/download/cargo-tauri-x86_64-unknown-linux-gnu.tgz | tar -xzf- -C /usr/local/bin
|
||||
chmod +x /usr/local/bin/trunk /usr/local/bin/cargo-tauri
|
||||
export PATH="$HOME/.cargo/bin:$PATH"
|
||||
# Installation via Cargo ist sicherer als wget von GitHub Releases
|
||||
cargo install trunk
|
||||
cargo install tauri-cli --version "^2.0.0"
|
||||
|
||||
- name: Setup Android SDK
|
||||
run: |
|
||||
@@ -63,15 +65,21 @@ jobs:
|
||||
|
||||
# 2. Android Build
|
||||
if [ ! -d "src-tauri/gen/android" ]; then
|
||||
cargo-tauri android init
|
||||
cargo tauri android init
|
||||
fi
|
||||
cargo-tauri android build --target aarch64 --apk true
|
||||
|
||||
cargo tauri android build --release --apk
|
||||
|
||||
# 3. APK manuell signieren
|
||||
echo "${{ secrets.ANDROID_KEYSTORE_BASE64 }}" | tr -d '[:space:]' > keystore.b64
|
||||
base64 -d keystore.b64 > release.keystore
|
||||
|
||||
UNSIGNED_APK=$(find src-tauri/gen/android/app/build/outputs/apk/universal/release -name "*-unsigned.apk" | head -n 1)
|
||||
UNSIGNED_APK=$(find src-tauri/gen/android/app/build/outputs/apk/universal/release -name "app-universal-release-unsigned.apk" | head -n 1)
|
||||
|
||||
if [ -z "$UNSIGNED_APK" ]; then
|
||||
UNSIGNED_APK="src-tauri/gen/android/app/build/outputs/apk/universal/release/app-universal-release-unsigned.apk"
|
||||
fi
|
||||
|
||||
APKSIGNER=$(find $ANDROID_HOME/build-tools -name apksigner | sort -r | head -n 1)
|
||||
|
||||
$APKSIGNER sign --ks release.keystore \
|
||||
@@ -80,7 +88,7 @@ jobs:
|
||||
--ks-pass pass:"${{ secrets.ANDROID_KEYSTORE_PASSWORD }}" \
|
||||
--key-pass pass:"${{ secrets.ANDROID_KEY_PASSWORD }}" \
|
||||
--v4-signing-enabled true \
|
||||
--out Marstemedia-Signed.apk \
|
||||
--out Marstemedia-Universal-Signed.apk \
|
||||
"$UNSIGNED_APK"
|
||||
|
||||
echo "Signierung erfolgreich!"
|
||||
@@ -90,15 +98,14 @@ jobs:
|
||||
- name: Upload Artifact
|
||||
uses: actions/upload-artifact@v3
|
||||
with:
|
||||
name: Marstemedia-Signed
|
||||
path: Marstemedia-Signed.apk
|
||||
name: Marstemedia-Universal-Signed
|
||||
path: Marstemedia-Universal-Signed.apk
|
||||
|
||||
- name: Create Gitea Release
|
||||
if: startsWith(github.ref, 'refs/tags/')
|
||||
uses: softprops/action-gh-release@v1
|
||||
with:
|
||||
files: Marstemedia-Signed.apk
|
||||
# Gitea braucht manchmal explizit den Namen/Body
|
||||
files: Marstemedia-Universal-Signed.apk
|
||||
name: "Release ${{ github.ref_name }}"
|
||||
draft: false
|
||||
prerelease: false
|
||||
|
||||
Reference in New Issue
Block a user