En esta página, se describe cómo crear, acceder con y borrar una clave de recuperación.
Compatibilidad de versiones
La función Restore Credentials de Credential Manager funciona en dispositivos que ejecutan Android 9 y versiones posteriores, la versión principal 24220000 o posterior de los Servicios de Google Play (GMS) y la versión 1.5.0 o posterior de la biblioteca androidx.credentials.
Requisitos previos
Configura un servidor de terceros similar al servidor de llaves de acceso. Si ya tienes un servidor configurado para controlar la autenticación con llaves de acceso, usa la misma implementación del servidor para las claves de recuperación.
Dependencias
Agrega las siguientes dependencias al archivo build.gradle del módulo de tu app:
Kotlin
dependencies { implementation("androidx.credentials:credentials:1.6.0-rc01") implementation("androidx.credentials:credentials-play-services-auth:1.6.0-rc01") }
Groovy
dependencies { implementation "androidx.credentials:credentials:1.6.0-rc01" implementation "androidx.credentials:credentials-play-services-auth:1.6.0-rc01" }
La función Restore Credentials está disponible a partir de la versión 1.5.0 y versiones posteriores de la biblioteca androidx.credentials. Sin embargo, se recomienda usar las versiones estables más recientes de las dependencias siempre que sea posible.
Descripción general
- Crea una clave de restablecimiento: Para crear una clave de restablecimiento, completa los siguientes pasos:
- Crea una instancia de Credential Manager: Crea un objeto
CredentialManager. - Obtén opciones de creación de credenciales del servidor de la app: Envía a la app cliente los detalles necesarios para crear la clave de restablecimiento desde el servidor de la app.
- Crea la clave de recuperación: Crea una clave de recuperación para la cuenta del usuario si este accedió a tu app.
- Controla la respuesta de creación de credenciales: Envía las credenciales de tu app cliente al servidor de tu app para que las procese y controla las excepciones.
- Crea una instancia de Credential Manager: Crea un objeto
- Acceder con una clave de recuperación: Para acceder con una clave de recuperación, completa los siguientes pasos:
- Obtén opciones de recuperación de credenciales del servidor de la app: Envía a la app cliente los detalles necesarios para recuperar la clave de restauración de tu servidor de la app.
- Obtén la clave de restablecimiento: Solicita la clave de restablecimiento a Credential Manager cuando el usuario configure un dispositivo nuevo. Esto permite que el usuario acceda sin ingresar información adicional.
- Controla la respuesta de recuperación de credenciales: Envía la clave de restauración de la app cliente al servidor de la app para que el usuario acceda.
- Borra una clave de restablecimiento.
Crea una clave de restablecimiento
Crea la clave de restauración después de que el usuario se autentique en tu app, inmediatamente después de acceder o durante un inicio posterior de la app si ya accedió.
Crea una instancia del Administrador de credenciales
Usa el contexto de actividad de tu app para crear una instancia de un objeto CredentialManager.
// Use your app or activity context to instantiate a client instance of
// CredentialManager.
private val credentialManager = CredentialManager.create(context)
Obtén opciones de creación de credenciales del servidor de tu app
Usa una biblioteca compatible con FIDO en el servidor de tu app para enviar a la app cliente la información necesaria para crear la credencial de restablecimiento, como información sobre el usuario, la app y propiedades de configuración adicionales. Para obtener más información sobre la implementación del servidor, consulta la guía del servidor.
Crea la clave de restablecimiento
Después de analizar las opciones de creación de claves públicas que envió el servidor, crea una clave de recuperación envolviendo estas opciones en un objeto CreateRestoreCredentialRequest y llamando al método createCredential() con el objeto CredentialManager.
val credentialManager = CredentialManager.create(context)
// On a successful authentication create a Restore Key
// Pass in the context and CreateRestoreCredentialRequest object
val response = credentialManager.createCredential(context, createRestoreRequest)
Puntos clave sobre el código
El objeto
CreateRestoreCredentialRequestcontiene los siguientes campos:requestJson: Son las opciones de creación de credenciales que envía el servidor de la app en el formato de la API de Web Authentication paraPublicKeyCredentialCreationOptionsJSON.isCloudBackupEnabled: CampoBooleanpara determinar si se debe crear una copia de seguridad de la clave de restablecimiento en la nube. De forma predeterminada, esta marca estrue. Este campo tiene los siguientes valores:true: (Recomendado) Este valor permite hacer una copia de seguridad de las claves de restauración en la nube si el usuario tiene habilitada la copia de seguridad de Google y la encriptación de extremo a extremo, como un bloqueo de pantalla.false: Este valor guarda la clave de forma local y no en la nube. La clave no está disponible en el dispositivo nuevo si el usuario elige restablecer la copia de seguridad desde la nube.
Cómo controlar la respuesta de creación de credenciales
La API de Credential Manager devuelve una respuesta del tipo CreateRestoreCredentialResponse. Esta respuesta contiene la respuesta de registro de credenciales de clave pública en formato JSON.
Envía la clave pública de tu app al servidor de la parte que confía. Esta clave pública es similar a la que se genera cuando creas una llave de acceso. El mismo código que controla la creación de llaves de acceso en el servidor también puede controlar la creación de claves de recuperación. Para obtener más información sobre la implementación del servidor, consulta la guía sobre llaves de acceso.
Durante el proceso de creación de la clave de restablecimiento, controla estas excepciones:
CreateRestoreCredentialDomException: Esta excepción se produce sirequestJsonno es válido y no sigue el formato de WebAuthn paraPublicKeyCredentialCreationOptionsJSON.E2eeUnavailableException: Esta excepción se produce siisCloudBackupEnabledestrue, pero el dispositivo del usuario no tiene copia de seguridad de datos ni encriptación de extremo a extremo, como un bloqueo de pantalla.IllegalArgumentException: Esta excepción se produce sicreateRestoreRequestestá vacío o no es un JSON válido, o si no tiene unuser.idválido que cumpla con las especificaciones de WebAuthn.
Cómo acceder con una clave de recuperación
Usa Restablecer credenciales para permitir que el usuario acceda de forma silenciosa durante el proceso de configuración del dispositivo.
Obtén opciones de recuperación de credenciales del servidor de la app
Envía a la app cliente las opciones necesarias para obtener la clave de restauración del servidor. Para obtener orientación similar sobre las llaves de acceso para este paso, consulta Cómo acceder con una llave de acceso. Para obtener más información sobre la implementación del servidor, consulta la guía de autenticación del servidor.
Obtén la clave de restablecimiento
Para obtener la clave de restablecimiento en el dispositivo nuevo, llama al método getCredential() en el objeto CredentialManager.
Puedes recuperar la clave de restablecimiento en los siguientes casos:
- (Recomendado) Inmediatamente después de que se restablecen los datos de la app Usa
BackupAgentpara configurar la copia de seguridad de tu app y completar la funcionalidad degetCredentialdentro de la devolución de llamadaonRestorepara garantizar que las credenciales de la app se restablezcan inmediatamente después de que se restablezcan los datos de la app. Esto evita posibles demoras cuando los usuarios abren su dispositivo nuevo por primera vez y les permite interactuar sin esperar a que abran tu app. - En el primer inicio de la app en el dispositivo
Para enviar notificaciones a un usuario antes de que abra la app por primera vez en un dispositivo nuevo, recupera la clave de restablecimiento en la devolución de llamada onRestore de BackupAgent.
Esto es especialmente relevante para las apps de mensajería o comunicación.
// Fetch the Authentication JSON from server
val authenticationJson = fetchAuthenticationJson()
// Create the GetRestoreCredentialRequest object
val options = GetRestoreCredentialOption(authenticationJson)
val getRequest = GetCredentialRequest(listOf(options))
// The restore key can be fetched in two scenarios to
// 1. On the first launch of app on the device, fetch the Restore Key
// 2. In the onRestore callback (if the app implements the Backup Agent)
val response = credentialManager.getCredential(context, getRequest)
Las APIs de Credential Manager devuelven una respuesta del tipo GetCredentialResponse. Esta respuesta contiene la clave pública.
Controla la respuesta de acceso
Envía la clave pública de la app al servidor de la parte que confía, que luego se puede usar para acceder al usuario. En el servidor, esta acción es similar a acceder con una llave de acceso. El mismo código que controla el acceso con llaves de acceso en el servidor también puede controlar el acceso con claves de recuperación. Para obtener más información sobre la implementación del servidor para las llaves de acceso, consulta Cómo acceder con una llave de acceso.
Borra la clave de restablecimiento
Credential Manager no tiene estado y no conoce la actividad del usuario, por lo que no borra automáticamente las claves de restablecimiento después de usarlas. Para borrar una clave de recuperación, llama al método clearCredentialState(). Por motivos de seguridad, borra la llave cada vez que un usuario salga de su cuenta. Esto garantiza que, la próxima vez que el usuario abra la app en el mismo dispositivo, se cierre su sesión y se le solicite que vuelva a acceder.
Desinstalar una app se interpreta como un intento de borrar la clave de restablecimiento correspondiente del dispositivo, de manera similar a la intención del usuario cuando cierra la sesión.
Las claves de recuperación solo se quitan en las siguientes situaciones:
- Acciones a nivel del sistema: Los usuarios desinstalan la app o borran sus datos.
- Llamadas a nivel de la app: Borra la clave de forma programática llamando a
clearCredentialState()cuando manejes el cierre de sesión del usuario en el código de tu app.
Cuando el usuario salga de tu app, llama al método clearCredentialState() en el objeto CredentialManager.
// Create a ClearCredentialStateRequest object
val clearRequest = ClearCredentialStateRequest(TYPE_CLEAR_RESTORE_CREDENTIAL)
// On user log-out, clear the restore key
val response = credentialManager.clearCredentialState(clearRequest)