Voici la traduction en français :
Livraison continue pour iOS en utilisant Fastlane et GitHub Actions et certificat
Prérequis
Avant de poursuivre le tutoriel…
- Assurez-vous d’avoir Fastlane installé sur votre machine de développement
- Adhésion au programme de développeur iOS
- Envie de lire 😆…
Important concernant le prix
https://githubcom/features/actions
Le service est ‘gratuit’ jusqu’à la limite, selon la machine choisie Nous allons utiliser une machine macOS, vous pouvez voir sur la capture d’écran son prix et ses limites (prix au moment de la création du tutoriel, ils pourraient subir des changements à l’avenir)
🔴 Une fois avertis des exigences et des prix, si vous le souhaitez, nous continuons…
📣 Dans cet article, nous supposons que nous avons l’application créée dans iTunes Connect, que nous avons les certificats de l’écosystème Apple, tout sera copié par Fastlane !
Passons aux choses sérieuses 🧑🏽💻
Étapes à suivre dans l’article
- Utilisation de l’API App Store Connect avec Fastlane
- Prérequis
- Création d’une clé API App Store Connect
- Utilisation d’une clé API App Store Connect
- Copie des fichiers Fastlane
- Configuration de GitHub Actions
1. Utilisation de l’API App Store Connect avec Fastlane
Depuis février 2021, l’authentification à deux facteurs ou la vérification en deux étapes est requise pour tous les utilisateurs pour se connecter à App Store Connect. Cette couche de sécurité supplémentaire pour votre identifiant Apple aide à garantir que vous êtes la seule personne à pouvoir accéder à votre compte. De Apple Support
Prérequis
Pour pouvoir utiliser l’API App Store Connect, Fastlane a besoin de trois éléments :
- ID de l’émetteur
- ID de la clé
- Fichier de clé ou contenu de la clé
Création d’une clé API App Store Connect
Pour générer des clés, vous devez avoir l’autorisation Admin dans App Store Connect. Si vous n’avez pas cette autorisation, vous pouvez diriger la personne concernée vers cet article et suivre les instructions suivantes.
1 — Connectez-vous à App Store Connect
2 — Sélectionnez Utilisateurs et accès
3 — Sélectionnez l’onglet Clés API
4 — Cliquez sur Générer une clé API ou sur le bouton Ajouter (+)
5 — Entrez un nom pour la clé. Le nom est uniquement pour votre référence et ne fait pas partie de la clé elle-même.
6 — Sous Accès, sélectionnez le rôle pour la clé. Les rôles qui s’appliquent aux clés sont les mêmes rôles qui s’appliquent aux utilisateurs de votre équipe. Voir les autorisations de rôle. Nous recommandons de sélectionner Gestion d’applications
7 — Cliquez sur Générer
L’accès d’une clé API ne peut pas être limité à des applications spécifiques
Le nom de la nouvelle clé, l’ID de la clé, un lien de téléchargement et d’autres informations apparaissent sur la page.
Vous pouvez récupérer les trois informations nécessaires ici : <1> ID de l’émetteur <2> ID de la clé <3> Cliquez sur “Télécharger la clé API” pour télécharger votre clé privée API. Le lien de téléchargement n’apparaît que si la clé privée n’a pas encore été téléchargée. Apple ne conserve pas de copie de la clé privée. Vous ne pouvez donc la télécharger qu’une seule fois.
🔴 Stockez votre clé privée dans un endroit sûr. Vous ne devez jamais partager vos clés, les stocker dans un dépôt de code ou inclure les clés dans le code côté client.
Utilisation d’une clé API App Store Connect
Le fichier de clé API (fichier p8 que vous téléchargez), l’ID de la clé et l’ID de l’émetteur sont nécessaires pour créer le jeton JWT pour l’autorisation. Il existe plusieurs façons d’entrer ces informations dans Fastlane en utilisant la nouvelle action de Fastlane, app_store_connect_api_key
. Vous pouvez découvrir d’autres méthodes dans la documentation de FastlaneJe montre cette méthode car je pense que c’est la façon la plus simple de travailler avec la plupart des CI, où vous pouvez définir des variables d’environnement
Maintenant nous pouvons gérer Fastlane avec la clé API App Store Connect, super !
Créer des certificats et des profils de provisionnement
Certificats
Ouvrez XCode et allez dans Préférences > Comptes > Apple ID > Équipes et sélectionnez votre équipe
Cliquez sur Gérer les certificats > + et sélectionnez Apple Distribution
Ensuite, vous pouvez créer un nouveau certificat
Puis vous devez aller dans le trousseau pour télécharger le certificat en tant que fichier p12
Pour ce faire, vous devez aller dans le trousseau, basculer vers le trousseau session puis l’onglet Mes certificats
Vous pouvez ensuite sélectionner le certificat que vous souhaitez télécharger (Recherchez par la date du certificat)
Puis faites un clic droit sur le certificat et sélectionnez Exporter
Choisissez le format de fichier Échange d’informations personnelles (.p12)
Cela téléchargera le certificat en tant que fichier p12
Profils de provisionnement
Ouvrez Apple Developer et sélectionnez la bonne équipe
Ensuite, créez un nouveau profil en cliquant sur +
Et sélectionnez App Store Connect
Ensuite, vous devez sélectionner la bonne application, faites attention à ne pas utiliser de caractère générique sinon la signature échouera
Sélectionnez le bon certificat que vous avez créé précédemment (recherchez la date d’expiration, elle devrait être le même jour et mois qu’aujourd’hui) et cliquez sur Continuer
Enfin, entrez le nom du profil et cliquez sur Générer
Le nom sera utilisé pour identifier le profil dans Fastlane, sous la valeur de
APPLE_PROFILE_NAME
Vous pouvez télécharger le profil en tant que fichier mobileprovision
Création de secrets GitHub pour votre certificat et profil de provisionnement
Le processus de signature implique le stockage des certificats et des profils de provisionnement, leur transfert vers l’exécuteur, leur importation dans le trousseau de l’exécuteur, et leur utilisation dans votre build
Créez des secrets dans votre dépôt ou organisation pour les éléments suivants :
-
Votre certificat de signature Apple
-
Il s’agit de votre fichier de certificat
p12
. Pour plus d’informations sur l’exportation de votre certificat de signature depuis Xcode, consultez la documentation Xcode -
Vous devez convertir votre certificat en Base64 lorsque vous l’enregistrez en tant que secret. Dans cet exemple, le secret est nommé
BUILD_CERTIFICATE_BASE64
-
Utilisez la commande suivante pour convertir votre certificat en Base64 et le copier dans votre presse-papiers :
-
-
Le mot de passe de votre certificat de signature Apple
- Dans cet exemple, le secret est nommé
P12_PASSWORD
- Dans cet exemple, le secret est nommé
-
Votre profil de provisionnement Apple
-
Pour plus d’informations sur l’exportation de votre profil de provisionnement depuis Xcode, consultez la documentation Xcode
-
Vous devez convertir votre profil de provisionnement en Base64 lorsque vous l’enregistrez en tant que secret. Dans cet exemple, le secret est nommé
BUILD_PROVISION_PROFILE_BASE64
-
Utilisez la commande suivante pour convertir votre profil de provisionnement en Base64 et le copier dans votre presse-papiers :
-
2. Copier les fichiers Fastlane
Fastlane est une bibliothèque Ruby créée pour automatiser les tâches courantes de développement mobile. En utilisant Fastlane, vous pouvez configurer des “lanes” personnalisées qui regroupent une série d‘“actions” qui effectuent des tâches que vous effectueriez normalement en utilisant Android Studio. Vous pouvez faire beaucoup avec Fastlane, mais pour les besoins de ce tutoriel, nous n’utiliserons qu’une poignée d’actions principales.Créez un dossier Fastlane à la racine de votre projet et copiez les fichiers suivants : Fastfile
Traitement des builds
Dans GitHub Actions, vous êtes facturé en fonction des minutes que vous avez utilisées pour exécuter votre workflow CI/CD. D’après l’expérience, il faut environ 10 à 15 minutes avant qu’un build puisse être traité dans App Store Connect.
Pour les projets privés, le coût estimé par build peut atteindre 0,08 $/min x 15 min = 1,2 $, ou plus, selon la configuration ou les dépendances de votre projet.
Si vous partagez les mêmes préoccupations que moi concernant le prix pour les projets privés, vous pouvez garder skip_waiting_for_build_processing
à true
.
Quel est l’inconvénient ? Vous devez mettre à jour manuellement la conformité de votre application dans App Store Connect après le traitement du build, pour pouvoir distribuer le build à vos utilisateurs.
Il s’agit simplement d’un paramètre facultatif à mettre à jour si vous souhaitez économiser sur les minutes de build pour les projets privés. Pour les projets gratuits, cela ne devrait pas poser de problème du tout. Voir tarification
3. Configurer GitHub Actions
Configurer les secrets GitHub
Vous vous êtes déjà demandé d’où viennent les valeurs de ENV
? Eh bien, ce n’est plus un secret - c’est à partir du secret de votre projet 🤦
-
APP_STORE_CONNECT_TEAM_ID
- l’ID de votre équipe App Store Connect si vous faites partie de plusieurs équipes -
PROVISIONING_PROFILE_SPECIFIER
-match AppStore <YOUR_APP_BUNDLE_IDENTIFIER>
, par exemplematch AppStore com.domain.blabla.demo
-
BUILD_CERTIFICATE_BASE64
- Certificat encodé en Base64 -
BUILD_PROVISION_PROFILE_BASE64
- Profil de provisionnement encodé en Base64 -
BUNDLE_IDENTIFIER
- l’identifiant de bundle de votre application -
APPLE_KEY_ID
— Clé API App Store Connect 🔺Key ID -
APPLE_ISSUER_ID
— Clé API App Store Connect 🔺Issuer ID -
APPLE_KEY_CONTENT
— Clé API App Store Connect 🔺 Contenu de la clé p8, vérifiez-le
4. Configurer le fichier de workflow GitHub
Créez un répertoire de workflow GitHub
Dans le dossier workflow
, créez un fichier nommé build-upload-ios.yml
et ajoutez ce qui suit
Ce workflow devrait être déclenché après chaque tag GitHub, si vous avez besoin d’automatiser le tag, veuillez d’abord vous référer à Construction et publication automatiques avec les actions GitHub
Ensuite, ce workflow extraira vos dépendances NodeJS, les installera et construira votre application JavaScript.
Chaque fois que vous envoyez un nouveau commit, une version sera construite dans TestFlight
Votre application n’a pas besoin d’utiliser Ionic, seule la base Capacitor est obligatoire, elle peut avoir d’anciens modules Cordova, mais les plugins JS Capacitor devraient être préférés.
5. Déclencher le workflow
Créer un commit
Faites un commit, vous devriez voir le workflow actif dans le dépôt.
Déclencher le workflow
Poussez les nouveaux commits vers la branche main
ou development
pour déclencher le workflow.
Après quelques minutes, le build devrait être disponible dans votre tableau de bord App Store Connect.
Peut-on déployer depuis une machine locale ?
Oui, vous le pouvez, et c’est très simple.
Vous pouvez utiliser Xcode pour construire et signer votre application, comme d’habitude.
Remerciements
Ce blog est basé sur les articles suivants :