Saltar a contenido

API Reportería

A continuación detallaremos el consumo de esta API de reportería que permite poder realizar extracción de data. Está compuesta de 2 métodos, el de autenticación y el de Ejecución.

Api CREATETOKEN

La api de autenticación se utiliza para obtener un Token bearer que es de uso obligatorio para consumir la API de ejecución.

En donde las credenciales usadas en el Json del Body se obtienen desde la interfaz de Lynn según el ambiente, por un usuario con perfil administrador para Tenant

Buena Práctica 👨‍🏫: se recomienda crear una credencial única para cada aplicación cliente que va consumir las API, esto permitirá dar de baja a una credencial sin afectar a otras aplicaciones.

Para agregar una nueva credencial hacemos click en el icono de Crear (+), ubicado en la esquina superior derecha el cual abrirá el siguiente formulario:

Nombre: Se debe colocar un nombre descriptivo que identifique la aplicación que consume la API.

Tenant: Se desplegará una lista con los tenant a los cuales el usuario tiene acceso. En este campo, el usuario debe seleccionar en cuál de los tenant disponibles desea crear la credencial. (Se incluirá entre paréntesis el número del Tenant a utilizar en la API).

Division: Las api de Reportería son mult-division, es decir puedes tener una o más divisiones seleccionadas, en la cual la información a recuperar son filtradas en base a esta configuración, es obligatorio tener al menos una división seleccionada en caso contrario al utilizar el token la API va devolver un error. Estas divisiones seran cargadas segun el tenant seleccionado en el campo anterior.

Token: Autogenerado (Valor a utilizar en la API).

Token Secreto: Autogenerado (Valor a utilizar en la API).

Webhook: Url en la cual Lynn notifica los mensajes para los clientes, este parámetro se usa para las API de mensajería, en la Api de reportería no aplica se deja vacío.

Uso Interno: funciones de aplicaciones propias de Lynn no aplica para el uso de las API.

Api EXECUTEREPORT

La siguiente API se utiliza para ejecutar un reporte, en la URL se incluye el tenant que estamos trabajando y el la GUID que identifica el reporte a consumir

En donde en el Header (Athorization), específicamente {{token}} es reemplazado por la respuesta obtenida en el CreateToken, y el body es un Json en la cual:

  • startDate: Obligatorio, es la fecha de origen del Filtro, formato “yyyy-MM-dd hh:mm:ss”

  • endDate: Obligatorio, es la fecha de fin del Filtro, formato “yyyy-MM-dd hh:mm:ss”

  • size: (Obligatorio) entero que indica el volumen máximo de registro a recuperar teniendo como tope 10000

Ejemplo de ejecución de la API

En la cual en el response obtenemos un JSON con los siguientes Valores.

  • isValid: Booleano que indica que si se ejecutó correctamente el reporte.

  • executionTime: tiempo que tarda en hacer la query.

  • idReporting: idReporte utilizado en la URL.

  • NameVisualization: Nombre del Reporte.

  • pageCount: cantidad de Querys adicionales que se debe ejecutar para obtener el total de registro.

  • result: es un arreglo JSON con el resultado del reporte, es del tipo , en donde cada key representa una columna, y cada objeto json reprenta un registro.

  • errors: se muestra errores en caso de que existan.

  • lastDocument: registro utilizado para paginar en caso de que sean muchos los registros a recuperar.

Paginación

Cuando un reporte recupera una cantidad muy grande de registros que supera la cantidad configurada en el parámetro size del request, es necesario aplicar paginación para recuperar el total de registro.

Identificamos que necesitamos paginar cuando en el response el parámetro pageCount es mayor a cero (0), este número indica la cantidad de querys adicionales a la original se debe repetir para recuperar el resto de la información en este caso se debe repetir la query original manteniendo los filtros (startDate, endDate, size) y adicional se incorpora el parámetro lastDocument obtenido en el response, y este último debe ser reemplazado con el recuperado en cada ciclo.

En el ejemplo Ejemplo de ejecución de la API, se procesa el resultado de la primera ejecución y luego se repite la búsqueda 2 veces más para obtener el total y la forma de ejecución se muestra en la siguiente imagen

Observar que lastDocument cambia, por ende en la siguiente query se debe actualizar en nuevo valor y repetir query.

