Build: Android-Signierung hinzugefügt
Some checks failed
Android Build Final Fixed / build-android (push) Failing after 7m9s
Some checks failed
Android Build Final Fixed / build-android (push) Failing after 7m9s
This commit is contained in:
@@ -27,7 +27,6 @@ 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 wasm32-unknown-unknown
|
rustup target add aarch64-linux-android wasm32-unknown-unknown
|
||||||
|
|
||||||
@@ -45,39 +44,45 @@ 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 33 vor, aber Gradle wird im Build-Schritt evtl. auf 35/36 upgraden
|
||||||
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-33" "build-tools;33.0.1" "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 and Compile
|
- 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 (Dein ursprünglicher Befehl)
|
# 2. Android Build
|
||||||
if [ ! -d "src-tauri/gen/android" ]; then
|
if [ ! -d "src-tauri/gen/android" ]; then
|
||||||
cargo-tauri android init
|
cargo-tauri android init
|
||||||
fi
|
fi
|
||||||
cargo-tauri android build --target aarch64 --apk true
|
cargo-tauri android build --target aarch64 --apk true
|
||||||
|
|
||||||
# 3. APK manuell signieren
|
# 3. APK manuell signieren
|
||||||
echo "Signiere APK..."
|
echo "Erstelle Keystore..."
|
||||||
echo "${{ secrets.ANDROID_KEYSTORE_BASE64 }}" | tr -d '[:space:]' | base64 -d > release.keystore
|
# printf und tr stellen sicher, dass kein Müll im Keystore landet
|
||||||
|
printf "%s" "${{ secrets.ANDROID_KEYSTORE_BASE64 }}" | tr -d '[:space:]' | base64 -d > release.keystore
|
||||||
|
|
||||||
# Finde die unsignierte Datei im universal Ordner
|
if [ ! -s release.keystore ]; then
|
||||||
|
echo "FEHLER: Keystore-Datei ist leer!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Suche unsignierte APK..."
|
||||||
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)
|
||||||
|
echo "Gefunden: $UNSIGNED_APK"
|
||||||
|
|
||||||
# Suche apksigner (der neueste)
|
echo "Suche apksigner..."
|
||||||
|
# Da dein Log zeigt, dass Version 35.0.0 installiert wurde, suchen wir dynamisch die neueste
|
||||||
APKSIGNER=$(find $ANDROID_HOME/build-tools -name apksigner | sort -r | head -n 1)
|
APKSIGNER=$(find $ANDROID_HOME/build-tools -name apksigner | sort -r | head -n 1)
|
||||||
|
echo "Nutze apksigner unter: $APKSIGNER"
|
||||||
|
|
||||||
$APKSIGNER sign --ks release.keystore \
|
$APKSIGNER sign --ks release.keystore \
|
||||||
--ks-key-alias "${{ secrets.ANDROID_KEY_ALIAS }}" \
|
--ks-key-alias "${{ secrets.ANDROID_KEY_ALIAS }}" \
|
||||||
@@ -85,11 +90,13 @@ jobs:
|
|||||||
--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"
|
||||||
|
|
||||||
|
echo "Signierung abgeschlossen!"
|
||||||
env:
|
env:
|
||||||
JAVA_HOME: /usr/lib/jvm/java-17-openjdk-amd64
|
JAVA_HOME: /usr/lib/jvm/java-17-openjdk-amd64
|
||||||
|
|
||||||
- name: Upload Signed APK
|
- name: Upload Signed APK
|
||||||
uses: actions/upload-artifact@v3
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: Marstemedia-Signed
|
name: Marstemedia-Signed
|
||||||
path: Marstemedia-Signed.apk
|
path: Marstemedia-Signed.apk
|
||||||
|
|||||||
Reference in New Issue
Block a user