Saltare al contenuto

Migrare l'autenticazione di Google a @capgo/social-login

GitHub

Questa guida fornisce passaggi dettagliati per la migrazione da @codetrix-studio/capacitor-google-auth a @capgo/capacitor-social-login, garantendo una transizione liscia e un'esperienza di autenticazione migliorata. Il nuovo plugin unifica i provider di autenticazione sociale multipli sotto un singolo e coerente API.

  1. Elimina il vecchio pacchetto:

    Finestra del terminale
    npm uninstall @codetrix-studio/capacitor-google-auth
  2. Installa il nuovo pacchetto:

    Finestra del terminale
    npm install @capgo/capacitor-social-login
    npx cap sync

Modifiche importanti nella configurazione di autenticazione di Google

Sezione intitolata “Modifiche importanti nella configurazione di autenticazione di Google”

Cambiamento Critico : L'aggiornamento del plugin richiede l'utilizzo di un ID del Client Web su tutti i piattaforme.

Avrai bisogno di:

  1. Creare un ID del Client Web nel Console di Google Cloud se non ne hai già uno (Come ottenere le credenziali)
  2. Utilizzare questo ID del Client Web nel webClientId campo per tutte le piattaforme
  3. Per Android, tuttavia, è ancora necessario creare un ID del Client Android con il tuo SHA1, ma questo è solo a scopo di verifica - il token non verrà utilizzato (Guida di configurazione per Android)
import { GoogleAuth } from '@codetrix-studio/capacitor-google-auth';
import { SocialLogin } from '@capgo/capacitor-social-login';

La configurazione di avvio si trasforma da una semplice GoogleAuth.initialize() chiamata a una struttura più complessa SocialLogin.initialize() con configurazione Google nidificata:

GoogleAuth.initialize({
clientId: 'CLIENT_ID.apps.googleusercontent.com',
scopes: ['profile', 'email'],
grantOfflineAccess: true,
});
await SocialLogin.initialize({
google: {
webClientId: 'WEB_CLIENT_ID.apps.googleusercontent.com', // Use Web Client ID for all platforms
iOSClientId: 'IOS_CLIENT_ID', // for iOS
mode: 'offline' // replaces grantOfflineAccess
}
});

Il metodo di accesso cambia da GoogleAuth.signIn() a SocialLogin.login() con specificazione esplicita del provider:

const user = await GoogleAuth.signIn();
const res = await SocialLogin.login({
provider: 'google',
options: {
scopes: ['email', 'profile'],
forceRefreshToken: true // if you need refresh token
}
});
  1. Aggiorna il tuo MainActivity.java (Guida completa per la configurazione di Android):
import ee.forgr.capacitor.social.login.GoogleProvider;
import ee.forgr.capacitor.social.login.SocialLoginPlugin;
import ee.forgr.capacitor.social.login.ModifiedMainActivityForSocialLoginPlugin;
import com.getcapacitor.PluginHandle;
import com.getcapacitor.Plugin;
import android.content.Intent;
import android.util.Log;
public class MainActivity extends BridgeActivity {
public class MainActivity extends BridgeActivity implements ModifiedMainActivityForSocialLoginPlugin {
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode >= GoogleProvider.REQUEST_AUTHORIZE_GOOGLE_MIN && requestCode < GoogleProvider.REQUEST_AUTHORIZE_GOOGLE_MAX) {
PluginHandle pluginHandle = getBridge().getPlugin("SocialLogin");
if (pluginHandle == null) {
Log.i("Google Activity Result", "SocialLogin login handle is null");
return;
}
Plugin plugin = pluginHandle.getInstance();
if (!(plugin instanceof SocialLoginPlugin)) {
Log.i("Google Activity Result", "SocialLogin plugin instance is not SocialLoginPlugin");
return;
}
((SocialLoginPlugin) plugin).handleGoogleLoginIntent(requestCode, data);
}
}
public void IHaveModifiedTheMainActivityForTheUseWithSocialLoginPlugin() {}
}
  1. Nessuna modifica importante è necessaria in AppDelegate.swift (Guida di configurazione per iOS)

  2. Aggiorna la tua configurazione in capacitor.config.jsonNon lo utilizziamo nel nuovo plugin:

{
"plugins": {
"GoogleAuth": {
"scopes": ["profile", "email"],
"serverClientId": "xxxxxx-xxxxxxxxxxxxxxxxxx.apps.googleusercontent.com",
"forceCodeForRefreshToken": true
}
}
  1. Elimina le mete di segno Google da i tuoi index.html Se li stavi utilizzando:
<meta name="google-signin-client_id" content="{your client id here}" />
<meta name="google-signin-scope" content="profile email" />

La risposta di autenticazione fornisce ora un oggetto strutturato contenente informazioni sul provider, i token di accesso, i token ID e i dati del profilo utente:

interface GoogleLoginResponse {
provider: 'google';
result: {
accessToken: {
token: string;
expires: string;
// ... other token fields
} | null;
idToken: string | null;
profile: {
email: string | null;
familyName: string | null;
givenName: string | null;
id: string | null;
name: string | null;
imageUrl: string | null;
};
};
}

La struttura della risposta include:

  • provider: Identifica il provider di autenticazione ('google')
  • result.accessToken: Dettagli del token di accesso con scadenza
  • result.idToken: Token ID per l'autenticazione
  • result.profile: Informazioni del profilo dell'utente, compreso l'indirizzo email, il nome e l'URL dell'immagine

The new package supports multiple social authentication providers beyond Google:

Questa approccio unificato fornisce:

  • Consistenza API su tutti i provider
  • Miglior supporto per TypeScript
  • Miglior gestione degli errori
  • Sostegno attivo e comunitario

Controlla il documento principale per le istruzioni di configurazione dettagliate per questi provider aggiuntivi.

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