Build: Android-Signierung hinzugefügt
Some checks failed
Android Build Final Fixed / build-android (push) Failing after 7m15s
Some checks failed
Android Build Final Fixed / build-android (push) Failing after 7m15s
This commit is contained in:
@@ -10,6 +10,9 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Checkout Main Project
|
- name: Checkout Main Project
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
submodules: false
|
||||||
|
token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
|
||||||
- name: Manual Clone easy-nostr
|
- name: Manual Clone easy-nostr
|
||||||
run: |
|
run: |
|
||||||
@@ -24,8 +27,9 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y
|
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y
|
||||||
echo "$HOME/.cargo/bin" >> $GITHUB_PATH
|
echo "$HOME/.cargo/bin" >> $GITHUB_PATH
|
||||||
|
# Hier direkt exportieren, damit die nächsten Befehle in diesem Step Rust finden
|
||||||
export PATH="$HOME/.cargo/bin:$PATH"
|
export PATH="$HOME/.cargo/bin:$PATH"
|
||||||
rustup target add aarch64-linux-android
|
rustup target add aarch64-linux-android wasm32-unknown-unknown
|
||||||
|
|
||||||
- name: Install Trunk & Tauri-CLI
|
- name: Install Trunk & Tauri-CLI
|
||||||
run: |
|
run: |
|
||||||
@@ -41,60 +45,51 @@ jobs:
|
|||||||
wget -q https://dl.google.com/android/repository/commandlinetools-linux-9477386_latest.zip
|
wget -q https://dl.google.com/android/repository/commandlinetools-linux-9477386_latest.zip
|
||||||
unzip -q commandlinetools-linux-9477386_latest.zip
|
unzip -q commandlinetools-linux-9477386_latest.zip
|
||||||
mv cmdline-tools latest
|
mv cmdline-tools latest
|
||||||
# Wir installieren direkt Version 35, da dein Log zeigt, dass Gradle diese bevorzugt
|
yes | $ANDROID_HOME/cmdline-tools/latest/bin/sdkmanager --sdk_root=$ANDROID_HOME "platform-tools" "platforms;android-33" "build-tools;33.0.1" "ndk;25.1.8937393"
|
||||||
yes | $ANDROID_HOME/cmdline-tools/latest/bin/sdkmanager --sdk_root=$ANDROID_HOME "platform-tools" "platforms;android-35" "build-tools;35.0.0" "ndk;25.1.8937393"
|
|
||||||
echo "ANDROID_HOME=$ANDROID_HOME" >> $GITHUB_ENV
|
echo "ANDROID_HOME=$ANDROID_HOME" >> $GITHUB_ENV
|
||||||
echo "NDK_HOME=$ANDROID_HOME/ndk/25.1.8937393" >> $GITHUB_ENV
|
echo "NDK_HOME=$ANDROID_HOME/ndk/25.1.8937393" >> $GITHUB_ENV
|
||||||
|
|
||||||
- name: Build Frontend and APK
|
- name: Build and Compile
|
||||||
run: |
|
run: |
|
||||||
|
# Pfade für diesen Shell-Block explizit setzen
|
||||||
export PATH="$HOME/.cargo/bin:$PATH"
|
export PATH="$HOME/.cargo/bin:$PATH"
|
||||||
export ANDROID_HOME=$HOME/android-sdk
|
export ANDROID_HOME=$HOME/android-sdk
|
||||||
export NDK_HOME=$ANDROID_HOME/ndk/25.1.8937393
|
export NDK_HOME=$ANDROID_HOME/ndk/25.1.8937393
|
||||||
export JAVA_HOME=/usr/lib/jvm/java-17-openjdk-amd64
|
export JAVA_HOME=/usr/lib/jvm/java-17-openjdk-amd64
|
||||||
|
|
||||||
|
# Falls rustup die targets in diesem Block nicht kennt, sicherheitshalber nochmal:
|
||||||
|
rustup target add aarch64-linux-android wasm32-unknown-unknown
|
||||||
|
|
||||||
# 1. Frontend bauen
|
# 1. Frontend bauen
|
||||||
trunk build --release
|
trunk build --release
|
||||||
|
|
||||||
# 2. Android Build
|
# 2. Android Build (Dein ursprünglicher Befehl)
|
||||||
cargo-tauri android build --target aarch64 --apk true
|
if [ ! -d "src-tauri/gen/android" ]; then
|
||||||
env:
|
cargo-tauri android init
|
||||||
JAVA_HOME: /usr/lib/jvm/java-17-openjdk-amd64
|
|
||||||
|
|
||||||
- name: Sign APK
|
|
||||||
run: |
|
|
||||||
echo "Erstelle Keystore aus Secret..."
|
|
||||||
# Nutze printf um Probleme mit echo-Zeilenumbrüchen zu vermeiden
|
|
||||||
printf "%s" "${{ secrets.ANDROID_KEYSTORE_BASE64 }}" | base64 -d > release.keystore
|
|
||||||
|
|
||||||
if [ ! -s release.keystore ]; then
|
|
||||||
echo "FEHLER: Keystore-Datei ist leer oder konnte nicht erstellt werden!"
|
|
||||||
exit 1
|
|
||||||
fi
|
fi
|
||||||
|
cargo-tauri android build --target aarch64 --apk true
|
||||||
|
|
||||||
echo "Suche unsignierte APK..."
|
# 3. APK manuell signieren
|
||||||
|
echo "Signiere APK..."
|
||||||
|
echo "${{ secrets.ANDROID_KEYSTORE_BASE64 }}" | tr -d '[:space:]' | base64 -d > release.keystore
|
||||||
|
|
||||||
|
# Finde die unsignierte Datei im universal Ordner
|
||||||
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 "*-unsigned.apk" | head -n 1)
|
||||||
|
|
||||||
if [ -z "$UNSIGNED_APK" ]; then
|
# Suche apksigner (der neueste)
|
||||||
echo "FEHLER: Keine unsignierte APK gefunden!"
|
APKSIGNER=$(find $ANDROID_HOME/build-tools -name apksigner | sort -r | head -n 1)
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Gefunden: $UNSIGNED_APK"
|
$APKSIGNER sign --ks release.keystore \
|
||||||
|
|
||||||
echo "Signiere mit apksigner..."
|
|
||||||
# Expliziter Pfad zu den Build-Tools 35
|
|
||||||
$ANDROID_HOME/build-tools/35.0.0/apksigner sign --ks release.keystore \
|
|
||||||
--ks-key-alias "${{ secrets.ANDROID_KEY_ALIAS }}" \
|
--ks-key-alias "${{ secrets.ANDROID_KEY_ALIAS }}" \
|
||||||
--ks-pass pass:"${{ secrets.ANDROID_KEYSTORE_PASSWORD }}" \
|
--ks-pass pass:"${{ secrets.ANDROID_KEYSTORE_PASSWORD }}" \
|
||||||
--key-pass pass:"${{ secrets.ANDROID_KEY_PASSWORD }}" \
|
--key-pass pass:"${{ secrets.ANDROID_KEY_PASSWORD }}" \
|
||||||
--out Marstemedia-Signed.apk \
|
--out Marstemedia-Signed.apk \
|
||||||
"$UNSIGNED_APK"
|
"$UNSIGNED_APK"
|
||||||
|
env:
|
||||||
echo "Signierung abgeschlossen!"
|
JAVA_HOME: /usr/lib/jvm/java-17-openjdk-amd64
|
||||||
|
|
||||||
- name: Upload Signed APK
|
- name: Upload Signed APK
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v3
|
||||||
with:
|
with:
|
||||||
name: Marstemedia-Signed
|
name: Marstemedia-Signed
|
||||||
path: Marstemedia-Signed.apk
|
path: Marstemedia-Signed.apk
|
||||||
|
|||||||
Reference in New Issue
Block a user