Migration d'authentification Google vers @capgo/social-login
Copier un prompt de configuration avec les étapes d'installation et le guide Markdown complet pour ce plugin.
Vue d'ensemble
Sous-section intitulée « Vue d'ensemble »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 cohérent API.
Installation
Sous-section intitulée « Installation »-
Supprimez l'ancien package :
Fenêtre de terminal npm uninstall @codetrix-studio/capacitor-google-auth -
Installer le nouveau package :
Fenêtre de terminal npm install @capgo/capacitor-social-loginnpx cap sync
Changements importants dans la configuration de l'authentification Google
Section intitulée “Changements importants dans la configuration de l'authentification Google”Exigence de l'ID du client Web
Section intitulée “Exigence de l'ID du client Web”Changement critique: La mise à jour du plugin nécessite l'utilisation d'un ID du client Web sur tous les plateformes.
Vous devrez :
- Créez un ID de client Web dans le console Google Cloud si vous n'en avez pas (Comment obtenir les informations d'identification)
- Utilisez cet ID de client Web dans le
webClientIdchamp pour tous les plateformes - 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)
Code Modifications
Section intitulée “Code Modifications”Importer les modifications
Section intitulée “Importer les modifications”import { GoogleAuth } from '@codetrix-studio/capacitor-google-auth';import { SocialLogin } from '@capgo/capacitor-social-login';Initialisation
Section intitulée “Initialisation”Le setup évolue d'un appel simple GoogleAuth.initialize() vers 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 }});Se connecter
Section intitulée “Se connecter”La méthode de connexion passe 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 }});Changements spécifiques aux plateformes
Section intitulée « Changements spécifiques au plateforme »- 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() {}}-
Aucun changement majeur n'est nécessaire dans AppDelegate.swift (Guide de configuration d'iOS)
-
Mettez à jour votre configuration dans
capacitor.config.json, nous ne l'utilisons pas dans le nouveau plugin :
{ "plugins": { "GoogleAuth": { "scopes": ["profile", "email"], "serverClientId": "xxxxxx-xxxxxxxxxxxxxxxxxx.apps.googleusercontent.com", "forceCodeForRefreshToken": true }}- Supprimez les balises de signe de Google de votre
index.htmlsi vous les utilisiez :
<meta name="google-signin-client_id" content="{your client id here}" /><meta name="google-signin-scope" content="profile email" />Changements de type de réponse
Section intitulée « Changements de type de réponse »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 la réponse comprend :
- fournisseur: Identifie le fournisseur d'authentification (
'google') - result.accessToken: Détails de l'access token avec expiration
- result.idToken: Jeton d'identification pour l'authentification
- result.profile: Informations de profil de l'utilisateur incluant l'e-mail, le nom et l'URL de l'image
Capacités supplémentaires
Section intitulée « Capacités supplémentaires »Le nouveau package prend en charge plusieurs fournisseurs d'authentification sociale au-delà de Google :
Cette approche unifiée fournit :
- Un API cohérent sur tous les fournisseurs
- Une meilleure prise en charge de TypeScript
- Une meilleure gestion des erreurs
- Un entretien actif et un soutien communautaire
Vérifiez le documentation principale pour les instructions de configuration détaillées pour ces fournisseurs supplémentaires.
Continuez de la migration d'authentification Google à @capgo/social-login
Section intitulée “Continuez de la migration d'authentification Google à @capgo/social-login”Si vous utilisez la migration d'authentification Google à @capgo/social-login pour planifier l'authentification et les flux de compte, connectez-le avec Utilisation de @capgo/capacitor-social-login pour le capacité native dans Utilisation de @capgo/capacitor-social-login, @capgo/capacitor-social-login pour le détail d'implémentation dans @capgo/capacitor-social-login, @capgo/capacitor-passkey pour le détail d'implémentation dans @capgo/capacitor-passkey, @capgo/capacitor-native-biometric pour le détail d'implémentation dans @capgo/capacitor-native-biometric, et L'authentification à deux facteurs pour le détail d'implémentation dans L'authentification à deux facteurs.