__CAPGO_KEEP_0__ - Actualizaciones en vivo para aplicaciones __CAPGO_KEEP_1__

Iniciar sesión con Apple en Android

El inicio de sesión de Apple en Android es engañoso. Apple no ofrece soporte oficial para Sign in with Apple en Android, por lo que la solución es ligeramente engañosa.

Actualmente, Android utiliza una pestaña de Chrome para mostrar un sitio web OAuth2. Esta aproximación tiene los desafíos:

  • Configuración difícil
  • Se requiere un backend

Déjame usar un diagrama para explicar el flujo en Android:

Ahora que estás al tanto de los desafíos y el flujo, comencemos la configuración.

  1. Inicia sesión en el Portal de desarrolladores de Apple.

  2. Haga clic en Identifiers.

    Sección de identificadores del Portal de desarrolladores de Apple

    Deberías ver una pantalla que se parece a esta:

    Pantalla de identificadores del Portal de desarrolladores de Apple
    1. Asegúrese de que este campo diga App IDs
    2. Asegúrese de que pueda encontrar su ID de aplicación.
  3. Asegúrese de que la Sign in with Apple capacidad esté habilitada para su aplicación

    1. Haga clic en su aplicación Seleccionar su aplicación de la lista
    2. Asegúrese de que Sign in with Apple __CAPGO_KEEP_0__ es habilitado Habilitar la capacidad de inicio de sesión con Apple
    3. Si no está habilitado, habilítelo.
  4. Volver a todos All Identifiers

    Botón de navegación de todos los identificadores
  5. Haga clic en App Ids y vaya a Services IDs

    Navegación a la sección de IDs de servicios
  6. Crear un nuevo identificador

    1. Haga clic en el botón de más

      Botón de agregar nuevo ID de servicio
    2. Seleccionar Servcice IDs y haz clic Continue

      Opción de selección de IDs de servicio
    3. Introduzca una descripción y un identificador y haz clic Continuie.

      Introduciendo detalles del ID de servicio
    4. Por favor, verifica los detalles y haz clic en Register

      Confirmación de registro del ID de servicio
    5. Haz clic en el servicio creado recientemente

      Seleccionar el nuevo ID de servicio creado
    6. Habilitar la Sign in with Apple opción

      Habilitar inicio de sesión con Apple para el ID de servicio
    7. Configurar el Sign In with Apple

      Configurar el botón para inicio de sesión con Apple
    8. Asegúrate de que el Primary App ID esté configurado en el ID de App configurado en el paso anterior

      Configuración del ID principal de la aplicación
    9. Agregar el dominio en el que vas a alojar tu backend.

      Configuración de campos de dominio y URL de retorno
    10. Confirmar los datos y haga clic en Done

      Confirmación de configuración de dominio y URL de retorno
    11. Haga clic en Continue

      Botón de continuación para la configuración del servicio
    12. Haga clic en Save

      Botón de guardar para la configuración del servicio
  1. Volver a todos All Identifiers

    Botón de navegación de todos los identificadores
  2. Haz clic en Keys

    Sección de claves en el Portal de Desarrolladores de Apple
  3. Haz clic en el icono de más

    Botón de agregar nueva clave
  4. Nombra tu clave

    Campo de ingreso del nombre de la clave
  5. Seleccionar Sign in with Apple y haz clic Configure

    Habilitar y configurar Iniciar sesión con Apple para la clave
  6. Seleccionar la App ID principal, y presionar Save

    Seleccionar App ID principal para la clave
  7. Haz clic en Continue

    Botón Continuar para la configuración de la clave
  8. Haz clic en Register

    Botón Registrar para la creación de la clave
  9. Copiar la ID de la clave y descargar la clave.

    Pantalla de ID de clave y botón de descarga
  10. Encuentre el archivo de clave descargado y guarde en el carpeta de backend.

    Archivo de clave descargado

Para utilizar Login with Apple en Android, necesita obtener el Team ID. Se utilizará en el backend.

  1. Ir a esta página web y desplázate hacia abajo

  2. Encuentra la Team ID

    ubicación de la ID de equipo en la cuenta de desarrollador

