Saltar al contenido

Inicio de sesión de Google en iOS

En esta guía, aprenderá a configurar el inicio de sesión de Google con Capgo Inicio de sesión social para iOS. Supongo que ya ha leído la guía de configuración general general setup guide.

En esta parte, aprenderás a configurar el inicio de sesión de Google en iOS.

  1. Crear un ID de cliente de iOS en la consola de Google

    1. Haga clic en la barra de búsqueda

      Barra de búsqueda de la consola de Google
    2. Buscar por credentials y haga clic en el APIs and Services uno (número 2 en la captura de pantalla)

      Resultados de búsqueda mostrando la opción de credenciales con APIs y Servicios destacados
    3. Haga clic en el create credentials

      Botón de crear credenciales en la consola de Google
    4. Seleccione OAuth client ID

      Opción de ID de cliente OAuth en menú de creación de credenciales
    5. Seleccione el Application type para iOS

      Selección de tipo de aplicación con opción de iOS destacada
    6. Encuentre el ID de la caja

      1. Abra Xcode

      2. Haga doble clic en App

        Objetivo de la aplicación en navegador de proyecto de Xcode
      3. Asegúrese de que esté en Targets -> App

        Sección de objetivos en Xcode con la aplicación seleccionada
      4. Encuentre su Bundle Identifier

        Campo de identificador de paquete en la configuración del proyecto de Xcode
      5. Vuelve a la consola de Google y pega tu Bundle Identifier en Bundle ID

        Campo de identificador de paquete en la forma de creación de cliente iOS de la consola de Google
    7. Opcionalmente, agrega tu App Store ID o Team ID en el campo de cliente ID si has publicado tu aplicación en la Tienda de Mac

    8. Después de rellenar todos los detalles, haz clic en create

      botón de crear en la parte inferior de la forma de creación de cliente iOS
    9. Haz clic en OK

      botón Aceptar en el diálogo de confirmación de cliente ID creado
    10. Abre el cliente iOS recién creado

      Nueva cliente iOS creada en la lista de credenciales
    11. Copie los siguientes datos

      Detalles del ID del cliente mostrando el ID del cliente y el ID del cliente invertido para copiar
  2. Modifique la configuración de Info.plist de su aplicación

    1. Abra Xcode y busque el archivo Info.plist archivo

      archivo Info.plist en el navegador de proyectos de Xcode
    2. Haga clic con el botón derecho en este archivo y abra como fuente code

      Menú de clic derecho mostrando la opción Abrir como fuente Code
    3. En la parte inferior de su Plist archivo, verá un </dict> etiqueta

      Etiqueta de cierre de diccionario en el archivo Info.plist
    4. Inserte el siguiente fragmento justo antes de la etiqueta de cierre </dict> archivo Info.plist con esquemas de URL __CAPGO_KEEP_0__ insertados antes de la etiqueta de cierre

      archivo Info.plist con esquemas de URL code insertados antes de la etiqueta de cierre
      <key>CFBundleURLTypes</key>
      <array>
      <dict>
      <key>CFBundleURLSchemes</key>
      <array>
      <string>YOUR_DOT_REVERSED_IOS_CLIENT_ID</string>
      </array>
      </dict>
      </array>
    5. Cambiar a YOUR_DOT_REVERSED_IOS_CLIENT_ID a el valor copiado en el paso anterior

      Info.plist con el ID del cliente real insertado en esquemas de URL
    6. Guardar el archivo con Command + S

  3. Modificar el AppDelegate.swift

    1. Abrir el AppDelegate

      Archivo AppDelegate.swift en el navegador de proyectos de Xcode
    2. Insertar import GoogleSignIn en la parte superior del archivo

      Archivo AppDelegate.swift con import de GoogleSignIn agregado
    3. Encuentre el func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey: Any] = [:]) función

      Función de apertura de la aplicación original en AppDelegate
    4. Modifique la función para que tenga este aspecto

      func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey: Any] = [:]) -> Bool {
      // Called when the app was launched with a url. Feel free to add additional processing here,
      // but if you want the App API to support tracking app url opens, make sure to keep this call
      var handled: Bool
      handled = GIDSignIn.sharedInstance.handle(url)
      if handled {
      return true
      }
      return ApplicationDelegateProxy.shared.application(app, open: url, options: options)
      }
      Función de apertura de la aplicación modificada con manejo de GoogleSignIn
    5. Guardar el archivo con Command + S

  4. Configurar inicio de sesión de Google en su JavaScript/TypeScript code

    1. Importar SocialLogin y Capacitor

      import { SocialLogin } from '@capgo/capacitor-social-login';
      import { Capacitor } from '@capacitor/core';
    2. Llamar al método initialize (debe llamarse solo una vez)

      Configuración básica (modo en línea - recomendado para la mayoría de las aplicaciones):

      // onMounted is Vue specific
      onMounted(() => {
      SocialLogin.initialize({
      google: {
      iOSClientId: '673324426943-redacted.apps.googleusercontent.com',
      mode: 'online' // Default mode
      }
      })
      })

      Configuración avanzada con IDs de cliente adicionales:

      onMounted(() => {
      SocialLogin.initialize({
      google: {
      webClientId: 'YOUR_WEB_CLIENT_ID', // Optional: for web platform support
      iOSClientId: 'YOUR_IOS_CLIENT_ID', // Required: from step 1
      iOSServerClientId: 'YOUR_WEB_CLIENT_ID', // Optional: same as webClientId, needed for some advanced features
      mode: 'online' // 'online' or 'offline'
      }
      })
      })
    3. Implement the login function. Create a button and run the following code on click

      comando __CAPGO_KEEP_0__ al hacer clic

      const res = await SocialLogin.login({
      provider: 'google',
      options: {}
      })
      // handle the response - contains user data
      console.log(JSON.stringify(res))

      Para modo offline:

      const res = await SocialLogin.login({
      provider: 'google',
      options: {
      forceRefreshToken: true // Recommended for offline mode
      }
      })
      // res contains serverAuthCode, not user data
      // Send serverAuthCode to your backend to get user information
      // Do not call SocialLogin.refresh() in offline mode
      console.log('Server auth code:', res.result.serverAuthCode)
  5. Prueba tu aplicación

    1. Construye tu aplicación y ejecútala cap sync

    2. Si has hecho todo correctamente, deberías ver el flujo de inicio de sesión de Google funcionando correctamente

      Demostración del flujo de inicio de sesión de Google en iOS mostrando el proceso de inicio de sesión y autenticación exitosa

Incompatibilidad del plugin de pantalla de privacidad

Sección titulada “Incompatibilidad del plugin de pantalla de privacidad”

El plugin de inicio de sesión de Google es incompatible con @capacitor/privacy-screenAl utilizar ambos plugins juntos, el navegador de inicio de sesión de Google se interrumpirá por la pantalla de privacidad.

Solución alternativa: Llamar a await PrivacyScreen.disable(); antes de llamar a la función de inicio de sesión:

import { PrivacyScreen } from '@capacitor/privacy-screen';
import { SocialLogin } from '@capgo/capacitor-social-login';
await PrivacyScreen.disable();
await SocialLogin.login({
provider: 'google',
options: {}
});