Saltar al contenido
Última actualización

Guía de Pix Biometria (Android SDK - Integración Simplificada)

Próximo Lanzamiento

Esta documentación cubre características de nuestro próximo lanzamiento. Aunque la funcionalidad principal y el flujo de trabajo descrito aquí permanecerán sin cambios, puede que notes algunas mejoras antes del lanzamiento final.

Con Pix Biometria de Belvo, la recolección de pagos de los usuarios se vuelve sencilla, eliminando la necesidad de que los usuarios naveguen a su institución financiera para aprobar cada solicitud de pago individual.

Esta guía demuestra la integración utilizando los métodos de conveniencia del SDK de Android de Belvo. El SDK maneja la comunicación de backend, los flujos de OAuth y el registro FIDO internamente, proporcionando un camino de integración simplificado.

El primer paso para habilitar la recolección de pagos biométricos es registrar el dispositivo del usuario con su institución. Durante el registro, los datos clave sobre el dispositivo y las credenciales de clave pública del usuario se registran de manera segura con su institución, asegurando que los pagos futuros puedan ser confirmados usando solo la autenticación biométrica.

Una vez que el registro esté completo, puedes comenzar a solicitar pagos directamente desde el dispositivo del usuario.

Prerrequisitos

Antes de comenzar, asegúrate de tener:

  1. Generadas tus claves de la API de Belvo Payments
  2. Configurados los webhooks para recibir actualizaciones de estado de pagos y registros
  3. Generado un SDK Access Token (ver abajo)
  4. Instalado el Belvo Android SDK

Token de Acceso del SDK

Autenticación del SDK

El SDK de Pix Biometria requiere un token de acceso para autenticar las solicitudes de la API. Genera este token desde tu servidor backend y pásalo al SDK durante la inicialización.

Genera un token de acceso del SDK desde tu backend:

POST https://api.belvo.com/payments/api/widget-token/
Authorization: Basic <base64_encoded_secret_id:secret_password>
Content-Type: application/json
{
  "access": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...",
  "refresh": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."
}
Mejores Prácticas para Tokens

Nunca codifiques tokens directamente en tu aplicación. Siempre genéralos del lado del servidor e implementa un almacenamiento seguro y lógica de actualización.

Instalación del SDK

Requisitos Mínimos:

  • Android API Level 24 (Android 7.0) o superior
  • Kotlin 1.9.0 o superior

Agrega a tu build.gradle.kts (nivel de Módulo):

dependencies {
    implementation("com.belvo:biometric-pix-core:1.0.0")
}

Sincroniza tu proyecto ¡y estarás listo para comenzar!

Configuración de la App

Agrega permisos a AndroidManifest.xml:

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />

Agrega soporte de App Links para callbacks de OAuth:

<activity android:name=".MainActivity">
    <intent-filter android:autoVerify="true">
        <action android:name="android.intent.action.VIEW" />
        <category android:name="android.intent.category.DEFAULT" />
        <category android:name="android.intent.category.BROWSABLE" />
        <data
            android:scheme="https"
            android:host="yourdomain.com"
            android:pathPrefix="/callback" />
    </intent-filter>
</activity>

Comparte el nombre de tu paquete y la huella digital del certificado SHA-256 con Belvo:

# Obtén tu huella digital SHA-256
keytool -list -v -keystore ~/.android/debug.keystore -alias androiddebugkey -storepass android -keypass android

# Formato para compartir con Belvo:
# Package: com.yourcompany.appname
# SHA-256: AA:BB:CC:DD:EE:FF:...

Permisos e Inicialización del SDK

Momento de Solicitud de Permisos

Los permisos deben ser solicitados antes de la inicialización del SDK. Además, la solicitud de permisos solo puede ser llamada desde un contexto de Activity.

Paso 1: Solicitar Permisos Primero

import com.belvo.biometricpixsdk.BiometricPixSDK
import androidx.activity.ComponentActivity

