Pular al contenido

Configuración de inicio de sesión de Google

En esta guía, aprenderá a configurar el inicio de sesión de Google con Capgo Inicio de sesión social. Necesitará lo siguiente para configurar el inicio de sesión de Google:

  • Una cuenta de Google

En esta parte, configurará la pantalla de inicio de sesión que muestra Google.

  1. Por favor, vaya a console.cloud.google.com
  2. Haz clic en el selector de proyecto Selector de proyecto de Google Console
  3. Si no tienes un proyecto creado ya, por favor crear un nuevo proyecto.
    1. Haz clic en New project Botón de nuevo proyecto en Google Console
    2. Nombra tu proyecto y haz clic Create Pantalla de nombre del proyecto mostrando campo de nombre y botón de crear
    3. Asegúrate de que estás en el proyecto correcto Nombre de proyecto mostrando en el selector indicando selección de proyecto correcta
  4. Comienza a configurar el OAuth consent screen
    1. Haz clic en la barra de búsqueda

      Barra de búsqueda de Google Console
    2. Búsqueda de OAuth consent screen haz clic en ella

      Resultados de búsqueda mostrando opción de pantalla de consentimiento de OAuth
    3. Configura la pantalla de consentimiento

      Haz clic en create

      Selección del tipo de usuario de pantalla de consentimiento de OAuth con opciones de Exterior e Interno
  5. Rellene la información sobre su aplicación
    1. Comencemos con la sección App Information

      Información de la aplicación mostrando el campo de nombre de la aplicación y correo electrónico de soporte del usuario
      • Por favor, escriba su App Name
      • Ingrese el user support email
      1. Usted PUEDE agregar el logo de la aplicación.

        Sección de carga de logo de la aplicación en pantalla de consentimiento de OAuth
      2. Usted DEBE configurar el App domain

        Sección de configuración de dominio de la aplicación con campo de dominios autorizados
      3. Sección de información de contacto del desarrollador con campo de correo electrónico Haz clic en Botón de guardar y continuar en la parte inferior del formulario

        Configura los alcances
      4. Haz clic en save and continue

        Botón de guardar y continuar en la parte inferior del formulario
  6. Configura los alcances
    1. Haz clic en add or remove scopes

      Botón de agregar o eliminar ámbitos en la pantalla de configuración de ámbitos
    2. Seleccione los siguientes ámbitos y haga clic update

      Diálogo de selección de ámbitos con ámbitos de correo electrónico y perfil seleccionados
    3. Haga clic save and continue

      Botón de guardar y continuar en la pantalla de ámbitos
  7. Agregar un usuario de prueba
    1. Haga clic en add users Botón de agregar usuarios en la sección de usuarios de prueba
    2. Ingrese su correo electrónico de Google, haga clic en ingresar y haga clic add Campo de entrada de correo electrónico y botón de agregar para usuarios de prueba
    3. Haga clic save and continue Botón de guardar y continuar en la pantalla de usuarios de prueba
  8. Haga clic back to dashboard Botón de regreso a la consola en la parte inferior de la página de finalización
  9. Enviar su aplicación para su verificación

Diferencias entre acceso en línea y acceso sin conexión

Sección titulada “Diferencias entre acceso en línea y acceso sin conexión”

Hay varias formas de utilizar el inicio de sesión de Google con Capacitor. Aquí hay una tabla que resume las diferencias entre los dos:

Acceso en líneaAcceso offline
Requiere un backend
Token de acceso de larga duración
Configuración fácil

Quieres que el usuario se registre, inmediatamente después vas a emitirle un JWT personalizado. Tu aplicación NO llamará a las API de Google

  1. En este caso, elige acceso en línea.

    Tu aplicación llamará a algunas API de Google desde el cliente, pero nunca desde el backend

  2. En este caso, elige acceso en línea

    Si todavía no sabes cuál debes elegir, por favor considera los siguientes escenarios:

  3. Tu aplicación llamará a algunas APIs de Google desde el backend, pero solo cuando el usuario esté utilizando activamente la aplicación

    En este caso, elige el acceso en línea

  4. Tu aplicación verificará periódicamente el calendario del usuario, incluso cuando no esté utilizando activamente la aplicación

    En este caso, elige el acceso en línea

En esta parte del tutorial, mostraré cómo validar al usuario en su backend.

Este ejemplo será muy simple y se basará en las siguientes tecnologías:

Puedes encontrar el code para este ejemplo As puedes ver:

VS __CAPGO_KEEP_0__ mostrando autenticación de Google __CAPGO_KEEP_1__ que verifica tokens

VS Code showing Google authentication code that verifies tokens

y esto te devuelve si el token es válido o no y si lo es, te da el correo electrónico del usuario. También te da algunas otras informaciones sobre el token del usuario GET Google OAuth Playground mostrando información de respuesta de token con detalles del usuario https://www.googleapis.com/oauth2/v3/tokeninfo Desde allí, podrías emitir al usuario con tu propio JWT o emitir alguna clase de cookie de sesión. Las posibilidades son infinitas, para la implementación de autenticación final.

Si deseas llamar a Google __CAPGO_KEEP_0__’, te recomendaría fuertemente que mires en

Google’s OAuth 2.0 Playground

If you do want to call Google API’s, I would strongly recommend looking at Usando acceso offline con tu propio backendhere

Desde allí, podrías emitir al usuario con tu propio JWT o emitir alguna clase de cookie de sesión. Las posibilidades son infinitas, para la implementación de autenticación final.

Sección titulada “Usando acceso en línea con tu propio backend”

Para usar el acceso en línea necesitarás lo siguiente:

  • Un servidor HTTP

En este ejemplo, utilizaré las siguientes tecnologías para proporcionar el acceso en línea en mi aplicación:

El code para este ejemplo se puede encontrar aquí

Para el cliente code, se ve así:

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

Fíjese en lo que falta aquí: no hay SocialLogin.refresh() llamada en la aplicación. Eso es intencional. En modo de línea de tiempo de Google, el refresco ocurre después de que su servidor intercambia serverAuthCode y almacena el token de refresco de manera segura.

Siga adelante desde Configuración de inicio de sesión de Google

Sección titulada “Siga adelante desde Configuración de inicio de sesión de Google”

Si está utilizando Configuración de inicio de sesión de Google para planificar la autenticación y los flujos de cuenta, conéctela con Usando @capgo/capacitor-login-social para la capacidad nativa en Usando @capgo/capacitor-login-social, @capgo/capacitor-iniciación-social para el detalle de implementación en @capgo/capacitor-iniciación-social, @capgo/capacitor-clave-llave para el detalle de implementación en @capgo/capacitor-clave-llave, @capgo/capacitor-biometría-nativa para el detalle de implementación en @capgo/capacitor-biometría-nativa, y Autenticación de dos factores para el detalle de implementación en Autenticación de dos factores.