Configuration de connexion Google
Copiez un prompt de configuration avec les étapes d'installation et la guide markdown complet pour ce plugin.
Introduction
Section intitulée « Introduction »Dans ce guide, vous apprendrez à configurer l'authentification Google avec Capgo Social Login. Vous aurez besoin des éléments suivants pour configurer l'authentification Google :
- Un compte Google
Configuration générale
Section intitulée « Configuration générale »Dans cette partie, vous allez configurer l'écran de connexion affiché par Google.
- Veuillez vous rendre sur console.cloud.google.com
- Cliquez sur le sélecteur de projet
- Si vous n'avez pas encore de projet, veuillez créer un nouveau projet.
- Cliquez sur
New project
- Nommez votre projet et cliquez
Create
- Assurez-vous d'être sur le bon projet
- Cliquez sur
- Commencez à configurer le
OAuth consent screen-
Cliquez sur la barre de recherche
-
Recherchez
OAuth consent screenet cliquez dessus
-
Configurez l'écran de consentement
Cliquez sur
create
-
- Remplissez les informations sur votre application
-
Commencez par la
App Information
- Veuillez saisir votre
App Name - Entrez le
user support email
-
Vous PEUT ajouter le logo de l'application.
-
Vous DEVEZ configurer la section de configuration du domaine de l'application avec le champ des domaines autorisés
App domain
-
DEVEZ configurer la section de configuration du domaine de l'application avec le champ des domaines autorisés fourir l'adresse e-mail du développeur
-
Cliquez sur
save and continue
- Veuillez saisir votre
-
- Configurer les étendues
-
Cliquez sur
add or remove scopes
-
Sélectionnez les étendues suivantes et cliquez
update
-
Cliquez
save and continue
-
- Ajoutez un utilisateur de test
- Cliquez sur
add users
- Entrez votre adresse e-mail Google, cliquez sur Entrer, puis cliquez sur
add
- Cliquez
save and continue
- Cliquez sur
- Cliquez
back to dashboard
- Soumettre votre application pour la vérification
Différences entre l'accès en ligne et l'accès hors ligne
Section intitulée “Différences entre l'accès en ligne et l'accès hors ligne”Il existe plusieurs façons d'utiliser Google Login avec Capacitor. Voici une table qui résume les différences entre les deux :
| Accès en ligne | Accès hors ligne | |
|---|---|---|
| Exige un backend | ❌ | ✅ |
| Jeton d'accès longue durée | ❌ | ✅ |
| Configuration facile | ✅ | ❌ |
Si vous ne savez toujours pas lequel choisir, veuillez considérer les scénarios suivants :
-
Vous voulez que l'utilisateur se connecte, immédiatement après vous allez lui émettre un JWT personnalisé. Votre application ne fera PAS d'appels aux API Google
Dans ce cas, choisissez l'accès en ligne.
-
Votre application fera appel à certaines API Google depuis le client, mais jamais depuis le backend
Dans ce cas, choisissez l'accès en ligne
-
Votre application fera appel à certaines API Google depuis le backend, mais uniquement lorsque l'utilisateur utilise l'application activement
Dans ce cas, choisissez l'accès en ligne
-
Votre application vérifiera périodiquement le calendrier de l'utilisateur, même lorsqu'il n'utilise pas l'application
Dans ce cas, choisissez l'accès hors ligne
Un exemple de backend pour l'accès en ligne
Titre de la section « Un exemple de backend pour l'accès en ligne »Dans cette partie du tutoriel, je vais montrer comment valider l'utilisateur sur votre backend.
Cet exemple sera très simple et il sera basé sur les technologies suivantes :
Vous pouvez trouver le code pour cet exemple ici
Comme vous pouvez le voir :
L'idée est plutôt simple. Vous envoyez une requête simple à GET et cela vous retourne si le jeton est valide ou non et si c'est le cas, il vous donne l'adresse e-mail de l'utilisateur. Il vous donne également d'autres informations sur le jeton de l'utilisateur. https://www.googleapis.com/oauth2/v3/tokeninfo Cloudflare
À partir de là, vous pourriez attribuer au utilisateur votre propre JWT ou attribuer une sorte de cookie de session. Les possibilités sont infinies, pour la mise en œuvre d'authentification finale.
Si vous voulez appeler Google API’, je vous recommande fortement de regarder Google’s OAuth 2.0 PlaygroundÀ partir de là, vous pouvez facilement voir quels APIs vous pouvez appeler.
Utilisation de l'accès hors ligne avec votre propre backend
Titre de la section « Utilisation de l'accès hors ligne avec votre propre backend »Pour utiliser l'accès hors ligne, vous aurez besoin des éléments suivants :
- Un serveur HTTP
Dans cet exemple, j'utiliserai les technologies suivantes pour fournir l'accès hors ligne dans mon application :
-
LowDb (une base de données simple)
Le code pour cet exemple peut être trouvé ici
En ce qui concerne le client code, il ressemble à ceci :
import { Capacitor } from '@capacitor/core';import { GoogleLoginOfflineResponse, SocialLogin } from '@capgo/capacitor-social-login';import { usePopoutStore } from '@/popoutStore'; // <-- specific to my app
const baseURL = "[redacted]";
async function fullLogin() { await SocialLogin.initialize({ google: { webClientId: '[redacted]', iOSClientId: '[redacted]', iOSServerClientId: 'The same value as webClientId', mode: 'offline' // <-- important } }) const response = await SocialLogin.login({ provider: 'google', options: { forceRefreshToken: true // <-- important } })
if (response.provider === 'google') { const result = response.result as GoogleLoginOfflineResponse const res = await fetch(`${baseURL}/auth/google_offline`, { headers: { "Content-Type": "application/json" }, body: JSON.stringify({ serverAuthCode: result.serverAuthCode, platform: Capacitor.getPlatform() }), method: "POST" })
if (res.status !== 200) { popoutStore.popout("Full google login failed", "check console"); return }
const { jwt } = await res.json(); const userinfo = await fetch(`${baseURL}/auth/get_google_user`, { headers: { Authorization: `Bearer ${jwt}` } }) if (userinfo.status !== 200) { popoutStore.popout("Full google (userinfo) login failed", "check console"); return } popoutStore.popout("userinfo res", await userinfo.text()); }}Notez ce qui manque ici : il n'y a pas SocialLogin.refresh() appel dans l'application. C'est intentionnel. Dans le mode hors ligne de Google, la mise à jour se produit après que votre serveur échange et stocke le jeton de mise à jour de manière sécurisée. serverAuthCode Continuez de la configuration de connexion Google
Paramètres de connexion Google
Section intitulée “Continuez de Google Login Setup”Si vous utilisez Google Login Setup pour planifier l'authentification et les flux de compte, connectez-le avec En utilisant @capgo/capacitor-social-login pour la capacité native en utilisant @capgo/capacitor-social-login, @capgo/capacitor-social-login pour le détail d'implémentation en @capgo/capacitor-social-login, @capgo/capacitor-passkey pour le détail d'implémentation en @capgo/capacitor-passkey, @capgo/capacitor-native-biometric pour le détail d'implémentation en @capgo/capacitor-native-biometric, et Deux facteurs d'authentification pour le détail d'implémentation dans Deux facteurs d'authentification.