Basic Concepts

Provides a technical overview of the Envision product.

Supported Envision Versions: 1.0, 1.1, 1.2

Table of Contents

Introduction

Envision is an analytics platform that allows you to slice and dice your data to analyze every aspect of your business and digital strategy. It can help you collect data and identify patterns, trends, violations, baselines, or historical context. The domain of the data you wish to analyze is open ended. You may wish to analyze:

General API operations such as:

  • API usage patterns, such as by apps, by geographic region, or by users.
  • API performance patterns and trends by examining load, throughput, and latency
  • SLA violations

Business specific transactions such as:

  • Sales trends based on model in different regions
  • Channel partner effectiveness by examining sales volumes
  • Effectiveness of sales mediums
  • Effectiveness of different apps

Or business operations such as:

  • API/microservice lifecycle and bottlenecks
  • Time to market trends for client apps
  • Popularity of APIs
  • Customer satisfaction trends

The Envision product does not require any prior understanding of what the data it analyzes represents. It does not require any business understanding. It can analyze data from any business domain because it works using general analytical concepts.

Capabilities

Envision's capabilities can be broken down into different four categories, data definition, data enrichment & storage, data aggregation, and data analysis

Envision

Data Definition

The foundation for analytics is understanding and defining what data you have to work with and what you want to do with that data. This is what is done with the data definition capabilities of Envision.

Then the data must be collected. Envision at its core does not reach out to different business systems to collect data. Instead it provides a data storage API for clients to push the data into a highly scalable Envision data store. Connectors are then provided that are domain specific to extract data from different business systems and use the Envision data storage API. One such connector is provided by Akana Policy Manager which enables the extraction of business specific data from payload and stores it for future analysis. The use of the Envision data storage API is optional. Alternatively data can be saved directly to the Envision data store if access is permitted.

Data Storage

Envision also supports data enrichment during the storage process. This is the amending, or altering, of data before it is persisted based on information obtained from a different source. For example the business system might be just collecting the user-agent field but for proper charting the corresponding browser/OS/device may be what is persisted instead. Enrichment is performed by plugins invoked by the data storage API prior to persisting the data or by scheduled jobs to manipulate data not persisted through the API.

Data Analysis

Based on the data definition raw business data must be transformed into metrics that can be compared, charted, and trended. This is done by organizing, or grouping, the data in ways that can be queried with the proper granularity and purpose, and performing aggregating calculations on the data according to those groupings. For example calculating the average sales figures of each channel partner on a quarterly basis. This is what the Envision data aggregation capabilities provide.

Data Aggregation

Finally users of Envision want to view the aggregated data in ways that easily depict the trends, patterns, and violations they are looking for. Envision provides analysis capabilities for the user to do this. Envision does this through a highly tailorable charting and dashboard generation portal. It can also support the extraction of data through the use of an API so that third party visualization tools can be used.

The following illustration shows how Envision would interact with users and other systems.

Envision

Envision stores all data in a NoSQL database. Connectors extract data from business systems and call Envision APIs that store the data in the NoSQL database. Envision performs the needed aggregations on the data in the NoSQL database. The data is then available for viewing in a browser using the Envision web application in user designed dashboards and charts. Alternatively a Third Party reporting product can query the data from Envision.