Skip to content

Insight Open APIs

Introduction

You can install open APIs on your analyzer instance allowing the extraction of real-time measurements and key performance indicators (KPIs) related to Latency, Throughput and Reliability.

The APIs can extract selected data available in the existing visual dashboards such as latency measurement per protocol, aggregated KPIs for network and application latency levels and new network quality qualifiers such as volatility and stability.

The API output data is presented in JSON format for a given pair or QoSAgent-Reflector. The result can then be easily integrated into other external systems.

The A) Connectivity Insight API allows users to ask the analyzer instance for connectivity performance data about a specific QoSAgent using its AgentID. The request aims to capture the latest available data from the last 5 minutes.

The B) Throughput Insight API allows users to ask the analyzer instance for real time throughput measurements using the Lifbe protocol (when configured and activated). Download and Upload results in Mbps and associated Jitter results are retrieved using this API.

The C) Latency Insight API can be used to retrieve the latency measurements for a specific protocol and for a specific agent in a user determined time range set in seconds.

The D) Geoloc Insight API is used to query the latest average latency measured and its geographic coordinates in GPS format (when available and configured). Adding the optional time_range query parameter to the /api/v1/geoloc endpoint, allows users to specify the time period in seconds for which they want to retrieve historical geolocation data.

The E) Twamp Insight API can be used to query latest and detailed latency levels measured using the TWAMP Protocol (RFC 5357) for a given QoSAgent. The latency results are split between forward latency in ms, return latency in ms and processing latency in ms (i.e. time spent within the Reflector).

The F) Forecast Insight API provides the latest forecasted measures using statistical based mean and projection.

The G) Radio Insight API provides the latest radio/cellular measures.

The H) Networks API provides all the customer_id / networks on the analyzer.

The I) Agents API provides all the QoS-Agents attached to a customer_id, can include either, only the ID or, also including the metadata.

The API requires that you open and secure the port 12099 on your analyzer instance.

Download

First, download the latencetech_api.yaml file using the following command:

wget https://api.latence.ca/software/latencetech_api.yaml

The latencetech_api.yaml is a docker-compose file with the following contents:

version: '2.4'
services:
  latencetech_api:
    image: registry.latence.ca/software/latencetech_api:latest
    container_name: latencetech_api
    ports:
      - "12099:12099"
    extra_hosts:
      - "host.docker.internal:host-gateway"
    environment:
      - NODE_ENV=production
    restart: always
    volumes:
      - ${HOME}/.cached_lti_license_key:/root/.cached_lti_license_key

Launch

Launch the LatenceTech Insight API using docker-compose:

docker-compose -f latencetech_api.yaml pull
docker-compose -f latencetech_api.yaml up -d

The container should be deployed on the VM onto which you have an analyzer installed.

Usage

Authentication

The API uses API key authentication. Include your API key in the x-api-key header with every request:

x-api-key: your_api_key_here

You can retrieve the API key by examining container logs:

docker logs <api_container_ID>| grep "API Key:"

A) Connectivity Insight API

Used with the /api/v1/ci endpoint. You can see the measurements for the agents using the agent_id and customer_id parameters:

curl -H "x-api-key: your_api_key_here" -s -k https://<analyzer_IP>:12099/api/v1/ci?agent_id=<agentID>&customer_id=<customerID>

sample output:

{
    "CustomerID": "0",
    "AgentID": "0",
    "KPIs": {
        "tcpMs": 8.94,
        "udpMs": 9.53,
        "httpMs": 9.09,
        "httpsMs": 18,
        "icmpMs": 9.2,
        "twampMs": 9.45,
        "downloadThroughputMbps": 1383.58,
        "uploadThroughputMbps": 950.06,
        "networkLatencyMs": 9.32,
        "applicationLatencyMs": 11.39,
        "packetLossRatePercent": 0,
        "jitterMs": 6.1,
        "volatilityPercent": 46.2,
        "networkStabilityPercent": 65.5,
        "connectivityHealth": "Warning",
        "qualityOfExperience": 4.921,
        "expectedLatencyMS": 40,
        "expectedStabilityPercent": 98,
        "expectedPacketLossPercent": 0.1
    },
    "Attributes": {
        "time": "2025-03-26T14:01:23.305Z",
        "agentName": "GenericQoSAgent",
        "hardware": "Not-Applicable",
        "networkName": "OutScale-Network",
        "networkType": "Outscale",
        "gpsPos": "48.864716,2.349014",
        "details": "Generic QoSAgent preinstalled with OMI",
    },
    "APInotes": {
        "comment": "Results from LatenceTech ConnectivityInsight API version 2.1",
        "documentation": "Refer to docs.latence.ca for API details and data structure"
    }
}

