Build: Android-Signierung hinzugefügt
Some checks failed
Android Build Final Fixed / build-android (push) Failing after 2m7s
Some checks failed
Android Build Final Fixed / build-android (push) Failing after 2m7s
This commit is contained in:
@@ -10,9 +10,6 @@ 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: |
|
||||||
@@ -25,10 +22,10 @@ jobs:
|
|||||||
|
|
||||||
- name: Install Rust & Targets
|
- name: Install Rust & Targets
|
||||||
run: |
|
run: |
|
||||||
curl --proto '=https' --sv1.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
|
||||||
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
|
||||||
|
|
||||||
- name: Install Trunk & Tauri-CLI
|
- name: Install Trunk & Tauri-CLI
|
||||||
run: |
|
run: |
|
||||||
@@ -44,11 +41,12 @@ 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
|
||||||
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"
|
# 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-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 and Compile
|
- name: Build Frontend and APK
|
||||||
run: |
|
run: |
|
||||||
export PATH="$HOME/.cargo/bin:$PATH"
|
export PATH="$HOME/.cargo/bin:$PATH"
|
||||||
export ANDROID_HOME=$HOME/android-sdk
|
export ANDROID_HOME=$HOME/android-sdk
|
||||||
@@ -60,24 +58,32 @@ jobs:
|
|||||||
|
|
||||||
# 2. Android Build
|
# 2. Android Build
|
||||||
cargo-tauri android build --target aarch64 --apk true
|
cargo-tauri android build --target aarch64 --apk true
|
||||||
|
env:
|
||||||
|
JAVA_HOME: /usr/lib/jvm/java-17-openjdk-amd64
|
||||||
|
|
||||||
# 3. APK manuell signieren
|
- name: Sign APK
|
||||||
|
run: |
|
||||||
echo "Erstelle Keystore aus Secret..."
|
echo "Erstelle Keystore aus Secret..."
|
||||||
# Dekodieren ohne Zeilenumbruch-Probleme
|
# Nutze printf um Probleme mit echo-Zeilenumbrüchen zu vermeiden
|
||||||
echo "${{ secrets.ANDROID_KEYSTORE_BASE64 }}" | tr -d '[:space:]' | base64 -d > release.keystore
|
printf "%s" "${{ secrets.ANDROID_KEYSTORE_BASE64 }}" | base64 -d > release.keystore
|
||||||
|
|
||||||
# Sicherheitscheck: Ist die Datei valide?
|
|
||||||
if [ ! -s release.keystore ]; then
|
if [ ! -s release.keystore ]; then
|
||||||
echo "FEHLER: Keystore-Datei konnte nicht erstellt werden oder ist leer."
|
echo "FEHLER: Keystore-Datei ist leer oder konnte nicht erstellt werden!"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Suche unsignierte APK..."
|
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)
|
||||||
|
|
||||||
|
if [ -z "$UNSIGNED_APK" ]; then
|
||||||
|
echo "FEHLER: Keine unsignierte APK gefunden!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
echo "Gefunden: $UNSIGNED_APK"
|
echo "Gefunden: $UNSIGNED_APK"
|
||||||
|
|
||||||
echo "Signiere APK mit apksigner..."
|
echo "Signiere mit apksigner..."
|
||||||
# Wir nutzen Version 35.0.0, da Gradle diese laut deinem Log bevorzugt installiert hat
|
# Expliziter Pfad zu den Build-Tools 35
|
||||||
$ANDROID_HOME/build-tools/35.0.0/apksigner sign --ks release.keystore \
|
$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 }}" \
|
||||||
@@ -85,12 +91,10 @@ jobs:
|
|||||||
--out Marstemedia-Signed.apk \
|
--out Marstemedia-Signed.apk \
|
||||||
"$UNSIGNED_APK"
|
"$UNSIGNED_APK"
|
||||||
|
|
||||||
echo "Signierung erfolgreich abgeschlossen!"
|
echo "Signierung abgeschlossen!"
|
||||||
env:
|
|
||||||
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