Files
TravelMate/.gitea/workflows/deploy-ios.yaml
Van Leemput Dayron 12fdd6da62
Some checks failed
Deploy Flutter to Firebase (Mac) / deploy-android (push) Successful in 2m20s
Deploy Flutter to Firebase iOS / deploy-ios (push) Failing after 45s
test 9
2026-01-10 21:20:16 +01:00

102 lines
3.9 KiB
YAML

name: Deploy Flutter to Firebase iOS
on:
push:
branches: release
jobs:
deploy-ios:
runs-on: macos-latest
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Vérifier et Configurer Xcode
run: |
# 1. Lister les versions installées pour le debug (visible dans les logs)
ls /Applications | grep Xcode
# 2. Vérifier la version actuelle par défaut
xcodebuild -version
# 3. (Optionnel) Ne décommenter que si la version par défaut n'est pas la 26.2
# sudo xcode-select -s /Applications/Xcode.app
- name: Installer les dépendances Flutter & Cocoapods
run: |
flutter pub get
cd ios
pod install --repo-update
cd ..
- name: Créer les fichiers secrets
run: |
echo "${{ secrets.ENV_FILE }}" > .env
printf '%s' '${{ secrets.FIREBASE_CREDENTIALS }}' > ./ios/firebase_credentials.json
- name: Préparer le Code Signing (Certificats)
env:
P12_CERTIFICATE_BASE64: ${{ secrets.IOS_P12_BASE64 }}
P12_PASSWORD: ${{ secrets.IOS_P12_PASSWORD }}
PROVISIONING_PROFILE_BASE64: ${{ secrets.IOS_PROVISION_BASE64 }}
run: |
# 1. Supprimer le keychain s'il existe déjà (Évite l'erreur du build précédent)
security delete-keychain build.keychain || true
# 2. Créer le keychain proprement
security create-keychain -p "" build.keychain
security default-keychain -s build.keychain
security unlock-keychain -p "" build.keychain
security set-keychain-settings -t 3600 -u build.keychain
# 3. Importer le certificat .p12
echo "$P12_CERTIFICATE_BASE64" | base64 -D -o certificate.p12
security import certificate.p12 -k build.keychain -P "$P12_PASSWORD" -T /usr/bin/codesign
security set-key-partition-list -S apple-tool:,apple: -s -k "" build.keychain
# 4. Importer le Profil de Provisionnement
mkdir -p ~/Library/MobileDevice/Provisioning\ Profiles
echo "$PROVISIONING_PROFILE_BASE64" | base64 -D -o ~/Library/MobileDevice/Provisioning\ Profiles/distribution.mobileprovision
- name: Lancer Fastlane & Build IPA
working-directory: ./ios
env:
FIREBASE_IOS_APP_ID: ${{ secrets.FIREBASE_IOS_APP_ID }}
run: |
# 1. Nettoyage et PATH (Optimisé pour Ruby 3.4 / Xcode 26.2)
unset GEM_HOME
unset GEM_PATH
export PATH="/opt/homebrew/opt/ruby/bin:/opt/homebrew/bin:$PATH"
# 2. Configuration de Bundler 4.0 (La nouvelle méthode)
# On définit le chemin de destination AVANT de lancer l'installation
bundle config set path 'vendor/bundle'
# 3. Création du Gemfile moderne
rm -f Gemfile Gemfile.lock
echo "source 'https://rubygems.org'" > Gemfile
echo "gem 'fastlane', '>= 2.210.0'" >> Gemfile
echo "gem 'fastlane-plugin-firebase_app_distribution'" >> Gemfile
# Indispensable pour la compatibilité Ruby 3.4
echo "gem 'base64'" >> Gemfile
echo "gem 'bigdecimal'" >> Gemfile
echo "gem 'mutex_m'" >> Gemfile
# 4. Installation sans le flag obsolète
bundle install
# 5. Construction de l'IPA
# Xcode 26.2 utilise son nouveau moteur de build parallèle ici
cd ..
flutter build ipa --release --export-method ad-hoc
cd ios
# 6. Envoi vers Firebase
echo "🚀 Envoi vers Firebase App Distribution..."
bundle exec fastlane run firebase_app_distribution \
app:"$FIREBASE_IOS_APP_ID" \
ipa_path:"../build/ios/ipa/*.ipa" \
service_credentials_file:"firebase_credentials.json" \
release_notes:"Build Flutter via Xcode 26.2"