Files
TravelMate/.gitea/workflows/deploy-android.yaml
Van Leemput Dayron 59b708a160
Some checks failed
Deploy Flutter to Firebase (Mac) / deploy-android (push) Failing after 15s
test 43
2025-12-15 01:16:32 +01:00

93 lines
3.9 KiB
YAML

name: Deploy Flutter to Firebase (Mac)
on:
push:
branches: release
jobs:
deploy-android:
runs-on: macos-latest
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Vérifier l'installation Flutter
run: flutter doctor -v
- name: Installer les dépendances Flutter
run: flutter pub get
- name: Créer les fichiers secrets
run: |
echo "${{ secrets.ENV_FILE }}" > .env
echo "${{ secrets.FIREBASE_CREDENTIALS }}" > ./android/firebase_credentials.json
# On NE crée PAS key.properties ici pour éviter les doublons. On le fera proprement après.
- name: Lancer Fastlane (Audit Keystore)
working-directory: ./android
env:
ANDROID_KEYSTORE_BASE64: ${{ secrets.ANDROID_KEYSTORE_BASE64 }}
# On injecte les secrets un par un pour construire un fichier propre
# ATTENTION : Assure-toi que ces variables existent dans tes secrets GitHub/Act !
# Si tu n'as qu'un bloc de texte, laisse comme avant, je vais le parser.
RAW_PROPERTIES: ${{ secrets.ANDROID_KEY_PROPERTIES }}
FIREBASE_ANDROID_APP_ID: ${{ secrets.FIREBASE_ANDROID_APP_ID }}
run: |
# 1. Config Ruby
export PATH="/opt/homebrew/opt/ruby/bin:$PATH"
export GEM_HOME=$PWD/vendor/bundle
export GEM_PATH=$PWD/vendor/bundle
export PATH=$GEM_HOME/bin:$PATH
# 2. Génération Keystore
echo "🔓 Décodage du Keystore..."
echo "$ANDROID_KEYSTORE_BASE64" | base64 -D > keystore.jks
KEYSTORE_PATH=$(pwd)/keystore.jks
# 3. Récupération "Propre" des infos (Parsing du secret brut)
echo "$RAW_PROPERTIES" > temp_props.txt
# On extrait les valeurs sans les chemins de fichier pollués
STORE_PASS=$(grep "storePassword" temp_props.txt | cut -d'=' -f2 | tr -d '\r')
KEY_PASS=$(grep "keyPassword" temp_props.txt | cut -d'=' -f2 | tr -d '\r')
KEY_ALIAS=$(grep "keyAlias" temp_props.txt | cut -d'=' -f2 | tr -d '\r')
echo "---------------------------------------------------"
echo "🕵️‍♂️ AUDIT DE VÉRITÉ AVEC KEYTOOL"
echo "---------------------------------------------------"
echo "On va tenter de lister le contenu du keystore avec le mot de passe : $STORE_PASS"
# COMMANDE CRITIQUE : Ceci va lister le vrai Alias contenu dans le fichier
keytool -list -v -keystore keystore.jks -storepass "$STORE_PASS"
echo "---------------------------------------------------"
echo "👉 Compare l'Alias ci-dessus (Alias name: ...) avec celui de ton secret : $KEY_ALIAS"
echo "---------------------------------------------------"
# 4. Création d'un key.properties PROPRE (sans doublons)
echo "storePassword=$STORE_PASS" > key.properties
echo "keyPassword=$KEY_PASS" >> key.properties
echo "keyAlias=$KEY_ALIAS" >> key.properties
echo "storeFile=$KEYSTORE_PATH" >> key.properties
echo "✅ Fichier key.properties régénéré proprement."
# 5. Préparation Fastlane
rm -rf vendor Gemfile.lock .bundle
echo "source 'https://rubygems.org'" > Gemfile
echo "gem 'fastlane', '>= 2.210.0'" >> Gemfile
echo "gem 'abbrev'" >> Gemfile
echo "gem 'ostruct'" >> Gemfile
echo "gem 'mutex_m'" >> Gemfile
echo "gem 'base64'" >> Gemfile
echo "gem 'csv'" >> Gemfile
echo "gem 'bigdecimal'" >> Gemfile
echo "gem 'drb'" >> Gemfile
echo "gem 'nkf'" >> Gemfile
gem install bundler -v 2.7.2 --force --no-document
bundle _2.7.2_ update --jobs 4
echo "🚀 Lancement..."
bundle _2.7.2_ exec fastlane deploy_firebase