B) Throughput Insight API

Used with the /api/v1/lifbe endpoint. You can display the real time data of throughput measurements using the Lifbe protocol using the agent_id and customer_id parameters:

curl -H "x-api-key: your_api_key_here" -s -k https://<analyzer_IP>:12099/api/v1/lifbe?agent_id=<agentID>&customer_id=<customerID>

sample output:

{
    "agentID": "1",
    "time": "2024-05-17T15:00:04.735Z",
    "lifbeDownload": 542.48,
    "lifbeUpload": 49.89,
    "jitterDownload": 1.23,
    "jitterUpload": 3.13,
    "networkInterface": "MOBILE",
    "networkType": "MOBILE_5G"
}

C) Latency Insight API

Used with the /api/v1/latency endpoint. You can see the measurements for a specific protocol for a specific agent in a user determined time range by adding 3 optional arguments to the query in addition to agent_id and customer_id parameters: 1) protocol (tcp, udp ,https, httpss, icmp, twamp)
2) time_range (in seconds) 3) chosen_time

curl -H "x-api-key: your_api_key_here" -s -k https://<analyzer_IP>:12099/api/v1/latency?agent_id=<agentID>&customer_id=<customerID>&protocol=tcp&time_range=400

sample output:

[   
    {
        "agentID": "1",
        "time": "2024-05-17T15:01:26.183Z",
        "measurement": "tcp_result",
        "value": 15.61
    },
    {
        "agentID": "1",
        "time": "2024-05-17T15:01:28.215Z",
        "measurement": "tcp_result",
        "value": 15.233
    }
]

Optional: the protocol parameter is optional, if not set, all protocols will be shown.

Optional: using the chosen_time parameter allows you to query data for a given time period, format start_time,end_time (ex: 2025-05-30T10:00:00Z,2025-06-15T17:00:00Z).
To not use with time_range.

The time specified has to be UTC, or the time zone configured for the analyzer (UTC by default)

curl -H "x-api-key: your_api_key_here" -s -k https://<analyzer_IP>:12099/api/v1/latency?customer_id=<customerID>&agent_id=<agentID&chosen_time=2025-07-07T16:12:26Z
2025-07-07T16:12:34Z

sample output:

[
  {
    "CustomerID": "0",
    "agentID": "9",
    "time": "2025-07-07T16:12:25.000Z",
    "tcp": 46.364,
    "udp": 48.355,
    "http": 49.572,
    "https": 96.752,
    "twamp": 47.791,
    "icmp": 48.5
  },
  {
    "CustomerID": "0",
    "agentID": "9",
    "time": "2025-07-07T16:12:30.000Z",
    "tcp": 48.233,
    "udp": 48.005,
    "http": 47.985,
    "https": 96.531,
    "twamp": 47.812,
    "icmp": 48.5
  }
]

D) Geoloc Insight API

You can use the mobile application (or a modem/CPE with geolocation retrieval enabled) and send GPS data to the analyzer, you will be able to check the current state of the latency as well as historical data with previous location.

Used with the /api/v1/geoloc endpoint. You can add the agent_id and customer_id parameters and an optional time_range (in seconds) to get historical data:

curl -H "x-api-key: your_api_key_here" -s -k https://<analyzer_IP>:12099/api/v1/geoloc?agent_id=<agentID>&customer_id=<customerID>

For historical data:

curl -H "x-api-key: your_api_key_here" -s -k https://<analyzer_IP>:12099/api/v1/geoloc?agent_id=<agentID>&customer_id=<customerID>&time_range=400

sample output:

{
    "agentID": "50",
    "time": "2024-05-17T15:01:20Z",
    "altitude": "39.1",
    "latitude": "45.4961001",
    "longitude": "-73.5619866",
    "applicationLatency": 10.213
}

E) Twamp Insight API

This API can be used to query latest and detailed latency levels measured using the TWAMP Protocol (RFC 5357) for a given QoSAgent. The latency results are as follow:
- TwampFwdDeltaMs = TWAMP Forward Delta (i.e. latency between QoSAgent -> Reflector) in milliseconds
- TwampRevDeltaMs = TWAMP Reverse Delta (i.e. latency between Reflector -> QoSAgent) in milliseconds
- TwampProcDeltaMs = TWAMP processing Delta (i.e. latency occurring within Reflector) in milliseconds

Used with the /api/v1/twamp endpoint. You can add the agent_id and customer_id parameters:

curl -H "x-api-key: your_api_key_here" -s -k https://<analyzer_IP>:12099/api/v1/twamp?agent_id=<agentID>&customer_id=<customerID>

