Perfiles de dispositivos complementarios

El perfil del dispositivo complementario, introducido en Android 12, es una función que permite que las aplicaciones complementarias soliciten un conjunto de permisos específicos para el tipo de dispositivo complementario, por ejemplo, un reloj inteligente. El uso de un perfil de dispositivo complementario simplifica el proceso de inscripción al permitir que las aplicaciones muestren un solo aviso a los usuarios en sus dispositivos móviles para solicitar un conjunto definido de permisos en lugar de múltiples avisos solicitando permisos individualmente. Esto puede permitir una experiencia de configuración más optimizada y mejores tasas de participación para las aplicaciones complementarias.

El uso de perfiles de dispositivos complementarios solo está disponible para los fabricantes de dispositivos que tienen dispositivos complementarios. Para que los dispositivos complementarios obtengan acceso a la función, deben cumplir con los requisitos y ser aprobados.

Los siguientes tipos de perfiles de dispositivos complementarios están disponibles en Android 12: COMPANION_DEVICE_WATCH .

Para obtener más información acerca de los dispositivos complementarios, consulte Emparejamiento de dispositivos complementarios .

Comportamiento del dispositivo

Esta sección describe el comportamiento del dispositivo cuando se utilizan perfiles de dispositivos complementarios.

Cuando un usuario acepta la solicitud de una aplicación para crear una asociación con un dispositivo complementario, el servicio CompanionDeviceManager (CDM) espera a que el dispositivo complementario se conecte y, cuando se conecta, el CDM asigna la función de perfil del dispositivo (por ejemplo, observar) al aplicación complementaria, otorgando todos los permisos definidos para ese rol de perfil especificado. La figura 1 muestra un ejemplo de una aplicación que solicita permisos para el perfil de dispositivo COMPANION_DEVICE_WATCH .

Visualización del cuadro de diálogo del perfil del dispositivo

Figura 1. Diálogo solicitando permisos para el perfil del dispositivo de vigilancia.

Cuando se elimina la asociación entre una aplicación y el dispositivo complementario, por ejemplo, cuando se borran los datos de un paquete o cuando se olvida un dispositivo, CDM revoca la función de perfil de dispositivo para la aplicación, lo que elimina todos los permisos definidos para la función de perfil. de la aplicación

Después de que un usuario acepta la solicitud de una aplicación para otorgar permisos para un perfil de dispositivo en particular, el usuario puede revocar los permisos individuales que se otorgaron. Cuando un usuario revoca un permiso, la aplicación permanece asociada con el dispositivo complementario, pero es posible que ciertas funciones dejen de estar disponibles. Si se requiere el permiso para que la aplicación funcione, la aplicación debe solicitar el permiso a través de una solicitud de permiso normal.

Requisitos

Para que una aplicación complementaria obtenga acceso a la API del perfil del dispositivo complementario, la aplicación debe cumplir con los siguientes requisitos:

  • Tener un dispositivo complementario (por ejemplo, un reloj inteligente).
  • Tener un motivo legítimo para solicitar los permisos definidos para el perfil del dispositivo complementario.

Mire los requisitos del perfil del dispositivo complementario

La siguiente tabla describe los permisos definidos para la función de perfil de dispositivo COMPANION_DEVICE_WATCH y los requisitos para usarlos.

permisos Requisitos de dispositivos y aplicaciones complementarias
Notificaciones

BIND_NOTIFICATION_LISTENER_SERVICE
  • Ser un dispositivo conectado mediante Bluetooth y/o Wi-Fi
  • Tiene una pantalla capaz de mostrar notificaciones (se excluyen los dispositivos que usan hápticos en lugar de una pantalla)
  • Brinda una experiencia de notificación orientada al usuario, por ejemplo, mostrando notificaciones telefónicas en la pantalla del dispositivo complementario.
Teléfono

phone
  • Ser un dispositivo conectado mediante Bluetooth y/o Wi-Fi
  • Tiene un micrófono y un altavoz incorporados que permiten la conversación de voz
  • Tiene una pantalla que muestra la información de la persona que llama
  • Proporciona una experiencia de llamada telefónica orientada al usuario (la aplicación complementaria une las llamadas telefónicas)
