Supabase Apple Login su Android
Copia un prompt di configurazione con i passaggi di installazione e la guida markdown completa per questo plugin.
Requisiti preliminari
Sezione intitolata “Requisiti preliminari”Questa guida ti aiuterà a integrare Apple Sign-In con l'autenticazione Supabase su Android. Si presume che tu abbia già completato:
Passo 1: Distribuisci la Funzione Edge Backend
Sezione intitolata “Passo 1: Distribuisci la Funzione Edge Backend”In primo luogo, dobbiamo distribuire la Funzione Edge Supabase che gestirà il callback OAuth Apple.
-
Naviga nella directory del tuo progetto Supabase
Finestra del terminale cd your-project/supabase -
Crea la funzione di edge (se non esiste)
Finestra del terminale supabase functions new apple-signin-callback -
Copia la funzione di edge code
La completa implementazione della funzione di edge è disponibile nell' esempio di applicazione.
Copia i seguenti file nel tuo progetto:
supabase/functions/apple-signin-callback/index.ts- Funzione di edge principale codesupabase/functions/apple-signin-callback/deno.json- Mappa di importazione per le dipendenze (includejoselibreria per la firma JWT)
-
Configura la verifica JWT
Il endpoint di callback OAuth di Apple deve essere pubblico (nessuna autenticazione richiesta) perché Apple lo reindirizzerà. Aggiorna il tuo
supabase/config.tomlfile:[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" -
Distribuisci la funzione
Finestra del terminale supabase functions deploy apple-signin-callback -
Ottieni l'URL della tua funzione
Dopo la distribuzione, otterrai un URL come:
https://your-project-ref.supabase.co/functions/v1/apple-signin-callbackSe non riesci a trovarlo, puoi fare le seguenti cose:
- Apri
https://supabase.com/dashboard/project/YOUR_PROJECT_REF/functions - Clicca sul
apple-signin-callbackURL della funzione per copiarlo.
- Apri
Passo 2: Configura il portale dello sviluppatore Apple
Sezione intitolata “Passo 2: Configura il portale dello sviluppatore Apple”Ora abbiamo bisogno di configurare il portale dello sviluppatore Apple con l'URL del backend e ottenere tutti i valori richiesti.
-
Segui la Guida di configurazione per Apple Login Android
Completa il guida di configurazione per Apple Login Android a:
- Crea un ID di Servizio
- Genera una chiave privata (.p8 file)
- Ottieni il tuo ID di Squadra e ID di Chiave
- Configura l'URL di ritorno
-
Imposta l'URL di ritorno nel Portale dello Sviluppatore Apple
Quando si configura l'URL di ritorno nel Portale dello sviluppatore Apple (passo 6.9 della guida Apple), utilizza l'URL della tua Funzione Edge Supabase:
https://your-project-ref.supabase.co/functions/v1/apple-signin-callbackImportante: utilizza l'URL della tua Funzione Edge Supabase
Non utilizzare l'URL di reindirizzamento dal guida di configurazione Apple Login Android. Questa guida utilizza un URL di server backend personalizzato. Per l'integrazione di Supabase, dovrai utilizzare invece l'URL della tua Funzione Edge Supabase.
-
Dopo aver completato la guida di configurazione Apple, dovresti avere:
ID DEL TEAM DI APPLE
- : Il tuo ID del team di sviluppatore Apple: L'ID della chiave da parte del portale dei sviluppatori Apple
- : La tua chiave privata .p8 (che deve essere codificata in base64): Il tuo ID di servizio Apple (ad esempio,
- APPLE_PRIVATE_KEY__CAPGO_KEEP_0__APPLE_KEY_ID__CAPGO_KEEP_0__
- APPLE_TEAM_ID__CAPGO_KEEP_0__ANDROID_SERVICE_ID__CAPGO_KEEP_0__
com.example.app.service) - BASE_REDIRECT_URL: La tua URL di link profondo (ad esempio,
capgo-demo-app://path)
Step 3: Imposta i segreti di Supabase
Sezione intitolata “Passo 3: Imposta i segreti di Supabase”Ora abbiamo bisogno di configurare le variabili di ambiente (secrets) per la Funzione Edge di Supabase.
-
Codifica la tua chiave privata
In primo luogo, codifica la tua chiave privata Apple (.p8 file) in base64:
Finestra del terminale base64 -i AuthKey_XXXXX.p8Copia l'intero output (è una stringa lunga e singola).
-
Imposta i segreti utilizzando Supabase CLI
Finestra del terminale 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 -
Alternativa: Imposta i segreti nel dashboard di Supabase
Se preferisci utilizzare il dashboard:
- Vai al tuo dashboard del progetto Supabase
- Naviga a Funzioni di Edge → Impostazioni → Segreti
- Aggiungi ogni variabile segreto con il suo valore
Passo 4: Utilizza l'helper di autenticazione
Sezione intitolata “Passo 4: Utilizza l'helper di autenticazione”Ora puoi utilizzare l'helper di autenticazione nella tua app code.
Implementazione
Sezione intitolata “Implementazione”La implementazione completa è disponibile nel file dell'applicazione di esempio. supabaseAuthUtils.ts Utilizzando l'helper di autenticazione
Sezione intitolata “Utilizzando l'helper di autenticazione”
Copia nel portapenneimport { 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);}Sezione intitolata “Aggiorna la funzione helper”
Quando si utilizza lafunzione helper, è necessario authenticateWithAppleSupabase aggiornare i seguenti valori per farli corrispondere alla tua configurazione: __CAPGO_KEEP_0__ __CAPGO_KEEP_1__
-
Aggiorna
redirectUrl- Imposta su questo il tuo URL della funzione di Edge di Supabase:const redirectUrl = platform === 'android'? 'https://your-project-ref.supabase.co/functions/v1/apple-signin-callback': undefined; -
Aggiorna
clientId- Imposta su questo il tuo ID del servizio Apple:await SocialLogin.initialize({apple: {clientId: isIOS? undefined // iOS uses bundle ID automatically: 'your.service.id.here', // Your Apple Service ID for AndroidredirectUrl: redirectUrl,},});
Vedi il implementazione completa per riferimento.
Passo 5: Testa l'integrazione
Sezione intitolata “Passo 5: Testa l'integrazione”-
Costruisci e esegui il tuo app Android
Finestra del terminale npx cap sync androidnpx cap run android -
Testa il flusso di autenticazione
- Clicca sul pulsante “Accedi con Apple”
- Dovresti vedere la pagina OAuth di Apple in un browser
- Dopo l'autenticazione, dovresti essere reindirizzato nuovamente alla tua app
- Controlla i log del console per eventuali errori
-
Verifica il flusso
Il flusso completo dovrebbe essere:
- L'utente premendo su “Accedi con Apple”
- L'app apre il browser con OAuth Apple
- L'utente si autentica con Apple
- Apple reindirizza a:
https://your-project-ref.supabase.co/functions/v1/apple-signin-callback - La funzione Edge scambia code per token
- La funzione Edge reindirizza a:
your-app://path?id_token=...&access_token=... - L'app Android riceve il link profondo e elabora il token di identità
- L'app si connette a Supabase con il token di identità
Risoluzione dei problemi
Sezione intitolata “Risoluzione dei problemi”If l'autenticazione fallisce:
- URI di reindirizzamento non corrispondente: Verifica che l'URL di ritorno nel portale dello sviluppatore Apple corrisponda esattamente con
APPLE_REDIRECT_URIsegreto - La deep link non funziona: Assicurati che
AndroidManifest.xmll'intent filter corrisponda aBASE_REDIRECT_URL - Segreti mancanti: Verifica che tutti i segreti siano impostati correttamente utilizzando
supabase secrets list - L'intercambio di token fallisce: Controlla i log dell'edge function nel dashboard di Supabase per messaggi di errore dettagliati
- L'app non riceve la callback: Assicurati che
onNewIntentsia correttamente implementato in MainActivity - Recensisci il esempio di applicazione code per riferimento
Come Funziona
Sottosezione intitolata “Come Funziona”Sul sistema Android, Apple Sign-In utilizza un flusso di reindirizzamento OAuth:
- Inizializzazione: Il plugin viene inizializzato con il tuo ID di servizio e l'URL di reindirizzamento del backend
- Flusso OAuth: Apre una finestra del browser/Tab personalizzato Chrome con la pagina OAuth di Apple
- Callback Backend: Apple reindirizza la tua Funzione Edge Supabase con un'autorizzazione code
- Scambio Token: La funzione edge scambia il code per token utilizzando il endpoint token di Apple
- Redirect a Profondità: La funzione edge reindirizza nuovamente alla tua app con il token di identità
- Autenticazione Supabase: L'app riceve il token e si connette a Supabase
Questa sequenza di passaggi è necessaria perché Apple non fornisce supporto nativo per Android per Sign in with Apple.
Continua da Supabase Apple Login on Android
Se stai utilizzandoIf you are using Login con Apple su Android per pianificare l'autenticazione e i flussi di account, connettilo con Utilizzo di @capgo/capacitor-login-social per la capacità nativa in Utilizzo di @capgo/capacitor-login-social @capgo/capacitor-login-social per la dettaglio di implementazione in @capgo/capacitor-login-social @capgo/capacitor-passkey per la dettaglio di implementazione in @capgo/capacitor-passkey @capgo/capacitor-biometrica-nativa per la dettaglio di implementazione in @capgo/capacitor-biometrica-nativa, e Autenticazione a due fattori per la dettaglio di implementazione in Autenticazione a due fattori