class EnrollmentActivity : ComponentActivity() {
    private lateinit var sdk: BiometricPixSDK
    
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        
        // DEBE solicitar permisos ANTES de inicializar el SDK
        requestPermissions()
    }
    
    private fun requestPermissions() {
        BiometricPixSDK.requestPermission(this) { granted ->
            if (granted) {
                // Permisos concedidos, ahora inicializar el SDK
                initializeSDK()
            } else {
                // Manejar la denegación de permisos
                showError("Se requiere permiso de ubicación para el registro")
            }
        }
    }
    
    private fun initializeSDK() {
        // Inicializar DESPUÉS de que se concedan los permisos
        sdk = BiometricPixSDK(
            context = this,
            accessToken = getAccessToken() // Desde tu backend
        )
        // Ahora listo para proceder con el registro
    }
    
    override fun onDestroy() {
        super.onDestroy()
        if (::sdk.isInitialized) {
            sdk.cleanup()
        }
    }
}
Gestión de Recursos

Siempre llama a cleanup() cuando hayas terminado con el SDK (por ejemplo, cuando la actividad se destruye o el usuario cierra sesión) para liberar adecuadamente los recursos y limpiar las tareas en segundo plano.

Flujo de Inscripción (6 Pasos)

El proceso de inscripción registra el dispositivo de un usuario con su institución para pagos biométricos.

UsuarioTuAppBiometricPixSDKBelvoAPIInstituciónLlamada 1: getPaymentInstitutions()Llamada 2: createEnrollment() + openRedirectUrl()Llamada 3: completeEnrollmentAfterRedirection()Llamada 4: getFidoRegistrationOptions()Llamada 5: startRegistration()Llamada 6: confirmEnrollment()Inicia inscripción1getPaymentInstitutions()2Obtener instituciones3Lista de instituciones4List<Institution>5Mostrar selector de institución6Selecciona institución7createEnrollment(cpf, institution, accountTenure, callbackUrl)8Recopilar señales de riesgo internamente9POST /enrollments/10Inscripción creada (redirect_url)11Objeto de inscripción12openRedirectUrl(context, redirect_url)13Abrir aplicación de la institución14Aprobar inscripción en la aplicación de la institución15Callback OAuth (code, state, id_token)16completeEnrollmentAfterRedirection(callbackUrl)17POST /enrollments/complete-redirection/18Inscripción actualizada19Objeto de inscripción20getFidoRegistrationOptions(enrollmentId)21Consultar opciones FIDO (reintento automático)22Opciones de registro FIDO23FidoRegistrationOptions24startRegistration(fidoOptions, callback)25Solicitar biometría (huella digital/rostro)26Proporciona biometría27Credencial vía callback28confirmEnrollment(enrollmentId, credential)29POST /enrollments/{id}/confirm/30Registrar credencial FIDO31Registro confirmado32Inscripción EXITOSA33Éxito (Boolean)34Mostrar pantalla de éxito35UsuarioTuAppBiometricPixSDKBelvoAPIInstitución

Paso 1: Obtener Instituciones de Pago

Obtén la lista de instituciones que soportan pagos biométricos:

import com.belvo.biometricpixsdk.BiometricPixSDK
import androidx.lifecycle.ViewModel
import androidx.lifecycle.viewModelScope
import kotlinx.coroutines.launch

class EnrollmentViewModel(
    private val sdk: BiometricPixSDK
) : ViewModel() {
    
    private val _institutions = MutableStateFlow<List<Institution>>(emptyList())
    val institutions: StateFlow<List<Institution>> = _institutions
    
    fun loadInstitutions() {
        viewModelScope.launch {
            try {
                _institutions.value = sdk.getPaymentInstitutions()
            } catch (e: Exception) {
                // Manejar error (red, autenticación, etc.)
                _error.value = "Error al cargar instituciones: ${e.message}"
            }
        }
    }
}

Mostrar instituciones al usuario:

@Composable
fun InstitutionPickerScreen(
    viewModel: EnrollmentViewModel
) {
    val institutions by viewModel.institutions.collectAsState()
    
    LazyColumn {
        items(institutions) { institution ->
            InstitutionItem(
                institution = institution,
                onClick = { viewModel.selectInstitution(institution) }
            )
        }
    }
    
    LaunchedEffect(Unit) {
        viewModel.loadInstitutions()
    }
}

@Composable
fun InstitutionItem(
    institution: Institution,
    onClick: () -> Unit
) {
    Row(
        modifier = Modifier
            .fillMaxWidth()
            .clickable(onClick = onClick)
            .padding(16.dp)
    ) {
        AsyncImage(
            model = institution.iconLogo,
            contentDescription = institution.displayName,
            modifier = Modifier.size(40.dp)
        )
        Spacer(modifier = Modifier.width(16.dp))
        Text(text = institution.displayName)
    }
}

Paso 2: Crear Inscripción y Abrir la Aplicación de la Institución

Crea la inscripción e inmediatamente abre la aplicación de la institución:

fun startEnrollment() {
    val institution = _selectedInstitution.value ?: return
    
    viewModelScope.launch {
        try {
            // Crear inscripción
            val enrollment = sdk.createEnrollment(
                cpf = userCPF,                           // CPF del usuario
                institution = institution.id,             // ID de la institución seleccionada
                accountTenure = customerCreatedDate,      // Formato "YYYY-MM-DD"
                callbackUrl = "https://yourdomain.com/callback"
            )
            
            // Guardar ID de inscripción e ID de dispositivo para más tarde
            _enrollmentId.value = enrollment.id
            _deviceId.value = enrollment.details.riskSignals.deviceId
            
            // Inmediatamente abrir la aplicación de la institución usando la URL de redirección
            enrollment.details.redirectUrl?.let { url ->
                sdk.openRedirectUrl(context, url)
            } ?: run {
                _error.value = "No se recibió URL de redirección de la inscripción"
            }
            
        } catch (e: Exception) {
            _error.value = "La creación de la inscripción falló: ${e.message}"
        }
    }
}
Formato de Antigüedad de Cuenta

El parámetro accountTenure debe ser la fecha en que el usuario fue creado como Cliente de Belvo, en formato YYYY-MM-DD. Extrae esto del timestamp created_at del Cliente (primeros 10 caracteres).

El método openRedirectUrl() del SDK maneja la apertura de la aplicación de la institución automáticamente. La institución redirigirá de vuelta a tu callbackUrl con parámetros OAuth.

Paso 5: Completar el Registro Después de la Redirección

Maneja el callback de OAuth en tu actividad y completa el registro:

// En tu MainActivity
override fun onNewIntent(intent: Intent?) {
    super.onNewIntent(intent)
    intent?.data?.let { uri ->
        handleEnrollmentCallback(uri)
    }
}

fun handleEnrollmentCallback(uri: Uri) {
    viewModelScope.launch {
        try {
            val enrollment = sdk.completeEnrollmentAfterRedirection(
                callbackUrl = uri.toString()  // SDK analiza los parámetros automáticamente
            )
            
            // Verifica si fue exitoso
            when (enrollment.status) {
                "PENDING" -> {
                    // Éxito - procede al registro FIDO
                    getFidoOptions(enrollment.id)
                }
                "FAILED" -> {
                    // Maneja el fallo
                    _error.value = "${enrollment.statusReasonCode}: ${enrollment.statusReasonMessage}"
                }
            }
            
        } catch (e: Exception) {
            _error.value = "Error al completar el registro: ${e.message}"
        }
    }
}
Alternativa: Parámetros Manuales

Si prefieres analizar la URL de callback tú mismo, puedes pasar los parámetros individualmente:

val enrollment = sdk.completeEnrollmentAfterRedirection(
    state = stateParam,
    code = codeParam,
    idToken = idTokenParam
)

Paso 4: Obtener Opciones de Registro FIDO

Recupera las opciones FIDO necesarias para el registro biométrico. El SDK realiza automáticamente la consulta durante hasta 5 minutos:

fun getFidoOptions(enrollmentId: String) {
    viewModelScope.launch {
        // El SDK consulta automáticamente cada 1 segundo durante hasta 5 minutos
        val fidoOptions = sdk.getFidoRegistrationOptions(enrollmentId)
        
        if (fidoOptions != null) {
            // Opciones FIDO recibidas, proceder al registro biométrico
            startBiometricRegistration(fidoOptions)
        } else {
            // El tiempo de espera de la consulta se agotó (pasaron 5 minutos)
            _error.value = "Tiempo de espera agotado para las opciones FIDO. Por favor, inténtalo de nuevo."
        }
    }
}
Consulta Automática

El método getFidoRegistrationOptions() maneja toda la lógica de consulta automáticamente. Verifica cada 1 segundo durante hasta 5 minutos, por lo que no necesitas implementar ninguna lógica de reintento.

Paso 5: Registrar Biometría y Confirmar

Solicite al usuario los datos biométricos y confirme la inscripción:

class EnrollmentViewModel(
    private val sdk: BiometricPixSDK
) : ViewModel() {
    
    private var enrollmentId: String? = null
    
    fun startBiometricRegistration(fidoOptions: FidoRegistrationOptions) {
        try {
            sdk.startRegistration(
                fidoOptions = fidoOptions.toJsonString(),
                callback = object : FidoRegistrationCallback {
                    override fun onSuccess(credential: PublicKeyCredential, response: AuthenticatorAttestationResponse) {
                        // SDK maneja la creación de payload automáticamente
                        confirmEnrollment(credential, response)
                    }
                    
                    override fun onError(error: String) {
                        _error.value = "El registro biométrico falló: $error"
                    }
                }
            )
        } catch (e: Exception) {
            _error.value = "Error al iniciar el registro: ${e.message}"
        }
    }
    
    private fun confirmEnrollment(
        credential: PublicKeyCredential,
        response: AuthenticatorAttestationResponse
    ) {
        val enrollmentId = this.enrollmentId ?: return
        
        viewModelScope.launch {
            val success = sdk.confirmEnrollment(
                enrollmentId = enrollmentId,
                credential = credential,
                response = response
            )
            
            if (success) {
                _state.value = EnrollmentState.Success
            } else {
                _error.value = "La confirmación de inscripción falló"
            }
        }
    }
}
¡Inscripción Completa!

El dispositivo ahora está inscrito y listo para pagos biométricos.

Flujo de Pago (4 Pasos)

Una vez inscrito, iniciar pagos requiere cuatro llamadas a métodos:

UsuarioTuAppBiometricPixSDKBelvoAPIInstituciónLlamada 1: listEnrollments()Llamada 2: createPaymentIntent()Llamada 3: startSigning() + collectRiskSignals()Llamada 4: authorizePaymentIntent()Inicia pago1listEnrollments(deviceId)2GET /enrollments/?device_id=...3List<Enrollment>4Lista de inscripciones5Mostrar selector de inscripción6Selecciona inscripción7createPaymentIntent(payload)8POST /payment-intents/9PaymentIntent (con opciones FIDO)10Objeto PaymentIntent11startSigning(fidoOptions, callback)12Solicitar biometría (huella/rostro)13Proporciona biometría14Afirmación vía callback15collectRiskSignals(accountTenure)16RiskSignals17authorizePaymentIntent(paymentIntentId, payload)18POST /payment-intents/{id}/authorize/19Procesar pago20Pago confirmado21Pago SUCCEEDED22Autorización exitosa (Boolean)23Mostrar confirmación de pago24UsuarioTuAppBiometricPixSDKBelvoAPIInstitución

Paso 1: Listar Inscripciones