SMS

sms
  • Ser un dispositivo conectado mediante Bluetooth y/o Wi-Fi
  • Tiene una pantalla que muestra mensajes SMS
  • Proporcione una experiencia de SMS orientada al usuario
Contactos

contacts
  • Ser un dispositivo conectado mediante Bluetooth y/o Wi-Fi
  • Tiene una pantalla de visualización
  • Utiliza la información de contacto como parte de la experiencia de llamadas o mensajes.
Calendario

calendar
  • Ser un dispositivo conectado mediante Bluetooth y/o Wi-Fi
  • Tiene una pantalla de visualización
  • Proporcione una experiencia de calendario orientada al usuario en el reloj
Dispositivos cercanos

nearby_devices
  • Ser un dispositivo conectado mediante Bluetooth y/o Wi-Fi
  • Tiene una pantalla de visualización
  • Proporcione una experiencia de emparejamiento/conexión orientada al usuario en el reloj
aprovisionamiento de eSIM

USE_ICC_AUTH_WITH_DEVICE_IDENTIFIER
  • Ser un dispositivo conectado mediante Bluetooth y/o Wi-Fi
  • Tiene una pantalla de visualización
  • Proporcione una experiencia orientada al usuario que administre los servicios del suscriptor desde el operador en el reloj
Gestión de llamadas en curso

MANAGE_ONGOING_CALLS
  • Ser un dispositivo conectado mediante Bluetooth y/o Wi-Fi
  • Tiene un micrófono y un altavoz incorporados que permiten la conversación de voz
  • Tiene una pantalla que muestra la información de la persona que llama
  • Proporciona una experiencia de llamada telefónica orientada al usuario (la aplicación complementaria une las llamadas telefónicas)

Obtener acceso

Para que las aplicaciones obtengan acceso a los perfiles de dispositivos complementarios, deben aprobarse y agregarse a una lista de permitidos. Cuando se recibe una solicitud para agregarse a la lista de permitidos, el equipo de Android revisa la aplicación para asegurarse de que cumpla con los requisitos para el perfil de dispositivo complementario correspondiente.

Implementación

Para los fabricantes de dispositivos que implementan una aplicación complementaria con un dispositivo específico, use las siguientes configuraciones del sistema Android requeridas para certificar la aplicación complementaria, lo que permite que la aplicación omita mostrar el mensaje de CDM para los usuarios.

  1. Recupere el certificado con el siguiente comando:

    keytool  -printcert -jarfile PATH/TO/APK
    
  2. Reemplace el nombre del paquete y el certificado como se muestra en la siguiente entrada de muestra en el archivo de configuración:

    <!-- A list of packages managing companion device(s) by the same manufacturers as the main device.
    It will not create the association without prompting if the association has been called multiple
    times in a short period. Note that config_companionDeviceManagerPackage and config_companionDeviceCerts
    are parallel arrays. -->
    
        <string-array name="config_companionDevicePackages" translatable="false">
            <item>YOUR_COMAPNION_APP_PACKAGE_NAME</item>
        </string-array>
    
        <!-- A list of SHA256 Certificates managing companion device(s) by the same manufacturers as the
        main device. It will fall back to showing a prompt if the association has been called multiple
        times in a short period. Note that config_companionDeviceCerts and config_companionDeviceManagerPackage
        are parallel arrays.
        Example: "1A:2B:3C:4D" -->
    
        <string-array name="config_companionDeviceCerts" translatable="false">
            <item>YOUR_COMPANION_APP_CERTIFICATE</item>
        </string-array>
    
  3. Utilice AssociationRequest para realizar una solicitud de asociación a un único dispositivo complementario.

Para los desarrolladores externos que implementan una aplicación complementaria que solicita el perfil DEVICE_PROFILE_WATCH , haga lo siguiente:

  1. Llame al método setDeviceProfile .
  2. Pase el perfil DEVICE_PROFILE_WATCH al crear AssociationRequest .

Validación

Para probar el comportamiento de la función de perfil del dispositivo complementario, use las siguientes pruebas CTS: