Extraer Registros de Empleo (Widget)
¿En México? Esta guía te guiará a través del proceso de usar nuestra API para extraer registros de empleo de manera segura y eficiente, permitiéndote verificar el empleo, entender el historial laboral y más.
Introducción
En esta guía, te guiaremos a través de todo lo que necesitas para extraer datos de empleo sobre tus usuarios utilizando nuestro widget. Esto incluye:
- Una visión general del flujo de datos
- Generación de un token de acceso para el widget y creación de un enlace
- Obtención de información de registros de empleo
Esta guía menciona actualmente un nuevo recurso que está en desarrollo: Empleos Actuales. Este recurso estará disponible en los próximos días, y actualizaremos esta guía una vez que esté listo. Por ahora, solo puedes extraer Registros de Empleo.
Prerrequisitos
Antes de proceder con tu integración, asegúrate de haber revisado nuestra guía de inicio. En la guía de inicio, crearás una cuenta de Belvo, generarás algunas claves de API de sandbox y configurarás una URL de webhook. Para propósitos de prueba y desarrollo de tu integración, recomendamos encarecidamente usar el entorno de Sandbox siempre que sea posible.
Flujo general de datos
El tiempo promedio que tarda Belvo en recuperar datos de empleo de una institución de empleo y enviarte un evento de webhook es de 15 segundos. Sin embargo, esto puede variar dependiendo de la capacidad de respuesta de la institución y su carga actual de solicitudes.
Belvo utiliza flujos de trabajo asincrónicos para mejorar tu flujo de datos (consulta el diagrama a continuación).
Cada vez que creas un enlace, Belvo extrae automáticamente todos los datos de empleo para ti en segundo plano, y una vez que tenemos todos los datos, te notificamos a través de un webhook que los datos están listos para ser recuperados. Para que podamos notificarte una vez que los datos estén listos, necesitarás proporcionar una URL a la que podamos enviar eventos.
Generar un token de acceso
El token de acceso devuelto es válido por 10 minutos y lo invalidamos tan pronto como un usuario conecta exitosamente su cuenta.
Para que el widget aparezca a tus usuarios finales, necesitas generar un token de access
en tu servidor y enviarlo a Belvo. Una vez que recibamos la solicitud, recibirás un objeto con dos claves: access y refresh. Pasa el valor de la clave access al iniciar el hosted widget.
Para generar un token de access
, simplemente realiza una llamada desde tu servidor a Belvo:
curl -X POST \
https://sandbox.belvo.com/api/token/ \
-H 'Content-Type: application/json' \
-d 'ver ejemplo de payload abajo'
{
"id": "YOUR_SECRET_ID",
"password": "YOUR_SECRET_PASSWORD",
"scopes": "read_institutions,write_links",
"stale_in": "365d",
"credentials_storage": "store",
"fetch_resources": ["EMPLOYMENT_RECORDS"],
"widget": {
"callback_urls": {
"success": "your-url-here://success",
"exit": "your-url-here://exit",
"event": "your-url-here://error"
},
"branding": {
"company_icon": "https://mysite.com/icon.svg",
"company_logo": "https://mysite.com/logo.svg",
"company_name": "ACME",
"company_terms_url": "https://belvo.com/terms-service/",
"overlay_background_color": "#F0F2F4",
"social_proof": true
},
"theme": [] // Ver nuestro artículo dedicado a la personalización del widget
}
}
Parámetro | Tipo | Requerido | Descripción | Ejemplo |
---|---|---|---|---|
id | string | true | Reemplaza YOUR_SECRET_ID con el ID secreto que generaste en el panel de Belvo. | |
password | string | true | Reemplaza YOUR_SECRET_PASSWORD con la contraseña secreta que generaste en el panel de Belvo. | |
scopes | string | true | El parámetro scopes contiene una lista de permisos que te permiten crear un enlace para el usuario. Este es un parámetro requerido y debe enviarse exactamente como se muestra. | |
stale_in | string | opcional | El parámetro stale_in te permite controlar por cuánto tiempo Belvo almacena los datos derivados del usuario. Para más información, consulta la sección stale_in de nuestro artículo sobre controles de retención de datos. | |
credentials_storage | string | opcional | El parámetro credentials_storage te permite controlar cuánto tiempo debe Belvo almacenar las credenciales para los usuarios. Si creas enlaces recurrentes, esto debe establecerse en store . Para más información, consulta la sección credentials_storage de nuestro artículo sobre controles de retención de datos. | |
fetch_resources | array de strings | true | En el parámetro fetch_resources , proporcionas una lista de recursos que deseas que Belvo recupere de manera asincrónica para el usuario. Para datos de registros de empleo en México, puedes enviar ["EMPLOYMENT_RECORDS", "CURRENT_EMPLOYMENTS"] . Nota: CURRENT_EMPLOYMENTS no está disponible en el entorno sandbox. | |
widget.callback_urls | object | true | En el objeto callback_urls , debes agregar enlaces a donde tu usuario debe ser redirigido en los siguientes casos:
| |
| object | true | En el objeto
También puedes agregar opcionalmente un color de fondo personalizado para cuando el widget se abra, así como desactivar el mensaje de Belvo sobre cuántas cuentas se han conectado. Para más información sobre las opciones de personalización y branding del widget, consulta nuestra guía dedicada. | |
widget.theme | array de objetos | opcional | Puedes opcionalmente agregar los colores de tu marca al widget usando el parámetro theme . Para más información sobre dónde aparecerán estos colores en el widget, consulta la sección dedicada Agregar colores personalizados al widget de nuestra guía de Branding. |
{
"access": "eyJhbGciOiJIUzUxMiIsInR5cCI6IkpXVCJ9.eyJ0b2tlbl90eXBlIjoiYWNjZXNzIiwiZXhwIjoxNzI3Mz...",
"refresh": "eyJhbGciOiJIUzUxMiIsInR5cCI6IkpXVCJ9.eyJ0b2tlbl90eXBlIjoicmVmcmVzaCIsImV4cCI6MjM0O...."
}
Inicia el widget en tu aplicación para tu usuario
A continuación, necesitarás redirigir a tu usuario al widget en una vista web dentro de tu aplicación, usando el token access
que recibiste de la solicitud /api/token/
:
https://widget.belvo.io/
?access_token={access_code}
&locale=mx
&institutions=planet_mx_employment
&access_mode=single
&external_id=HJLSI-897809
Parámetro | Requerido | Descripción |
---|---|---|
access_token | si | Reemplaza access_code con el token access que recibiste. |
locale | si | Para que el hosted widget funcione correctamente para tus usuarios en México, debes establecer el parámetro de consulta locale a mx . |
institutions | no | Con el parámetro institutions , puedes proporcionar una (o más) instituciones que deberían mostrarse en el widget. En el caso de los Registros de Empleo en México, recomendamos establecer este parámetro a imss_mx_employment,issste_mx_employment . |
access_mode | no | El tipo de enlace a crear (single o recurrent ). Para los Registros de Empleo en México, recomendamos usar enlaces single . Para más información sobre el access_mode de un enlace, consulta nuestra sección dedicada aquí. |
| altamente recomendado | Tu referencia interna para este usuario. Esto es extremadamente útil ya que puedes los datos que Belvo recupera para este usuario en tu sistema. El
|
Además, revisa nuestras secciones Iniciando el widget y eventos de callback de nuestra guía de Hosted Widget (Multi-Region).
¡Hecho! Belvo ahora se conectará a la institución y validará que el CURP proporcionado sea correcto. Una vez validado y creado tu enlace, Belvo cargará asincrónicamente los datos de empleo. Te enviaremos un webhook una vez que hayamos recuperado los datos para el enlace dado, y luego podrás extraerlos con una solicitud get.
Esperar un webhook y obtener datos de Registro de Empleo
Tan pronto como se crea tu enlace de empleo (para México), recuperamos de manera asincrónica los Registros de Empleo para el enlace y te enviamos el siguiente webhook:
Código del Webhook | Descripción |
---|---|
historical_update | El número total de Registros de Empleo encontrados para el enlace. |
En la carga útil del webhook incluimos el número de Registros de Empleo encontrados para el enlace.
{
"webhook_id": "03d1ca0d62db4f769488265d141047b7",
"webhook_type": "EMPLOYMENT_RECORDS",
"process_type": "historical_update",
"webhook_code": "historical_update",
"link_id": "2f5d361d-dad6-45d4-a0bf-26d479766067",
"request_id": "4363b08b-51eb-4350-9c74-5df5ac92a7f6",
"external_id": "your_external_id",
"data": {
"total_employment_record_profiles": 1 // El número total de perfiles de Registro de Empleo encontrados para el enlace
}
}
Una vez que recibas la notificación, puedes obtener más detalles haciendo la siguiente solicitud:
curl --request GET 'https://api.belvo.com/api/employment-records/?link=link_id' \
-u [Secret Key ID]:[Secret Key PASSWORD]
Parámetro de Consulta | Descripción | Ejemplo |
---|---|---|
link | El link_id que recibiste en la notificación del webhook. | 2f5d361d-dad6-45d4-a0bf-26d479766067 |
Esperar un webhook y obtener datos de Empleo Actual
Tan pronto como se crea tu enlace de empleo (para México), recuperamos de manera asincrónica los Empleos Actuales para el enlace y te enviamos el siguiente webhook:
Código del Webhook | Descripción |
---|---|
historical_update | El número total de registros de Empleo Actual encontrados para el enlace. |
En la carga útil del webhook incluimos el número de registros de Empleo Actual encontrados para el enlace.
{
"webhook_id": "03d1ca0d62db4f769488265d141047b7",
"webhook_type": "CURRENT_EMPLOYMENTS",
"process_type": "historical_update",
"webhook_code": "historical_update",
"link_id": "2f5d361d-dad6-45d4-a0bf-26d479766067",
"request_id": "4363b08b-51eb-4350-9c74-5df5ac92a7f6",
"external_id": "your_external_id",
"data": {
"total_current_employments": 1 // El número total de registros de Empleo Actual encontrados para el enlace
}
}
Una vez que recibas la notificación, puedes obtener más detalles haciendo la siguiente solicitud:
curl --request GET 'https://api.belvo.com/api/mx/current-employments/?link=link_id' \
-u [Secret Key ID]:[Secret Key PASSWORD]
Parámetro de Consulta | Descripción | Ejemplo |
---|---|---|
link | El link_id que recibiste en la notificación del webhook. | 2f5d361d-dad6-45d4-a0bf-26d479766067 |