Configuración de la redirección de la aplicación

Sección titulada “Configuración de la redirección de la aplicación”

Como viste en el diagrama, el backend realiza un paso llamado Redirect back to the app. Esto requiere cambios manuales en tu aplicación.

  1. Modificar el AndroidManifest.xml
    1. Abre el archivo, utilizaré AndroidStudio

      archivo AndroidManifest.xml en Android Studio
    2. Encuentre el MainActivity y agregue el siguiente filtro de intención

      Filtro de intención code para agregar en MainActivity
      <intent-filter>
      <action android:name="android.intent.action.VIEW" />
      <category android:name="android.intent.category.DEFAULT" />
      <category android:name="android.intent.category.BROWSABLE" />
      <data android:scheme="capgo-demo-app" android:host="path" />
      </intent-filter>
  2. Modificar el MainActivity
    1. Por favor, abra el MainActivity

      archivo MainActivity.java en Android Studio
    2. Agregue el siguiente code:

      Code para agregar a MainActivity para manejar enlaces profundos
      @Override
      protected void onNewIntent(Intent intent) {
      String action = intent.getAction();
      Uri data = intent.getData();
      if (Intent.ACTION_VIEW.equals(action) && data != null) {
      PluginHandle pluginHandle = getBridge().getPlugin("SocialLogin");
      if (pluginHandle == null) {
      Log.i("Apple Login Intent", "SocialLogin login handle is null");
      return;
      }
      Plugin plugin = pluginHandle.getInstance();
      if (!(plugin instanceof SocialLoginPlugin)) {
      Log.i("Apple Login Intent", "SocialLogin plugin instance is not SocialLoginPlugin");
      return;
      }
      ((SocialLoginPlugin) plugin).handleAppleLoginIntent(intent);
      return;
      }
      super.onNewIntent(intent);
      }

Se requiere un backend para Android, pero configurar un backend también afectará a IOS. Se proporciona un ejemplo de backend aquí

Este ejemplo proporciona lo siguiente:

  • Una base de datos JSON simple
  • Una forma de solicitar el JWT de los servidores de Apple
  • Una verificación de JWT simple

Dado todo lo que dije en este tutorial, aquí está cómo se vería la env sección:

  • ANDROID_SERVICE_ID = ID de Servicio
  • IOS_SERVICE_ID = ID de Aplicación
env: {
PRIVATE_KEY_FILE: "AuthKey_U93M8LBQK3.p8",
KEY_ID: "U93M8LBQK3",
TEAM_ID: "UVTJ336J2D",
ANDROID_SERVICE_ID: "ee.forgr.io.ionic.starter.service2",
IOS_SERVICE_ID: "me.wcaleniewolny.test.ionic.vue",
PORT: 3000,
REDIRECT_URI: "https://xyz.wcaleniewolny.me/login/callback",
BASE_REDIRECT_URL: "capgo-demo-app://path"
}

El uso de la login función no cambia, es lo mismo que IOS. Por favor, consulte esa sección para obtener más información. Sin embargo, el initialize método cambia un poco.

await SocialLogin.initialize({
apple: {
clientId: 'ee.forgr.io.ionic.starter.service2',
redirectUrl: 'https://appleloginvps.wcaleniewolny.me/login/callback'
}
})
  1. Si no tienes un ID de aplicación, haz clic en el botón de más

    Agregar nuevo identificador con botón de más
  2. Seleccionar App IDs y hacer clic en continuar

    Seleccionar tipo de ID de la aplicación
  3. Hacer clic en tipo App y hacer clic Continue

    Seleccionar tipo de aplicación
  4. Introducir la descripción y el ID de la aplicación

    Introducir descripción de la aplicación y ID de paquete
  5. Habilitar Sign with Apple capacidad

    Habilitar capacidad de inicio de sesión con Apple
  6. Haga clic Continue

    Botón de continuación para la inscripción de la aplicación
  7. Confirme los detalles y haga clic Register

    Confirmación de detalles de inscripción de la aplicación