ID y descripción de reportes disponibles

  • Show Dialogs:

    • ID: B0A26DFF-173F-4138-AB46-61273E52538A.
    • Descripción: Tabla con los diálogos disponibles.
  • Menu Detail:

    • ID: 542B8262-14EB-4FEF-9873-93EC8B439FB7.
    • Descripción: detalle de las opciones seleccionada de los menús.
  • Show Error:

    • ID: 192D8D34-2BE0-477D-94EE-C5B3198B15D5.
    • Descripción: Devuelve los errores asociados a una acción.
  • Detail Performance:

    • ID: CB7D310E-BF08-46ED-A5E9-24C744344018.
    • Descripción: devuelve información de la ejecución de los servicios.
  • Productivity Detail:

    • ID: 34175227-42BE-4A59-8B95-6F2EE6C14849.
    • Descripción: Información de auditoría sobre las acciones aplicadas a un flujo del tenant.
  • Survey result:

    • ID: 9C294B80-CCFF-44F7-B9D4-5909058D2513.
    • Descripción: Detalle del resultado de la encuesta.
  • Current Interactions

    • ID: 615DAD60-6EA5-4E19-AC37-5253170B86C0.
    • Descripción: Indicadores de Kyubo incluye tipificaciones.
  • Mark-NAVIGATION_USER

    • ID: A45EC705-6A38-426A-8D1F-9CAE4D311497
    • Descripción: Indicador de las marcas de navegación.
    • Ejemplo:
      {
          "timestamp": "2024-01-25T19:49:04.708600400Z",
          "session": "2f7bXXX-fff-4363-000-5d418XXXXXX",
          "division": "1",
          "channel_id": "26",
          "reportEnvironment": "testing",
          "intent": "ag_proximo_dia",
          "markName": "END_SESSION",
          "markValue": " -> ag_proximo_dia"
      }
      
  • Survey Result v2

  • ID: 468F3FC2-4406-4FD8-BD09-2788FC10A218

  • Descripción: Detalle del resultado de la encuesta V2 que incluye campos Custom.
Campo Ejemplo Descripción
@timestamp Apr 9, 2024 @ 15:20:49.608 Este campo contiene fecha y hora del registro
SessionId bd58e5e9-6260-0000-XXXX-77ccbe45XXXX Este campo contiene el ID de sesión de Lin
SurveyId bbbb666yyy66y-119b-4db1-bdb1-aaaa6767a6a76 Este campo contiene el ID de la encuesta
Criteria Rut El dato que será el criterio del registro
CriteriaValue 1111111-1 Valor del criterio del registro
Agent Name (empty) Nombre del Ejecutivo que atendió en
Title1 ¿Qué tan satisfecho estás con la atención...? Título de la primera pregunta
Options1 ⭐⭐
Response1 ⭐⭐⭐⭐⭐ Lo que respondió el cliente
Title2 ¿Fue resuelto tu requerimiento? Título de la 2da pregunta
Options2 SI,NO Opciones de respuesta de la 2da pregunta
Response2 SI Lo que respondió el cliente
Title3 RespuestaEncuesta02 Título de la 3ra pregunta
Options3 SI,NO Opciones de respuesta de la 3ra pregunta
Response3 SI Lo que respondió el cliente
Title4 RespuestaEncuesta02 Título de la 4ta pregunta
Options4 SI,NO Opciones de respuesta de la 4ta pregunta
Response4 SI Lo que respondió el cliente
Title5 RespuestaEncuesta02 Título de la 5ta pregunta
Options5 SI,NO Opciones de respuesta de la 5ta pregunta
Response5 SI Lo que respondió el cliente
Custom1 Ventas_Iquique Campo customizado, pude colocar por ejemplo la cola de transferencia en Genesys Cloud
Custom2 1b22eeeee-119b-4db1-bdb1-xxxxxxxx Campo customizado, pude colocar por ejemplo el ID de sesión en Genesys
Custom3 Campo customizado
  • Get Campaing Results
    • ID: 9FE42F19-0B8A-43A6-8BB0-604947E85160
    • Descripción: Obtener datos resultantes de la campaña solicitada. En referencia al estado del registro de campaña la API actualmente devuelve solo el último estado del registro.
    • Ejemplo Request y Response:
      Request :
      {
          "startDate": "2024-05-01 00:00:00",
          "endDate": "2024-05-30 00:00:00",
          "size": 10000,
          "campaingId": "0X1645XX-0EXX-49XX-BXX3-47C6CXXXXXXX"
      }
      
      Response:
      {
          "isValid": true,
          "executionTime": 235.6972,
          "idReport": "9fe42f19-0b8a-43a6-8bb0-604947e85160",
          "nameVisualization": "Get Campaing Result",
          "totalDocument": 3,
          "pageCount": 0,
          "lastDocument": "MQ==",
          "requestCharge": 0,
          "result": [
              {
                  "REQUEST_ID": "00000000-f9e0-4175-0000-9b00000000",
                  "CAMPAIGN_ID": "0X1645XX-0EXX-49XX-BXX3-47C6CXXXXXXX",
                  "CAMPAING_NAME": "Campaña de prueba",
                  "VALID_UNTIL": "2099-12-02T00:00:00",
                  "VALID_FOR_HOURS": "10000",
                  "CONTACT_CHANNEL_ID": "4",
                  "CONTACT_CHANNEL_NAME": "Skype",
                  "CONTACT_NAME": "MIGUEL JUAREZ",
                  "CONTACT_ID": "231f4147-38bf-4444-8404-ec93aXXXXX48",
                  "STATUS": "Sent",
                  "REQUEST_DATE": "2024-05-29T11:27:28.79",
                  "LAST_RESULT_DATE": "2024-05-29T11:27:34.507",
                  "DETAIL": "{ 'status' : '200', 'detail' : 'id: 0:12pr_MMPNQt2JYqOCKj_nbbHw_ynXryr0jPBP8cZ-zY6Sg5YJlW-9hShVGpvRewzI'}",
                  "LOAD_DESCRIPTION": "Default",
                  "REACTION_SESSION": null,
                  "EXPECTED_REACTION": "",
                  "REACTION": null,
                  "REACTED_AS_EXPECTED": null,
                  "REACTION_OUTOF_VALIDUNTIL": null,
                  "REACTION_OUTOF_VALIDFORHOURS": null
              },
              {
                  "REQUEST_ID": "12345678-1234-1234-1234-1234567890,
                  "CAMPAIGN_ID": "0X1645XX-0EXX-49XX-BXX3-47C6CXXXXXXX",
                  "CAMPAING_NAME": "Campaña de Navidad",
                  "VALID_UNTIL": "2099-12-02T00:00:00",
                  "VALID_FOR_HOURS": "10000",
                  "CONTACT_CHANNEL_ID": "16",
                  "CONTACT_CHANNEL_NAME": "Telegram",
                  "CONTACT_NAME": "Carlos Perez",
                  "CONTACT_ID": "95000000-905c-41f8-cccc-a8162c5cf89c",
                  "STATUS": "Sent",
                  "REQUEST_DATE": "2024-05-29T11:27:33.8",
                  "LAST_RESULT_DATE": "2024-05-29T11:27:39.14",
                  "DETAIL": "{ 'status' : '200', 'detail' : 'id: 407-405850970-f'}",
                  "LOAD_DESCRIPTION": "Default",
                  "REACTION_SESSION": null,
                  "EXPECTED_REACTION": "",
                  "REACTION": null,
                  "REACTED_AS_EXPECTED": null,
                  "REACTION_OUTOF_VALIDUNTIL": null,
                  "REACTION_OUTOF_VALIDFORHOURS": null
              },
              {
                  "REQUEST_ID": "6FFFFF-8888-4XXX-aXXX-XXXXXXXX1f",
                  "CAMPAIGN_ID": "0X1645XX-0EXX-49XX-BXX3-47C6CXXXXXXX",
                  "CAMPAING_NAME": "Campaña de Navidad",
                  "VALID_UNTIL": "2099-12-02T00:00:00",
                  "VALID_FOR_HOURS": "10000",
                  "CONTACT_CHANNEL_ID": "3",
                  "CONTACT_CHANNEL_NAME": "Teams",
                  "CONTACT_NAME": "Carlos Ignacio Reyes Perez",
                  "CONTACT_ID": "d9630000-3295-42d2-a848-952a41c1702c",
                  "STATUS": "Reacted",
                  "REQUEST_DATE": "2024-05-29T11:27:17.547",
                  "LAST_RESULT_DATE": "2024-05-29T11:29:28.67",
                  "DETAIL": "{ 'status' : '200', 'detail' : '{ 'message': 'The customer has reacted to the campaign message.', 'status': 'reacted' }' }",
                  "LOAD_DESCRIPTION": "Default",
                  "REACTION_SESSION": "7707e8b5-920d-4e86-8557-5bd3242f163a",
                  "EXPECTED_REACTION": "Carlos Ignacio Reyes Perez|***|Quiero|***|no quiero",
                  "REACTION": "holaaaa",
                  "REACTED_AS_EXPECTED": "false",
                  "REACTION_OUTOF_VALIDUNTIL": "false",
                  "REACTION_OUTOF_VALIDFORHOURS": "false"
              }
          ],
          "errors": []
      }
      

Limitaciones declaradas

Cuotas de consumo

rate-limit-by-key

  • Método '/CreateToken': Corresponde a 3 llamadas a la API cada 60 segundos.
  • Todos los otros métodos están limitados a 1 llamada a la API cada 4 segundos.

Cuotas por producto

Existen 2 tipos de producto:

Producto Básico: se activa por defecto al consumir la API. Permite:

  • Periodo: 43.200 segundos (12 horas)
  • Calls: 10.000
  • Bandwidth: 102.400 kilobytes (100 megabytes)

Producto Premium: es necesario solicitarlo a través de partner Lynn o asesor comercial quien sumistrará el Ocp-Apim-Subscription-Key válido. Permite:

  • Periodo: 43.200 segundos (12 horas)
  • Calls: 20.000
  • Bandwidth: 997.200 kilobytes (997.2 megabytes )

Para ejecutar un reporte con el producto Premium es necesario activar en los headers el parámetro Ocp-Apim-Subscription-Key, tal y como se muestra a continuación:

Para validar la cantidad de cuota que hay disponibles se puede utilizar en el POST: {{BaseUrl}}/api/LynnReporting/CreateToken?info

Descripción de errores

Código del error Descripción
429 rate limit is Exceeded. Try again in T seconds
403 Out of bandwidth quota. Quota will be replenished in T