Pular al contenido

Configuración de inicio de sesión de Google

GitHub

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 ya creado, 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 de 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. Haga clic en la barra de búsqueda

      Barra de búsqueda de Google Console
    2. Buscar por OAuth consent screen y haga clic en ella

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

      Haga clic en create

      Selección del tipo de usuario de pantalla de consentimiento de OAuth con opciones Externa y Interna
  5. Rellene la información sobre su aplicación
    1. Comencemos con la sección de información de la aplicación que muestra el campo de nombre de la aplicación y el correo electrónico de soporte del usuario App Information

      Por favor, ingrese su
      • Advertencia App Name
      • Nota 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. proporcionar la dirección de correo electrónico del desarrollador Sección de información de contacto del desarrollador con campo de correo electrónico Haz clic en

        botón Guardar y Continuar en la parte inferior del formulario
      4. Configura los alcances save and continue

        Haz clic en
  6. botón Guardar y Continuar en la parte inferior del formulario
    1. Configura los alcances 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 servidor

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

    Cuidado

  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 alguna otra información 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 echar un vistazo a

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

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í

As for the client code, it looks like this:

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 aérea 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, conecte con Usando @capgo/capacitor-login-social para la capacidad nativa en Usando @capgo/capacitor-login-social, @capgo/capacitor-social-login para los detalles de implementación en @capgo/capacitor-social-login, @capgo/capacitor-passkey para los detalles de implementación en @capgo/capacitor-passkey, @capgo/capacitor-native-biometric para los detalles de implementación en @capgo/capacitor-native-biometric, y Autenticación en dos factores para los detalles de implementación en Autenticación en dos factores.