Obtén todas las inscripciones para el dispositivo actual y permite que el usuario seleccione una:

class PaymentViewModel(
    private val sdk: BiometricPixSDK
) : ViewModel() {
    
    private val _enrollments = MutableStateFlow<List<Enrollment>>(emptyList())
    val enrollments: StateFlow<List<Enrollment>> = _enrollments
    
    fun loadEnrollments(deviceId: String) {
        viewModelScope.launch {
            try {
                _enrollments.value = sdk.listEnrollments(deviceId)
            } catch (e: Exception) {
                _error.value = "Failed to load enrollments: ${e.message}"
            }
        }
    }
}

Mostrar inscripciones al usuario:

@Composable
fun EnrollmentSelectionScreen(
    viewModel: PaymentViewModel
) {
    val enrollments by viewModel.enrollments.collectAsState()
    
    LazyColumn {
        items(enrollments) { enrollment ->
            enrollment.institution?.let { institution ->
                EnrollmentItem(
                    enrollment = enrollment,
                    institution = institution,
                    onClick = { viewModel.selectEnrollment(enrollment) }
                )
            }
        }
    }
    
    LaunchedEffect(Unit) {
        viewModel.loadEnrollments(savedDeviceId)
    }
}

@Composable
fun EnrollmentItem(
    enrollment: Enrollment,
    institution: Institution,
    onClick: () -> Unit
) {
    Row(
        modifier = Modifier
            .fillMaxWidth()
            .clickable(onClick = onClick)
            .padding(16.dp)
    ) {
        AsyncImage(
            model = institution.iconLogo,
            contentDescription = institution.displayName,
            modifier = Modifier.size(40.dp)
        )
        Spacer(modifier = Modifier.width(16.dp))
        Column {
            Text(text = institution.displayName)
            Text(
                text = "Estado: ${enrollment.status}",
                style = MaterialTheme.typography.bodySmall,
                color = MaterialTheme.colorScheme.onSurfaceVariant
            )
        }
    }
}

Paso 2: Crear una Intención de Pago

Crea una intención de pago con todos los detalles del pago:

fun createPayment(
    amount: Double,
    enrollmentId: String,
    beneficiaryAccountId: String
) {
    val payload = CreatePaymentIntentPayload(
        amount = amount,
        customer = Customer(identifier = userCPF),  // CPF del usuario
        description = "Pago por servicios",
        statementDescription = "Compra ACME Corp",
        allowedPaymentMethodTypes = listOf("open_finance_biometric_pix"),
        paymentMethodDetails = PaymentMethodDetails(
            openFinanceBiometricPix = OpenFinanceBiometricPixPaymentMethodDetails(
                beneficiaryBankAccount = beneficiaryAccountId,
                enrollment = enrollmentId
            )
        ),
        confirm = true
    )
    
    viewModelScope.launch {
        try {
            val paymentIntent = sdk.createPaymentIntent(payload)
            
            // Guardar ID de la intención de pago
            _paymentIntentId.value = paymentIntent.id
            
            // Extraer opciones FIDO para el siguiente paso
            paymentIntent.paymentMethodInformation?.openFinanceBiometricPix?.fidoOptions?.let { fidoOptions ->
                promptForBiometric(fidoOptions)
            }
            
        } catch (e: Exception) {
            _error.value = "Error al crear la intención de pago: ${e.message}"
        }
    }
}

Paso 3: Recopilar Señales Biométricas y de Riesgo

Solicitar autenticación biométrica y recopilar señales de riesgo:

class PaymentViewModel(
    private val sdk: BiometricPixSDK
) : ViewModel() {
    
    private var paymentIntentId: String? = null
    private var riskSignals: RiskSignals? = null
    private var assertionResponse: AssertionResponse? = null
    
    fun promptForBiometric(fidoOptions: FidoOptions) {
        try {
            sdk.startSigning(
                fidoOptions = fidoOptions.toJsonString(),
                fallbackCredential = null,  // Opcional: proporcionar si tienes uno
                callback = object : FidoAuthenticationCallback {
                    override fun onSuccess(response: AssertionResponse) {
                        // Almacenar respuesta de aserción
                        assertionResponse = response
                        
                        // Recopilar señales de riesgo
                        collectRiskSignals()
                    }
                    
                    override fun onError(error: String) {
                        _error.value = "La autenticación biométrica falló: $error"
                    }
                }
            )
        } catch (e: Exception) {
            _error.value = "Error al iniciar la firma: ${e.message}"
        }
    }
    
    private fun collectRiskSignals() {
        try {
            riskSignals = sdk.collectRiskSignals(
                accountTenure = customerCreatedDate  // "YYYY-MM-DD"
            )
            
            // Una vez que tenemos tanto la aserción como las señales de riesgo, autorizar el pago
            if (assertionResponse != null && riskSignals != null) {
                authorizePayment()
            }
        } catch (e: Exception) {
            _error.value = "Error al recopilar señales de riesgo: ${e.message}"
        }
    }
}

Paso 4: Autorizar Pago

Autoriza el pago con los datos recopilados:

private fun authorizePayment() {
    val paymentIntentId = this.paymentIntentId ?: return
    val riskSignals = this.riskSignals ?: return
    val assertion = this.assertionResponse ?: return
    
    val payload = AuthorizePaymentIntentPayload(
        platform = "android",
        riskSignals = riskSignals,
        assertion = assertion
    )
    
    viewModelScope.launch {
        val success = sdk.authorizePaymentIntent(
            paymentIntentId = paymentIntentId,
            payload = payload
        )
        
        if (success) {
            _state.value = PaymentState.Success
        } else {
            _error.value = "Payment authorization failed"
        }
    }
}
¡Flujo de Pago Completo!

El pago ahora está autorizado y en proceso. Necesitas monitorear eventos de webhook para rastrear su estado final.

Manejo de Errores

Todos los métodos del SDK que realizan operaciones de red pueden lanzar excepciones. Asegúrate de manejarlas adecuadamente:

try {
    val institutions = sdk.getPaymentInstitutions()
    // Éxito
} catch (e: BiometricPixSDKException) {
    when (e) {
        is BiometricPixSDKException.NetworkError -> {
            // Manejar problemas de red
            Log.e(TAG, "Error de red: ${e.message}")
        }
        is BiometricPixSDKException.AuthenticationError -> {
            // Manejar token inválido o expirado
            Log.e(TAG, "Autenticación fallida - el token puede estar expirado")
        }
        is BiometricPixSDKException.InvalidParametersError -> {
            // Manejar entrada inválida
            Log.e(TAG, "Parámetros inválidos: ${e.message}")
        }
        is BiometricPixSDKException.UnknownError -> {
            // Manejar errores desconocidos
            Log.e(TAG, "Error: ${e.message}")
        }
    }
} catch (e: Exception) {
    Log.e(TAG, "Error inesperado: ${e.message}")
}

Webhooks

Aunque el SDK maneja la mayor parte del flujo de trabajo, aún debes escuchar las notificaciones de webhook para manejar actualizaciones asíncronas:

  • Cambios en el estado de inscripción: tipo de webhook ENROLLMENTS
  • Cambios en el estado de pago: tipo de webhook PAYMENT_INTENTS

Para obtener la documentación completa de los webhooks, consulta Webhooks de Pagos (Brasil).

Referencia de Métodos del SDK

Inicialización

BiometricPixSDK(context: Context, accessToken: String)

  • Crea una nueva instancia del SDK con el contexto y el access token proporcionados
  • Debe inicializarse una vez y reutilizarse en toda tu aplicación
  • Access token obtenido del endpoint /payments/api/widget-token/

cleanup()

  • Libera los recursos del SDK y limpia las tareas en segundo plano
  • Llamar en onCleared() o cuando el usuario cierra sesión