sample output:

{
    "agentID": "12",
    "time": "2024-06-21T18:56:58.512Z",
    "TwampFwdDeltaMs":  0.32,
    "TwampRevDeltaMs":  0.94,
    "TwampProcDeltaMs": 0.18,
}

F) Forecast Insight API

This API provides the latest forecasted measures using statistical based mean and projection.

Used with the /api/v1/forecast endpoint. You can add the agent_id and customer_id parameters:

curl -H "x-api-key: your_api_key_here" -s -k https://<analyzer_IP>:12099/api/v1/forecast?agent_id=<agentID>&customer_id=<customerID>

sample output:

{
    "agentID": "1",
    "time": "2024-06-21T18:56:58.512Z",
    "projectedLatencyMs": 1.5,
    "forecastingIntervalMs": 3.28,
    "confidenceLevel": 0
}

G) Radio Insight API

This API provides the latest radio/cellular measures.

Used with the /api/v1/radio endpoint. You can add the agent_id and customer_id parameters:

curl -H "x-api-key: your_api_key_here" -s -k https://<analyzer_IP>:12099/api/v1/radio?agent_id=<agentID>&customer_id=<customerID>

sample output:

{
    "CustomerID": "0",
    "agentID": "1",
    "time": "2025-02-04T17:12:56.062Z",
    "networkName": "Bell",
    "networkType": "4G LTE",
    "cellID": "40",
    "SINR_dB": "2.147489",
    "RSSI_dBm": "-63",
    "RSRP_dBm": "-10",
    "RSRQ_dB": "-94"
}

Optional: using the chosen_time parameter allows you to query data for a given time period, format start_time,end_time (ex: 2025-05-30T10:00:00Z,2025-06-15T17:00:00Z) The time specified has to be UTC, or the time zone configured for the analyzer (UTC by default)

curl -H "x-api-key: your_api_key_here" -k https://<analyzer_IP>:12099/api/v1/radio?customer_id=<customerID>&agent_id=<agentID&chosen_time=2025-07-07T16:12:26Z
2025-07-07T16:12:34Z

sample output:

[
  {
    "CustomerID": "0",
    "agentID": "12",
    "time": "2025-07-08T15:21:07.94Z",
    "ECIO_dB": "0",
    "PCI": "908",
    "RSRP_dBm": "-101",
    "RSRQ_dB": "-13",
    "RSSI_dBm": "0",
    "SINR_dB": "15.5",
    "cellID": "22938075680",
    "networkName": "TELUS",
    "networkType": "5G"
  },
  {
    "CustomerID": "0",
    "agentID": "12",
    "time": "2025-07-08T15:21:17.932Z",
    "ECIO_dB": "0",
    "PCI": "908",
    "RSRP_dBm": "-101",
    "RSRQ_dB": "-13",
    "RSSI_dBm": "0",
    "SINR_dB": "16",
    "cellID": "22938075680",
    "networkName": "TELUS",
    "networkType": "5G"
  },
]

H) Networks API

This API provides the customer_ids of the analyzer.

Used with the /api/v1/networks endpoint. You do not need any parameters

curl -H "x-api-key: your_api_key_here" -s -k https://<analyzer_IP>:12099/api/v1/networks

sample output:

{
  "count": 1,
  "customerId": [
    "0"
  ]
}

I) Agents API

This API provides the customer_ids of the analyzer.

Used with the /api/v1/agents endpoint. You can add the customer_id parameter and the optional metadata=true to also recieve the metadata for each agent:

curl -H "x-api-key: your_api_key_here" -s -k https://<analyzer_IP>:12099/api/v1/agents?customer_id=<customer_id>&metadata=true

sample output:

{
  "CustomerID": "0",
  "count": 1,
  "agents": [
    {
      "id": "9",
      "name": "Montreal ref",
      "networkName": "AzNet",
      "networkType": "Azure Server Network",
      "hardware": "Azure Server",
      "details": "Azure Agent uses for Testing plateform",
      "gpsPosition": "-43.8121,78.3522"
    }
  ]
}

API Definition

An API definition file complies with the OpenAPI standard is available in yml format.
You can download the file here:

wget https://api.latence.ca/software/latencetech_api_definition.yml

Troubleshooting

customerID is required or agentID is required.

It is possible, depending on the environement you use, that the analyzer part of the query needs to be in quotation marks:

curl -H "x-api-key: your_api_key_here" -s -k "https://<analyzer_IP>:12099/api/v1/ci?agent_id=<agentID>&customer_id=<customerID>"