Skip to content
This repository has been archived by the owner on Oct 5, 2021. It is now read-only.

Ballerina connector for Azure Time-series Inisights

License

Notifications You must be signed in to change notification settings

ballerina-attic/module-ballerinax-azure.timeseries

Repository files navigation

Module Overview

The Azure Insights connector allows you to query Azure Time-series Insights through the REST API. It also allows you to access metadata on environments along with querying for events and aggregates. It handles OAuth 2.0 authentication.

Azure Insights Operations

The ballerinax/azure.timeseries module allows you to perform the following operations.

  • Get all available environment meta data
  • Get environment availability
  • Get environment metadata
  • Query environment for events
  • Query environment for aggregates

Compatibility

Versions
Ballerina Language Swan Lake Preview5
Azure Time-series Insights API 2016-12-12

Feature Overview

Azure Insights Clients

There are 2 clients provided by Ballerina to interact with different API groups of the Timeseries Insights REST API.

  1. azure.timeseries:InsightsClient - This client is the top-most client in the Timeseries module. This can be used to get the relevant metadata associated with the environments available to the user.

  2. azure.timeseries:EnvironmentClient - This client can be used to get metadata or query a specific environment.

Getting Started

Prerequisites

Download and install Ballerina.

Pull the Module

Execute the below command to pull the Azure.Timeseries module from Ballerina Central:

ballerina pull ballerinax/azure.timeseries

Sample

The EnvironmentClient getEvents() remote function can be used to query events available in the environment.

import ballerina/log;
import ballerinax/azure.timeseries;
timeseries:ConnectionConfiguration connConfig = {
    tenantId: <Tenant Id>,
    clientId: <Client id>,
    clientSecret: <Client secret>
};

public function main() {

    timeseries:EnvironmentClient environmentClient = new(<Environment FQDN>, connConfig);

    EventsRequest eventsRequest = {
        searchSpan: {
            'from: {
                dateTime: "2019-12-30T00:00:00.000Z"
            },
            to: {
                dateTime: "2021-12-30T00:00:00.000Z"
            }
        },
        predicate: {
            eq: {
        'left: {
            property: "latitude",
            'type: "Double"
        },
        'right: 3.14
            }
        },
        top: {
            sort: [
                {
                    input: {
                        builtInProperty: "$ts"
                    },
                    'order: ORDER_DESCENDING
                }
            ],
            count: 5
        }
    };

    var response = environmentClient->getEvents(eventsRequest);
    if (response is EventsResponse) {
        io:println("Events " + response.events);
    } else {
        io:println(response.message());
    }
}