Passer à la section principale

Migration d'authentification Google à @capgo/social-login

GitHub

Cette guide fournit des étapes complètes pour la migration de @codetrix-studio/capacitor-google-auth à @capgo/capacitor-social-login, garantissant une transition fluide et une expérience d'authentification améliorée. Le nouveau plugin unifie plusieurs fournisseurs d'authentification sociale sous un seul et même API.

  1. Supprimer l'ancien package :

    Fenêtre de terminal
    npm uninstall @codetrix-studio/capacitor-google-auth
  2. Installer le nouveau package :

    Fenêtre de terminal
    npm install @capgo/capacitor-social-login
    npx cap sync

Changements importants dans la configuration de l'authentification Google

Section intitulée « Changements importants dans la configuration de l'authentification Google »

Modification Critique: La mise à jour du plugin nécessite l'utilisation d'un ID de client Web sur tous les plateformes.

Vous aurez besoin de :

  1. Créez un ID de client Web dans le Console de Google Cloud si vous n'en avez pas un (Comment obtenir les informations d'identification)
  2. Utilisez cet ID de client Web dans le webClientId champ pour toutes les plateformes
  3. Pour Android, vous devez toujours créer un ID de client Android avec votre SHA1, mais cela est uniquement pour des raisons de vérification - le jeton ne sera pas utilisé (Guide de configuration Android)
import { GoogleAuth } from '@codetrix-studio/capacitor-google-auth';
import { SocialLogin } from '@capgo/capacitor-social-login';

La configuration de mise en place passe d'une simple GoogleAuth.initialize() appel à une structure plus complexe SocialLogin.initialize() avec une configuration Google imbriquée :

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
}
});

La méthode de connexion change de GoogleAuth.signIn() à SocialLogin.login() avec une spécification explicite du fournisseur :

const user = await GoogleAuth.signIn();
const res = await SocialLogin.login({
provider: 'google',
options: {
scopes: ['email', 'profile'],
forceRefreshToken: true // if you need refresh token
}
});
  1. Mettez à jour votre MainActivity.java (Guide complet de configuration d'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. Aucun changement majeur nécessaire dans AppDelegate.swift (guide de configuration iOS)

  2. Mettez à jour votre configuration dans capacitor.config.jsonNous ne l'utilisons pas dans le nouveau plugin :

{
"plugins": {
"GoogleAuth": {
"scopes": ["profile", "email"],
"serverClientId": "xxxxxx-xxxxxxxxxxxxxxxxxx.apps.googleusercontent.com",
"forceCodeForRefreshToken": true
}
}
  1. Supprimez les balises de connexion Google Sign-In de votre index.html Si vous les utilisiez :
<meta name="google-signin-client_id" content="{your client id here}" />
<meta name="google-signin-scope" content="profile email" />

La réponse d'authentification fournit maintenant un objet structuré contenant des informations de fournisseur, des jetons d'accès, des jetons d'ID et des données de profil d'utilisateur :

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 structure de réponse comprend :

  • fournisseur: Identifie le fournisseur d'authentification ('google')
  • result.accessToken: Détails du jeton d'accès avec expiration
  • result.idToken: Jeton d'identification pour l'authentification
  • result.profile: Informations de profil de l'utilisateur, y compris l'adresse e-mail, le nom et l'URL de l'image

The new package supports multiple social authentication providers beyond Google:

Cette approche unifiée offre:

  • Une expérience cohérente API sur tous les fournisseurs
  • Une meilleure prise en charge de TypeScript
  • Une meilleure gestion des erreurs
  • Un support actif et une communauté active

Consultez la documentation principale pour des instructions de mise en œuvre détaillées pour ces fournisseurs supplémentaires.

Continuez de la migration d'authentification Google à @capgo/social-login

Continuez de la migration d'authentification Google à @capgo/social-login

Si vous utilisez La migration d'authentification Google à @capgo/social-login pour planifier les flux d'authentification et de compte, connectez-le avec Utilisez @capgo/capacitor-social-login pour la capacité native dans Utilisez @capgo/capacitor-social-login Utilisez @capgo/capacitor-social-login pour le détail d'implémentation dans @capgo/capacitor-social-login Utilisez @capgo/capacitor-passkey pour le détail d'implémentation dans @capgo/capacitor-passkey Utilisez @capgo/capacitor-native-biometric pour le détail d'implémentation dans @capgo/capacitor-native-biometric Authentification à deux facteurs pour le détail d'implémentation dans Authentification à deux facteurs.