Connexion Apple Supabase sur Android
Copiez une commande de configuration avec les étapes d'installation et la guide markdown complet pour ce plugin.
Conditions préalables
Section intitulée « Conditions préalables »Ce guide vous aidera à intégrer Apple Sign-In avec l'authentification Supabase sur Android.
Étape 1 : Déployez la fonction Edge Backend
Section intitulée « Étape 1 : Déployez la fonction Edge Backend »Tout d'abord, nous devons déployer la fonction Edge Supabase qui gérera l'appel de rappel Apple OAuth.
-
Naviguez dans votre répertoire de projet Supabase
Fenêtre de terminal cd your-project/supabase -
Créez la fonction de bord si elle n'existe pas
Fenêtre de terminal supabase functions new apple-signin-callback -
Copiez la fonction de bord code
La mise en œuvre complète de la fonction de bord est disponible dans l'application d'exemple Copiez les fichiers suivants dans votre projet :.
- Fonction de bord principale __CAPGO_KEEP_0__
supabase/functions/apple-signin-callback/index.ts- Main edge function codesupabase/functions/apple-signin-callback/deno.jsonConfigurez la vérification JWTjose(if it doesn’t exist)
-
Terminal window
L'endpoint de rappel OAuth d'Apple doit être public (aucune authentication requise) car Apple le redirigera vers lui. Mettez à jour votre
supabase/config.tomlfichier :[functions.apple-signin-callback]enabled = trueverify_jwt = false # Important: Set to false for public OAuth callbackimport_map = "./functions/apple-signin-callback/deno.json"entrypoint = "./functions/apple-signin-callback/index.ts" -
Déployez la fonction
Fenêtre de terminal supabase functions deploy apple-signin-callback -
Obtenez l'URL de votre fonction
Après le déploiement, vous obtiendrez une URL comme :
https://your-project-ref.supabase.co/functions/v1/apple-signin-callbackSi vous ne pouvez pas le trouver, vous pouvez faire les choses suivantes :
- Ouvrir
https://supabase.com/dashboard/project/YOUR_PROJECT_REF/functions - Cliquez sur le
apple-signin-callbackURL de la fonction pour le copier.
- Ouvrir
Étape 2 : Configurer le Portail des développeurs Apple
Section intitulée « Étape 2 : Configurer le Portail des développeurs Apple »Maintenant, nous devons configurer le Portail des développeurs Apple avec l'URL de l'arrière-plan et obtenir toutes les valeurs requises.
-
Suivez le guide de configuration d'Apple Login pour Android
Completer le guide de configuration d'Apple Login pour Android à :
- Créer un ID de service
- Générez une clé privée (.p8 fichier)
- Obtenez votre ID d'équipe et votre ID de clé
- Configurez l'URL de retour
-
Définir l'URL de retour dans le Portail du développeur Apple
Lors de la configuration de l'URL de retour dans le Portail du développeur Apple (étape 6.9 du guide Apple), utilisez votre URL de fonction Edge Supabase :
https://your-project-ref.supabase.co/functions/v1/apple-signin-callbackImportant : Utilisez l'URL de fonction Edge Supabase
N'en faites pas ne utilisez pas l'URL de redirection du guide de configuration de l'authentification Apple Android . Ce guide utilise une URL de serveur de backend personnalisé.Pour l'intégration Supabase, vous devez utiliser votre URL de fonction Edge Supabase au lieu de celle-ci. Correspondance exacte requise
-
Après avoir terminé la guide de configuration Apple, vous devriez avoir :
: Votre identifiant de l'équipe de développeur Apple
- : L'ID de clé provenant du portail du développeur Apple: Votre fichier de clé privée .p8 (doit être encodé en base64)
- : Votre ID de service Apple (par exemple,__CAPGO_KEEP_0__
- __CAPGO_KEEP_0____CAPGO_KEEP_0__
- __CAPGO_KEEP_0____CAPGO_KEEP_0__
com.example.app.service) - BASE_REDIRECT_URL: Votre URL de lien profond (par exemple,
capgo-demo-app://path)
Étape 3 : Définir les secrets Supabase
Étape 3 : Définir les secrets de SupabaseNous devons maintenant configurer les variables d'environnement (secrets) pour la fonction Edge Supabase.
-
Encodez votre clé privée
Encodez d'abord votre clé privée Apple (.p8) en base64 :
Fenêtre de terminal base64 -i AuthKey_XXXXX.p8Copiez la sortie entière (il s'agit d'une seule longue chaîne).
-
Définir les secrets à l'aide de Supabase CLI
Fenêtre de terminal supabase secrets set APPLE_TEAM_ID=your_team_idsupabase secrets set APPLE_KEY_ID=your_key_idsupabase secrets set APPLE_PRIVATE_KEY=your_base64_encoded_keysupabase secrets set ANDROID_SERVICE_ID=your.service.idsupabase secrets set BASE_REDIRECT_URL=your-app://pathsupabase secrets set APPLE_REDIRECT_URI=https://your-project-ref.supabase.co/functions/v1/apple-signin-callback -
Alternative : Définir des secrets dans le tableau de bord de Supabase
Si vous préférez utiliser le tableau de bord :
- Allez dans votre tableau de bord de projet Supabase
- Naviguez vers Fonctions Edge → Paramètres → Secrets
- Ajoutez chaque variable de secret avec sa valeur
Étape 4 : Utilisez l'assistant d'authentification
Sous-titre « Étape 4 : Utilisez l'assistant d'authentification »Vous pouvez maintenant utiliser l'assistant d'authentification dans votre application code.
Mise en œuvre
Sous-titre « Mise en œuvre »La mise en œuvre complète est disponible dans le dossier de l'application d'exemple. supabaseAuthUtils.ts Utiliser l'assistant d'authentification
Section intitulée « Utiliser l'assistant d'authentification »
Copier dans le presse-papierimport { authenticateWithAppleSupabase } from './supabaseAuthUtils';
const result = await authenticateWithAppleSupabase();if (result.success) { console.log('Signed in:', result.user); // Navigate to your authenticated area} else { console.error('Error:', result.error);}Section intitulée « Mettre à jour la fonctionnalité de l'assistant »
Lorsque vous utilisez lafonctionnalité de l'assistant, vous devez authenticateWithAppleSupabase mettre à jour les valeurs suivantes pour qu'elles correspondent à votre configuration : __CAPGO_KEEP_0__ __CAPGO_KEEP_0__
-
Mise à jour
redirectUrl- Définissez-le sur votre URL de fonction Edge Supabase :const redirectUrl = platform === 'android'? 'https://your-project-ref.supabase.co/functions/v1/apple-signin-callback': undefined; -
Mise à jour
clientId- Définissez-le sur votre ID de service Apple :await SocialLogin.initialize({apple: {clientId: isIOS? undefined // iOS uses bundle ID automatically: 'your.service.id.here', // Your Apple Service ID for AndroidredirectUrl: redirectUrl,},});
Voir implémentation complète en référence.
Étape 5 : Tester l'intégration
Section intitulée “Étape 5 : Tester l'intégration”-
Construire et exécuter votre application Android
Fenêtre de terminal npx cap sync androidnpx cap run android -
Tester le flux d'authentification
- Cliquez sur le bouton « Connectez-vous avec Apple »
- Vous devriez voir la page OAuth Apple dans un navigateur
- Après avoir authentifié, vous devriez être redirigé vers votre application
- Vérifiez les journaux de console pour tout erreur
-
Vérifiez le flux
Le flux complet devrait être :
- L'utilisateur appuie sur « Se connecter avec Apple »
- L'application ouvre un navigateur avec OAuth Apple
- L'utilisateur se connecte avec Apple
- Apple redirige vers :
https://your-project-ref.supabase.co/functions/v1/apple-signin-callback - La fonction Edge échange code par des jetons
- La fonction Edge redirige vers :
your-app://path?id_token=...&access_token=... - L'application Android reçoit le lien profond et traite le jeton d'identité
- L'application se connecte à Supabase avec le jeton d'identité
Résolution des problèmes
Section intitulée « Résolution des problèmes »Si l'authentification échoue :
- URI de redirection incohérente: Vérifiez que l'URL de retour dans le portail Apple Developer correspond exactement à
APPLE_REDIRECT_URIsecret - Lien profond ne fonctionne pas: Vérifiez que
AndroidManifest.xmll'intent filter correspond à votreBASE_REDIRECT_URL - Manque de secrets: Vérifiez que tous les secrets sont correctement configurés à l'aide de
supabase secrets list - L'échange de jetons échoue: Vérifiez les journaux de fonction Edge dans le tableau de bord Supabase pour les messages d'erreur détaillés
- L'application ne reçoit pas d'appel de rappel: Assurez-vous que
onNewIntentest correctement implémenté dans MainActivity - Vérifiez le exemple d'application code en référence
Comment ça marche
Sous-section intitulée “Comment ça marche”Sur Android, Apple Sign-In utilise un flux OAuth de redirection :
- Initialisation: Le plugin est initialisé avec votre ID de service et l'URL de redirection de votre serveur
- Flux OAuth: Ouvre une fenêtre de navigateur/une fenêtre personnalisée Chrome avec la page OAuth d'Apple
- Callback de l'arrière-plan: Apple redirige votre fonction d'Edge Supabase avec une autorisation code
- Échange de jeton: La fonction d'Edge échange le code pour des jetons à l'aide de l'endpoint de jeton d'Apple
- Redirection de lien profond: La fonction d'Edge redirige vers votre application avec le jeton d'identité
- Authentification Supabase: L'application reçoit le jeton et s'authentifie auprès de Supabase
Cette flux est nécessaire car Apple ne fournit pas de support natif Android pour la connexion avec Apple.