diff --git a/.gitea/workflows/android.yaml b/.gitea/workflows/android.yaml index 1e329df..bdcf425 100644 --- a/.gitea/workflows/android.yaml +++ b/.gitea/workflows/android.yaml @@ -10,6 +10,9 @@ jobs: steps: - name: Checkout Main Project uses: actions/checkout@v4 + with: + submodules: false + token: ${{ secrets.GITHUB_TOKEN }} - name: Manual Clone easy-nostr run: | @@ -24,8 +27,9 @@ jobs: run: | curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y 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" - rustup target add aarch64-linux-android + rustup target add aarch64-linux-android wasm32-unknown-unknown - name: Install Trunk & Tauri-CLI run: | @@ -41,60 +45,51 @@ jobs: wget -q https://dl.google.com/android/repository/commandlinetools-linux-9477386_latest.zip unzip -q commandlinetools-linux-9477386_latest.zip 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-35" "build-tools;35.0.0" "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 "NDK_HOME=$ANDROID_HOME/ndk/25.1.8937393" >> $GITHUB_ENV - - name: Build Frontend and APK + - name: Build and Compile run: | + # Pfade für diesen Shell-Block explizit setzen export PATH="$HOME/.cargo/bin:$PATH" export ANDROID_HOME=$HOME/android-sdk export NDK_HOME=$ANDROID_HOME/ndk/25.1.8937393 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 trunk build --release - # 2. Android Build - cargo-tauri android build --target aarch64 --apk true - env: - 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 + # 2. Android Build (Dein ursprünglicher Befehl) + if [ ! -d "src-tauri/gen/android" ]; then + cargo-tauri android init 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) - if [ -z "$UNSIGNED_APK" ]; then - echo "FEHLER: Keine unsignierte APK gefunden!" - exit 1 - fi + # Suche apksigner (der neueste) + APKSIGNER=$(find $ANDROID_HOME/build-tools -name apksigner | sort -r | head -n 1) - echo "Gefunden: $UNSIGNED_APK" - - echo "Signiere mit apksigner..." - # Expliziter Pfad zu den Build-Tools 35 - $ANDROID_HOME/build-tools/35.0.0/apksigner sign --ks release.keystore \ + $APKSIGNER sign --ks release.keystore \ --ks-key-alias "${{ secrets.ANDROID_KEY_ALIAS }}" \ --ks-pass pass:"${{ secrets.ANDROID_KEYSTORE_PASSWORD }}" \ --key-pass pass:"${{ secrets.ANDROID_KEY_PASSWORD }}" \ --out Marstemedia-Signed.apk \ "$UNSIGNED_APK" - - echo "Signierung abgeschlossen!" + env: + JAVA_HOME: /usr/lib/jvm/java-17-openjdk-amd64 - name: Upload Signed APK - uses: actions/upload-artifact@v4 + uses: actions/upload-artifact@v3 with: name: Marstemedia-Signed path: Marstemedia-Signed.apk