Enrichment marketplace — errores estructurados
POST /integration-execution/marketplace/enrichment devuelve objetos error más ricos: category, retryable y statusCode opcionales.Creación automática / bulk — tax ID estricto
taxId debe ser solo el identificador fiscal; valores fusionados con columnas extra se rechazan con INVALID_TAX_ID.Transacciones — exchangeRate opcional (fallback)
POST /transactions y batch aceptan exchangeRate opcional por transacción. Sin este campo, el comportamiento es el mismo de siempre (conversión automática).Solo se usa si falla la conversión automática. Semántica: unidades de moneda base por 1 unidad de currency; monto normalizado en base = amount × exchangeRate. rateSource: client-provided.No convertibles hoy (sin tasa automática): WLD (Worldcoin), ETH (Ethereum). Enviá exchangeRate para monto normalizado en moneda base y reglas que dependen de conversión.Ver Crear transacción — Conversión de moneda.POST /entities/{entityId}/refresh — scope unificado y sync seguro
Campos opcionales nuevos (retrocompatibles si se omiten):refreshScope:basic_data|all_active|selected(+providerCodessiselected).preserveName:trueconserva el nombre; omitido = sync legacy desdefullNamenormalizado.preserveEntityData: solo conrefreshScope: "basic_data"—truecompleta vacíos enentityData,falsereemplaza; omitido = no tocar ficha.
basic_data siempre es solo entidad raíz (sin socios), sin importar depth.Ver Actualizar entidad. Payloads existentes sin estos campos no cambian de comportamiento.Warning GUENO_CROSS_ENTITY_DUPLICATED
Cuando Gu1 resuelve referencias duplicadas del proveedor en otra entidad de la misma organización (metadata.kycCrossEntityDuplicates.matches):- Añade
GUENO_CROSS_ENTITY_DUPLICATEDawarningsde la validación por sesión. - Si el proveedor mapeó
approved, Gu1 deja el estado enin_review(metadata.guenoCrossEntityDuplicateEscalation). - No omitible: no puede ir en
omitWarnings(400) y bloquea auto-aprobación por omit.
omitWarnings.Gu1 Biometría (POST /api/kyc/biometric y /api/kyc/biometric/sessions)
Re-autenticación tras KYC aprobado: verificación por imagen (POST /api/kyc/biometric) o sesión con UI hospedada (sessionUrl, iframeAllow, hostedSessionId, webhookUrl opcional, webhooks biometric.session_*, veredicto Gu1 con rejectionCode). Producto marketplace global_gueno_biometric_kyc. Ver Verificación biométrica y Sesión biométrica.decision siempre incluye pares array + objeto por feature
Al persistir (sync, webhook, ingest manual), Gu1 normaliza decision para que integradores lean indistintamente claves singulares legacy o arrays:id_verification↔id_verifications[0]liveness↔liveness_checks[0]face_match↔face_matches[0]aml_screening↔aml_screenings[0]ip_analysis↔ip_analyses[0]
array[0] gana y el objeto singular se sincroniza. Aplica a GET de validación y webhooks KYC (payload.decision).Ejemplos Mintlify actualizados con decision completo (sin branding de vendor; media como claves kyc/...). Ver Eventos webhook KYC.Config del motor en POST /entities/{entityId}/analyze
Nuevo objeto opcional rulesEngineConfig: partialCoverage (cobertura por matriz) y omitCoverage (omitir gates de cobertura). Defaults false — sin cambio vs comportamiento histórico.Ver Analizar entidad.ejemplar en extractedData
Las verificaciones de DNI argentino pueden incluir extractedData.ejemplar (A–D) en validaciones KYC y registros de ID Verification (GET, sync, webhooks).Con doubleCheckRenaper: true, comparisonResults.ejemplar compara OCR vs RENAPER; un mismatch agrega RENAPER_EJEMPLAR_NOT_MATCH a warnings.Ver campos de extractedData y doble chequeo RENAPER.Doble chequeo RENAPER en validaciones KYC
CondoubleCheckRenaper: true, metadata.responseDoubleChecks.renaper incluye comparisonResults, renaperBiometric (cuando aplica) y códigos RENAPER en warnings (p. ej. RENAPER_TRAMITE_ID_NOT_MATCH, RENAPER_EXPIRY_NOT_MATCH) sin reemplazar advertencias de la verificación OCR KYC.Enforce (rechazo automático): solo si la verificación OCR KYC devuelve el estado approved. En in_review y rejected el chequeo es informativo y deja datos en metadata. POST /api/kyc/validations/{id}/approve desde in_review no re-ejecuta RENAPER.Ver Crear validación KYC y Aprobar validación.Producto marketplace *_check eliminado
- Eliminado: códigos
*_check,POST /integration-execution/marketplace/check, triggers/acciones de reglascheck_completed/execute_check, y permisos RBACchecks:read/checks:execute. - Usar en su lugar: el
*_enrichmentequivalente con Ejecutar enrichment. - Compat legacy: payloads de create/import con
checks,executeAllActiveCheckso*_checkenautoExecuteIntegrations.enrichmentsse ignoran al parsear.
Códigos estables y endpoints JSON de fallos batch
- Fallos por fila con
code+message— Catálogo. CSV incluye columnacode. - JSON:
GET /batch-import/transaction-jobs/{jobId}/failures,GET /batch-import/user-event-jobs/{jobId}/failures,GET /batch-import/entity-jobs/{jobId}/failures— incluyenfailures[],jobFailureopcional,skips[]en entidades,truncated/failuresTotal(máx. 500). - CSV: mismas rutas con sufijo
.csvpara descarga directa.
Asignar matrices de riesgo al actualizar entidad
PATCH /entities/{id}(yPATCH /entities/by-external-id/{externalId},PATCH /entities/by-tax-id/{taxId}): documentadosriskMatrixIds(string[]) yriskMatrixId(string | string[] | null) — misma normalización que en create. Solo asigna matrices; no ejecuta el motor de reglas (usar Analizar entidad o triggers del ciclo de vida).- Mintlify actualizado en
/en/,/es/,/pt/en Actualizar entidad y Actualizar por ID externo.
configRulesExecution en alta de transacción
POST /transactions: objeto opcional en el bodyconfigRulesExecutionconnotifications(boolean). Confalse, gu1 omite notificaciones in-app de la evaluación de reglas (matriz / estado). AccionescreateAlerte investigaciones no cambian.- Default: si se omite el objeto, el resto de organizaciones mantiene el comportamiento anterior (
notificationsefectivamentetrue). Paytime prod (3bc1f621-27d4-423e-9d64-86680bec2388) usanotifications: falsepor defecto. - Legacy KYT
POST /legacy/kyt/verifyTransaction: mismo campo en el body Gu2; Paytime prodnotifications: falsepor defecto si se omite. - Aplica en reglas sync y async (
asyncRules).
/en/ y /pt/.POST /transactions y lote — campos de contraparte vinculados
Cuando origen o destino queda vinculado a persona/empresa (originEntityId / auto-link por external o tax id), gu1 siempre pisa las columnas denormalizadas desde la entidad antes del insert:originTaxId/destinationTaxId←entities.tax_idoriginExternalId/destinationExternalId←entities.external_id
POST /events/user — isNewDevice respeta el valor del integrador
- Si envías
isNewDevice: trueofalse, gu1 persiste exactamente ese valor (sin sobrescritura en servidor). - Si omitís el campo, gu1 lo infiere cuando hay
deviceId+deviceDetails(registro de dispositivos;truesi el device es nuevo ofirstSeenAtestá dentro de los últimos 5 minutos); si no,false.
CSV plataforma: attributes.* y entityData.*
- Cabeceras con punto (misma idea que transacciones nativas):
attributes.segment_tag,attributes.tags.tier,entityData.income,entityData.tradeName. entityData.<campo>sinperson/company→ bucket segúntypede la fila.- Columnas sin prefijo (
segment_tag) siguen yendo aattributes(retrocompat). - Plantillas hub actualizadas; ver Importar entidades (CSV).
Límites documentados (en / es / pt)
- Importaciones masivas — overview: matriz de archivos por request, filas por plan e manual vs automático en entidades.
- Páginas por endpoint con límites: Importar entidades (CSV), transacciones, eventos de usuario.
- Consulta límites en runtime:
GET /individual-organization/batch-upload-enabled.
Países en import bulk (manual vs automático)
- Manual (
manual): cualquier ISO2 válido de plataforma (lote ocountry_code/countrypor fila). Sin pipeline Nosis/CPF. - Automático (
automatic): AR, BR y CL (datos básicos por tax ID, incl. enrichments Chile: ruts.info / BaseAPI). - Aplica a
POST /batch-import/import/entities(CSV plataforma y CSV custom conmappingId).
POST /batch-import/import/entities — enrichments en manual
- El modo manual multipart coincide con el hub Manual:
autoExecuteIntegrations,monitoringy matrices opcionales — sin pipeline Nosis/CPF. - Solo CSV (sin enrichments explícitos) → entidad mínima, sin enrichments.
- Columnas CSV de enrichment por fila aplican en manual;
depthsolo en automático.
POST /batch-import/import/entities — default manual
- Sin
entityImportMode, el modo efectivo esmanual(entidad mínima; enrichments solo si los pedís). - Automático con
entityImportMode=automatic(+autoExecuteIntegrations,depth, etc.). - Modo manual exige
suggested_nameen cada fila (400si falta). - Respuesta
202incluyeimportModeaplicado.
POST /batch-import/import/entities — formato plataforma
mappingIdopcional con CSV formato plataforma (tax_id,type, …). Default de import:manual(ver entrada siguiente en este changelog).
asyncRules al crear transacción
POST /transactions: flag opcionalasyncRulesen query o body (defaultfalse). ContrueyexecuteRulesdistinto defalse, la transacción se crea en la misma request pero las reglas corren en background vía cola de jobs. La respuesta HTTP vuelve al instante conrulesHit/rulesNoHitvacíos, másasyncRules: trueyrulesEvaluationStatus: "queued".- Sin cambio por defecto: omitir
asyncRulesmantiene ejecución síncrona y unrulesExecutionSummarycompleto — clientes existentes siguen igual. - Legacy KYT
POST /legacy/kyt/verifyTransaction: mismo flag por query o campo en body Gu2. Paytime prod (3bc1f621-27d4-423e-9d64-86680bec2388) usa async por defecto si no envían el flag;asyncRules=falsefuerza sync en una request. - No aplica a batch. Si Redis/cola no está disponible, puede responder 503
ASYNC_RULES_QUEUE_UNAVAILABLE(la transacción puede existir — revisar el body antes de reintentar).
Doble chequeo RENAPER en endpoints KYC standalone
POST /api/kyc/face-match:doubleCheckRenaperopcional (body o query). Tras aprobar face match: RENAPER biométrico + datos. RequieredocumentNumber,gender,personalNumber(fallback de entidad para DNI/género). Respuesta conresponseDoubleChecks.POST /api/kyc/id-verification: mismo flag; tras OCR approved solo chequeo datos RENAPER. Fallo →declined+ códigos enwarnings.- Credenciales RENAPER de org (igual que KYC por sesión). Timeout HTTP ≥ 60 s en face-match con double-check.
KYT — triggers separados: cambio de estado vs actualización de campos
PATCH …/changeStatusejecuta reglas/matrices con triggerstatus_changed(trigger_transaction_status_changed), noupdated.PATCH /transactions/{id}conexecuteRules=truesigue usandoupdated(trigger_transaction_updated) para cambios de metadata, deviceDetails, channel o reason.- Migración: reconfigurar reglas que debían correr al cambiar estado al nuevo trigger (Rule Builder: Al cambiar estado; matrices:
transaction_status_changed).
Actualización parcial de transacción
PATCH /transactions/{id}yPATCH /transactions/external/{externalId}: actualizarmetadata(merge superficial),deviceDetails(merge superficial endevice_details),channel(nullable) y/oreason(enum). Requieretransactions:edit.- Query
executeRules=truere-ejecuta reglas KYT con triggerupdated— no reglas de cambio de estado. - Auditoría
transaction_updatedy webhooktransaction.updatedcon mapachanges(incluyedeviceDetailssi aplica).
Eventos de usuario — has-events por external ID o tax ID
GET /events/user/entity/has-events(nuevo): comprobación sí/no sin UUID interno. Query params:entity_id,entity_external_idotax_id(al menos uno obligatorio). Prioridad:entity_id→entity_external_id→tax_id; comparación de tax ID con normalización (sin caracteres no alfanuméricos).- La respuesta incluye
entityIdresuelto para poder llamar a Listar por entidad cuandohasEventses true. GET /events/user/entity/{entityId}/has-eventssigue soportado (contrato sin cambios).
KYC por sesión — advertencias de análisis de dispositivo e IP
GET /api/kyc/validations/:id(y rutas de sync/webhook): el arraywarningsahora fusiona códigosriskdedecision.ip_analyses[].warnings[](y legacydecision.ip_analysis.warnings), además de verificación de documento, liveness, face match y AML.- Ocho códigos del proveedor (p. ej.
PRIVATE_NETWORK_DETECTED,DUPLICATED_DEVICE_FINGERPRINT,IP_ADDRESS_IN_BLOCKLIST). Ver Códigos de advertencia KYC — Análisis de dispositivo e IP. - Los mismos códigos son válidos en
omitWarningsdePOST /api/kyc/validationsal auto-aprobar sesiones enin_review.
warnings hasta el próximo sync; volvé a consultar o sincronizá para backfillear códigos de IP analysis en filas antiguas.ID Verification — extractedData más completo
POST /api/kyc/id-verificationy auditoría list/get persisten y devuelven unextractedDatamás amplio: identidad (personalNumber,taxNumber,placeOfBirth, …),providerStatus,warningMeta(p. ej. sesión duplicada), scores de calidad,extraFields,mrz,parsedAddress,barcodescuando los devuelve el servicio ID Verification de Gu1.warningssigue siendo un array de códigos de riesgo para i18n; la metadata estructurada de duplicados va enwarningMetadentro deextractedData.- No se devuelven URLs externas de imagen ni base64; las imágenes subidas están en imágenes ID Verification.
debugProviderResponsesolo en entornos no productivos de la API Gu1 (payload de verificación sanitizado, sin imágenes).
Horario operativo por entidad (global)
- Entidades: campo opcional en raíz
operationalHours(timezoneenum +weekly). Aplica apersonycompany, manual yPOST /entities/automatic. Columnaentities.operational_hours. Ver Crear entidad, person/create y create-automatic. - Transacciones: enum
transaction_time_zoneampliado (zonas Brasil).timeZoneindependiente deoperationalHours.transactedAt: UTC en DB; ISO conZsin cambios para clientes actuales; datetime local +timeZoneopcional convierte a UTC. - Reglas: operadores
outside_entity_operational_hourseinside_entity_operational_hourssobretransactedAt(value:origin|destination).
timeZone en transacciones
- Base de datos: Nueva columna nullable
time_zoneentransactionscon enumtransaction_time_zone(valores IANA comoAmerica/Argentina/Buenos_Aires,UTC, etc.). Las filas existentes siguen ennull. - API:
timeZoneopcional enPOST /transactionsy creación en lote; se devuelve enGET /transactions/{id}yGET /transactions/external/{externalId}comostring | null.
validateExistingEntity (creación de transacciones)
POST /transactions: nuevo campo opcionalvalidateExistingEntity(defaultfalse). Contrue, cada identificador de origen/destino que envíes debe existir en la org; si no, 400INVALID_ENTITY_REFERENCESy no se crea la fila.- Batch (
POST /transactions/batch, upload, JSON): el default sigue siendotrue(validación estricta si enviás identificadores). Para import histórico permisivo:validateExistingEntity: false. - Legacy KYT
POST /legacy/kyt/verifyTransaction: acepta el mismo campo en el body Gu2 (validateExistingEntity).
excludeEnrichments en creación de entidades
autoExecuteIntegrations y autoExecuteIntegrationsShareholders aceptan excludeEnrichments: códigos de proveedor que se excluyen del conjunto final de enriquecimientos (también con executeAllActiveEnrichments: true).executeAllActiveChecks y checks ya no forman parte del contrato público de estos objetos; los payloads legacy que los envíen se ignoran al parsear.Ver Crear entidad (automática).Nuevo: Documentación de Página de Onboarding Alojada
Documentación completa para la Página de Onboarding Alojada - la forma más rápida de implementar verificación KYC sin código.Novedades
Documentación de Página Alojada:- ✅ Guía completa de parámetros de personalización (branding, colores, diseño)
- ✅ Configuración de reglas de validación (verificación de edad, métodos de captura, detección de duplicados)
- ✅ Reglas de validación de documentos (QR/código de barras, MRZ, fechas de vencimiento, vivacidad)
- ✅ Guía de integración paso a paso con ejemplos de código
- ✅ Diagrama de flujo visual mostrando el proceso completo
- ✅ Mejores prácticas de seguridad para gestión de sesiones
- ✅ Confirmación de diseño mobile-responsive
- 📱 Diseño mobile-responsive para todos los dispositivos
- 🎨 Personalización completa de colores, branding y diseño
- 🔒 Directrices de seguridad completas
- 📊 Diagramas de secuencia visuales para mayor claridad
- 🌐 Información de canal de soporte para cambios de configuración
Idiomas
Toda la documentación disponible en:- 🇺🇸 English
- 🇪🇸 Español
- 🇧🇷 Português
Impacto
- Implementación más rápida para soluciones sin código
- Guía clara sobre opciones de personalización
- Mayor conciencia de seguridad
- Mejor comprensión del flujo de la página alojada
Refinamiento de Páginas KYC Basado en Feedback del Cliente
Mejora importante en la documentación de KYC basada en 14 preguntas del feedback de clientes.Novedades
Documentación de Flujo Completo:- ✅ Tabla comparativa completa: Creación Automática vs Manual
- ✅ Guía completa de configuración de Matriz de Riesgo con instrucciones del dashboard
- ✅ Aclaración sobre función de accionistas (solo KYB, no KYC)
- ✅ Referencia de códigos de proveedores con ejemplos de uso
- ✅ Sección detallada de gestión de créditos con costos y flujos de trabajo
- ✅ Explicación Webhooks vs polling manual
- ✅ Tabla comparativa KYC Completo vs Verificaciones Individuales
- ✅ Advertencia completa sobre seguridad de face matching para bancos/fintech
- ✅ Tabla mejorada de endpoints API con casos de uso
- ✅ Diagrama de secuencia completo mostrando el flujo completo
- ✅ Aclaración Sandbox vs Producción
- ✅ Manejo de entidades duplicadas con ejemplos de código
- ✅ Documentación expandida de integrationCode
- ✅ Campos opcionales marcados con ejemplos (attributes, entityData)
- ✅ Ejemplos de creación de entidad mínima vs completa
Idiomas
Todas las mejoras disponibles en:- 🇺🇸 English
- 🇪🇸 Español
- 🇧🇷 Português
Impacto
- 14 preguntas de cliente respondidas inline
- 12 archivos de documentación actualizados
- 0 enlaces rotos
- Experiencia de onboarding de desarrolladores mejorada
Documentación Multi-idioma Mejorada
Estructura de documentación mejorada con traducciones completas en español y portugués.Cambios
- Cobertura completa de traducción para KYC, KYB y Monitoreo de Transacciones
- Terminología consistente en todos los idiomas
- Ejemplos específicos del idioma (DNI para España, CPF para Brasil, etc.)
Idiomas Disponibles
- Inglés (EN) - Principal
- Español (ES) - Completo
- Portugués (PT) - Completo
Lanzamiento de Documentación gu1
Lanzamiento inicial de documentación API completa.Funcionalidades Principales
- Referencia API completa para todos los endpoints
- Guías de casos de uso (KYC, KYB, Monitoreo de Transacciones)
- Guías de integración de webhooks
- Tutoriales interactivos
- Soporte multi-idioma
Componentes
- API de entidades persona
- API de entidades empresa
- Flujos de validación KYC
- Monitoreo de transacciones
- Motor de reglas
- Matrices de riesgo
- Alertas e investigaciones