Métodos de Inscripción

getPaymentInstitutions(): List<Institution>

  • Obtiene todas las instituciones que admiten pagos biométricos
  • Devuelve una lista de objetos Institution con id, displayName, iconLogo, etc.
  • Lanza una excepción en caso de errores de red o autenticación

createEnrollment(cpf: String, institution: String, accountTenure: String, callbackUrl: String): Enrollment

  • Crea la inscripción y recopila señales de riesgo automáticamente
  • cpf: Número de CPF del usuario
  • institution: ID de la institución de getPaymentInstitutions()
  • accountTenure: Fecha de creación del cliente en formato "YYYY-MM-DD"
  • callbackUrl: Enlace profundo para la devolución de llamada OAuth (debe estar registrado como App Link)
  • Devuelve un objeto Enrollment con id, redirect_url, device_id

openRedirectUrl(context: Context, url: String)

  • Abre la aplicación de la institución usando la URL de redirección proporcionada
  • Maneja la redirección automáticamente, incluyendo el enlace profundo
  • Debe ser llamado inmediatamente después de createEnrollment() con el redirect_url de la respuesta de inscripción
  • context: Contexto de la Actividad o Aplicación
  • url: La URL de redirección del objeto de inscripción

completeEnrollmentAfterRedirection(callbackUrl: String): Enrollment

  • Completa la inscripción después de la devolución de llamada OAuth de la institución
  • Analiza automáticamente los parámetros OAuth de la URL completa de devolución de llamada
  • Alternativa: completeEnrollmentAfterRedirection(state: String, code: String, idToken: String)

getFidoRegistrationOptions(enrollmentId: String): FidoRegistrationOptions?

  • Consulta las opciones de registro FIDO (reintento automático: intervalo de 1 segundo, tiempo de espera de 5 minutos)
  • Devuelve FidoRegistrationOptions cuando está listo
  • Devuelve null si el tiempo de espera de la consulta se agota

startRegistration(fidoOptions: String, callback: FidoRegistrationCallback)

  • Inicia el flujo de registro biométrico (reconocimiento de huella digital/rostro)
  • fidoOptions: Cadena JSON de FidoRegistrationOptions.toJsonString()
  • callback: Interfaz para recibir devoluciones de llamada de éxito/error

confirmEnrollment(enrollmentId: String, credential: PublicKeyCredential, response: AuthenticatorAttestationResponse): Boolean

  • Confirma la inscripción con la credencial FIDO
  • Devuelve true en caso de éxito, false en caso de fallo

Métodos de Pago

listEnrollments(deviceId: String): List<Enrollment>

  • Obtiene todas las inscripciones para un dispositivo
  • Devuelve una lista de objetos Enrollment con datos enriquecidos de la institución
  • Filtrar por status == "SUCCEEDED" para mostrar solo inscripciones activas

createPaymentIntent(payload: CreatePaymentIntentPayload): PaymentIntent

  • Crea una intención de pago
  • Devuelve PaymentIntent con id y paymentMethodInformation.openFinanceBiometricPix.fidoOptions

startSigning(fidoOptions: String, fallbackCredential: String?, callback: FidoAuthenticationCallback)

  • Inicia la autenticación biométrica para el pago
  • fallbackCredential: Credencial opcional para escenarios de reintento
  • callback: Interfaz para recibir la respuesta de la afirmación

collectRiskSignals(accountTenure: String): RiskSignals

  • Recoge huellas digitales del dispositivo y señales de seguridad
  • accountTenure: Fecha de creación del cliente en formato "YYYY-MM-DD"
  • Devuelve un objeto RiskSignals para la carga útil de autorización

authorizePaymentIntent(paymentIntentId: String, payload: AuthorizePaymentIntentPayload): Boolean

  • Autoriza el pago con afirmación biométrica y señales de riesgo
  • Devuelve true en caso de éxito, false en caso de fallo