Saltare al contenuto

Supabase Google Login - Configurazione Generale

Questa guida ti guiderà attraverso l'integrazione di Google Sign-In con l'autenticazione Supabase utilizzando il plugin di login sociale Capacitor.

Prima di iniziare, assicurati di avere:

  1. Creato un progetto Supabase

  2. Letto il Setup di Google Login Generale guida per configurare le credenziali OAuth di Google

  3. Seguito le guide specifiche per piattaforma per configurare le credenziali OAuth di Google per la tua piattaforma di destinazione:

  1. Vai al tuo Pannello di controllo di Supabase

  2. Clicca sul tuo progetto

    Selettore del progetto di Supabase
  3. Vai al Authentication menu

    Menu di autenticazione di Supabase
  4. Clicca sul Providers tab

    Tabella dei provider di Supabase
  5. Trova il Google provider

    Provider Google di Supabase
  6. Abilita il provider

    Provider Google di Supabase Abilita
  7. Aggiungi gli ID client per le piattaforme che intendi utilizzare

    Supabase Provider Google Aggiungi ID Clienti
  8. Clicca sul Save tasto

    Supabase Provider Google Salva

Ecco, hai ora abilitato l'accesso con Google con l'autenticazione Supabase 🎉

Come funziona l'accesso con Google con l'aiuto dell'autenticazione Supabase

Sottosezione intitolata “Come funziona l'accesso con Google con l'aiuto dell'autenticazione Supabase”

Questa sezione spiega come funziona l'integrazione dell'accesso con Google con Supabase sotto la pelle. Comprendere questo flusso ti aiuterà a implementare e a risolvere i problemi di autenticazione.

L'implementazione genera una coppia di nonce sicura in base alle Requisiti di nonce di Supabase:

// Generate URL-safe random nonce
function getUrlSafeNonce(): string {
const array = new Uint8Array(32);
crypto.getRandomValues(array);
return Array.from(array, (byte) => byte.toString(16).padStart(2, '0')).join('');
}
// Hash the nonce with SHA-256
async function sha256Hash(message: string): Promise<string> {
const encoder = new TextEncoder();
const data = encoder.encode(message);
const hashBuffer = await crypto.subtle.digest('SHA-256', data);
const hashArray = Array.from(new Uint8Array(hashBuffer));
return hashArray.map((b) => b.toString(16).padStart(2, '0')).join('');
}
// Generate nonce pair
async function getNonce(): Promise<{ rawNonce: string; nonceDigest: string }> {
const rawNonce = getUrlSafeNonce();
const nonceDigest = await sha256Hash(rawNonce);
return { rawNonce, nonceDigest };
}

Corsa:

  • rawNonce: Stringa casuale sicura per URL (64 caratteri esadecimali)
  • nonceDigest: Hash SHA-256 di rawNonce (codificato in esadecimale)
  • nonceDigest viene passato a Google Sign-In → Google include il digest nonce nel token ID
  • rawNonce viene passato a Supabase → Supabase hasha la nonce raw e la confronta con il nonce del token

La funzione inizializza il plugin e si accede con Google:

await SocialLogin.initialize({
google: {
webClientId: 'YOUR_WEB_CLIENT_ID.apps.googleusercontent.com',
// iOS only:
iOSClientId: 'YOUR_IOS_CLIENT_ID.apps.googleusercontent.com',
mode: 'online', // Required to get idToken
},
});
const response = await SocialLogin.login({
provider: 'google',
options: {
scopes: ['email', 'profile'],
nonce: nonceDigest, // Pass the SHA-256 hashed nonce
},
});

Prima di inviare il token a Supabase, l'implementazione valuta il token JWT:

function validateJWTToken(idToken: string, expectedNonceDigest: string): { valid: boolean; error?: string } {
const decodedToken = decodeJWT(idToken);
// Check audience matches your Google Client IDs
const audience = decodedToken.aud;
if (!VALID_GOOGLE_CLIENT_IDS.includes(audience)) {
return { valid: false, error: 'Invalid audience' };
}
// Check nonce matches
const tokenNonce = decodedToken.nonce;
if (tokenNonce && tokenNonce !== expectedNonceDigest) {
return { valid: false, error: 'Nonce mismatch' };
}
return { valid: true };
}

Perché validare prima di Supabase?

La validazione del token JWT prima di inviare il token a Supabase serve diversi scopi importanti:

  1. Prevenire Richieste Non Valide: Se il token ha un'audience o un nonce errato, Supabase rifiuterà comunque il token. Validare prima evita chiamate API non necessarie e fornisce messaggi di errore più chiari.

  2. Problemi di Cache dei Token: In alcuni sistemi operativi (soprattutto iOS), Google Sign-In SDK può memorizzare i token per migliorare le prestazioni. Quando viene restituito un token memorizzato, il token memorizzato potrebbe essere stato generato con un diverso nonce (o nessun nonce), causando che Supabase rifiuti il token con un errore di “mismatch nonce”. Validando prima di inviare a Supabase, possiamo rilevare questo problema in anticipo e riprovare automaticamente con un token fresco.

  3. Security (iOS): Sulla piattaforma iOS, la validazione assicura che il token sia stato emesso per i tuoi ID Client Google specifici, prevenendo potenziali problemi di sicurezza dall'utilizzo di token destinati ad altre applicazioni.

  4. Miglioramento degli Errori: Rilevando gli errori prima di Supabase consente la logica di riprova automatica, essenziale per gestire trasparentemente le problematiche di caching iOS.

Se la validazione fallisce, la funzione si autonoma:

  1. Logga fuori da Google (elimina i token memorizzati - critico su iOS)
  2. Riprova l'autenticazione una volta (forza la generazione di un token fresco con nonce corretto)
  3. Se anche la riprova fallisce, restituisce un errore

Infine, il token validato viene inviato a Supabase:

const { data, error } = await supabase.auth.signInWithIdToken({
provider: 'google',
token: googleResponse.idToken,
nonce: rawNonce, // Pass the raw (unhashed) nonce
});

La completa implementazione è disponibile nel file dell'applicazione di esempio supabaseAuthUtils.ts che include:

  • getUrlSafeNonce() - Genera un nonce sicuro per URL
  • sha256Hash() - Cifra una stringa con SHA-256
  • getNonce() - Genera coppia nonce
  • decodeJWT() - Decodifica token JWT
  • validateJWTToken() - Valida l'audience e il nonce JWT
  • authenticateWithGoogleSupabase() - Funzione di autenticazione principale con ritentativo automatico

Per favore procedere al guide di configurazione specifica per la piattaforma di destinazione:

Continua da Supabase Google Login - Configurazione Generale

Sezione intitolata “Continua da Supabase Google Login - Configurazione Generale”

Se stai utilizzando Supabase Google Login - Configurazione Generale per pianificare l'autenticazione e le flussi di account, connettilo con Utilizza @capgo/capacitor-login-social per la capacità nativa in Utilizza @capgo/capacitor-login-social @capgo/capacitor-login-social per il dettaglio di implementazione in @capgo/capacitor-login-social @capgo/capacitor-passkey per il dettaglio di implementazione in @capgo/capacitor-passkey @capgo/capacitor-biometrica-nativa per i dettagli di implementazione in @capgo/capacitor-native-biometric, e Autenticazione a due fattori per i dettagli di implementazione in Autenticazione a due fattori.