Files
TravelMate/.gitea/workflows/deploy-ios.yaml
Van Leemput Dayron 19c06c71f8
Some checks failed
Deploy Flutter to Firebase (Mac) / deploy-android (push) Successful in 2m42s
Deploy Flutter to Firebase iOS / deploy-ios (push) Failing after 1m11s
test 11
2026-01-10 21:30:24 +01:00

107 lines
4.2 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 (Version Xcode 26.2)
env:
P12_BASE: ${{ secrets.IOS_P12_BASE64 }}
P12_PASS: ${{ secrets.IOS_P12_PASSWORD }}
PROV_BASE: ${{ secrets.IOS_PROVISION_BASE64 }}
run: |
# 1. Nettoyage et création
security delete-keychain build.keychain || true
security create-keychain -p "" build.keychain
# 2. AJOUTER AU CHEMIN DE RECHERCHE (Crucial pour Xcode 26.2)
# Cela permet à Xcode de fouiller dans ce keychain pour signer l'IPA
security list-keychains -d user -s build.keychain $(security list-keychains -d user | xargs)
# 3. Paramétrage et Déverrouillage
security unlock-keychain -p "" build.keychain
security set-keychain-settings -t 3600 -u build.keychain
# 4. Importation du certificat Apple Distribution
echo "$P12_BASE" | base64 -D -o cert.p12
# On autorise explicitement /usr/bin/codesign à accéder à la clé
security import cert.p12 -k build.keychain -P "$P12_PASS" -T /usr/bin/codesign -T /usr/bin/productsign
# 5. Configuration de la partition pour éviter les popups bloquants
security set-key-partition-list -S apple-tool:,apple: -s -k "" build.keychain
# 6. Installation du Profil (Bundle ID: be.devdayronvl.TravelMate)
mkdir -p ~/Library/MobileDevice/Provisioning\ Profiles
# Xcode 26.2 nécessite que le nom du fichier corresponde à l'UUID ou soit standard
echo "$PROV_BASE" | 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
unset GEM_HOME
unset GEM_PATH
export PATH="/opt/homebrew/opt/ruby/bin:/opt/homebrew/bin:$PATH"
# 2. Installer la version de Bundler compatible avec Fastlane
gem install bundler -v 2.7.2 --no-document
# 3. Création du Gemfile
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 Ruby 3.4 (Xcode 26.2 compatible)
echo "gem 'base64'" >> Gemfile
echo "gem 'bigdecimal'" >> Gemfile
echo "gem 'mutex_m'" >> Gemfile
# 4. Installation avec la version FORCÉE de Bundler
bundle _2.7.2_ config set path 'vendor/bundle'
bundle _2.7.2_ install
# 5. Construction de l'IPA
# Xcode 26.2 compile plus vite grâce à son nouveau moteur
cd ..
flutter build ipa --release --export-method ad-hoc
cd ios
# 6. Envoi vers Firebase
echo "🚀 Envoi de l'IPA..."
bundle _2.7.2_ exec fastlane run firebase_app_distribution \
app:"$FIREBASE_IOS_APP_ID" \
ipa_path:"../build/ios/ipa/*.ipa" \
service_credentials_file:"firebase_credentials.json"