Skip to content

Latest commit

 

History

History
125 lines (79 loc) · 10.9 KB

File metadata and controls

125 lines (79 loc) · 10.9 KB

Symbl.ai Enterprise Conversation Application

The goal of this repository is to provide both:

  • an architecture for a highly scalable application with Enterprise class features used for Conversation Understanding
  • an off-the-shell Conversation Application implemented in an Enterprise-y Architecture

Characteristics of an Enterprise Conversation Application

What are some attributes of an Enterprise Application for Conversation Understanding? Here are some typical qualities that would probably fit this type of application:

  • Scalable - all aspects of the application can be scaled out to accommodate more operational capacity (ie microservices)
  • Highly Available - the application can absorb outages but still continue to function and be accessible to users
  • Data Resiliency - data strategic to the operation of the application is accessible despite disruptions
  • Data Recovery and Migration - Has the ability to withstand catastrophic failure and migrate data to other providers

In addition to the above characteristics, Enterprise-class features specifically a Conversation Analytics platform might also include but are not limited to:

  • Real-Time Response - Able to react to new information as it's happening
  • Historical Data - Conversation data is captured for purposes like dashboards, etc
  • Data Aggregation - Has the ability to detect trends or patterns based on historical data over time
  • Predictive Actions - Performing autonomous application driven actions based on data patterns discovered

Architecture Diagram Overview

This is a high-level block diagram, that satisfies the above characteristics, for what the architecture of an Enterprise Conversation could look like...

Enterprise Conversation Architecture

Feature Benefits for this Enterprise Conversation Architecture:

  • Build applications with a historical conversation context
  • Persist conversation insights (data ownership)
  • Build scalable conversation applications
  • Company’s business rules/logic pushed into backend server microservices
  • Dashboards, dashboards, dashboards
  • Historical data is air-gapped and can be backed up
  • UI isolation. Change all aspects of UI frameworks without changing the code
  • Also supports Asynchronous analysis of data

Deep Dive of this Architecture

This architecture consists of several components which differ based on the type of conversation application you are building. They are:

  • Symbl.ai Proxy/Dataminer Service
  • Symbl.ai Asynchronous Service
  • Middleware Plugin
  • Client Interface (Web, CLI, App, etc)

Symbl.ai Proxy/Dataminer Service

This Symbl.ai Proxy/Dataminer Service aims to ingest the data, create any additional metadata to associate with these insights, and then save this context to recall later. There happens to be an excellent platform that does all of the heavy lifting for us, cough cough the Symbl Platform. Using the Symbl Platform, we can extract these conversation insights without having to train models, have expertise in Artificial Intelligence or Machine Learning, or require a team of data scientists.

Preserving insights represents the first of two significant pieces of work in this design. In order to aggregate conversation insights from external conversation sources and through historical data, we need to have a method for persisting this data to recall and make associations to conversations happening now. This component bites off this aspect of the design.

This Proxy/Dataminer Service makes use of the Realtime/Streaming API to receive conversation insights from the Symbl Platform. For each realtime insight emitted by the platform, this component will persist the conversation insight into the graph database and then send a corresponding RabbitMQ message for that insight. This message will then be consumed by your middleware plugin to perform some action of your chosing.

Symbl.ai Asynchronous Service

This Symbl Asynchronous REST/Dataminer Service component can and should be re-used as-is. This does a lot of the heavy-lifting and will save you some time to implement a custom component and database schema that essentially can be reused as an off-the-shelf component. It is highly encouraged to use this component for reasons we will get into later on.

This REST/Dataminer Service makes use of the Asynchronous API to receive conversation insights from the Symbl Platform. This component exposes a REST endpoint which takes in a conversation ID and then retreives all of the conversation insights for that pre-processed conversation ID. For each insight retrieved from the platform, this component will also persist conversation insights into a graph database and then send a corresponding RabbitMQ message for each type of insight. This message will then be consumed by your middleware plugin to perform some action of your chosing.

Middleware Plugin

Middleware Plugins are a significant component required in this Enterprise Conversation Application for Conversation Analysis. It provides associations or defining the relationships between contextual insights and your business.

A Middleware Plugin is deeply tied to what your business cares about. This plugin, either in code or interfacing with another external system, captures your company's specific business rules, goals, or what you hope to achieve. For example, these business rules can then be used to notify others within the company to take action, create events that you might want to pass along to other software systems, or trigger actions you want to perform directly in this component.

There are two flavors of Middleware Plugins:

  • Realtime for processing conversation currently happening (like in a meeting)
  • Asynchronous for processing past/recorded conversations

To reiterate, since these plugins are codified business rules or actions for YOUR business, these plugins will most likely require to be built by YOU. Having said that, we decided to create a pluggable framework for your Middleware needs which means that there is a great deal of code reuse that can happen if you fully leverage this framework.

Client Application aka User Interface

If you are using this project to process Realtime Conversations, the last piece in this architecture is the Client-side Application. This is effectively your User Interface (UI). This interface can be an Angular Web UI, Golang Command Line Interface (CLI), another REST service, CPaaS application, etc.

This interfaces does not and probably will not be built from scratch. It's more likely you already have an interface that your customers or clients already use. You will augment that User Interface to receive these Application Specific Messages to display within your interface.

For example, your company might provide a sales enablement platform that uses conversation insights to help increase and drives sales for your customers. Within your customer conversation on your platform, you might have received a Symbl event that a customer mentioned the topic surrounding a product you have within your profolio. An Application Specific Messages can be sent to your sales person within your UI to discuss that particular product to your customer.

If you are processing ONLY Asynchronous conversations, you will not have an UI component to notify users and thus not need to send Application Specific Messages. Your UI will most likely consist of some kind of dashboard for your users to consume conversation insights.

How to Deploy the Example Application in this Repository

There are 3 main configurations for the implementation contained in this repo.

Realtime Conversation Processing To deploy this configuration, follow this setup guide: https://github.com/dvonthenen/enterprise-conversation-application/tree/main/docs/realtime-setup.md.

Realtime Conversation Processing

Asynchronous Conversation Processing To deploy this configuration, follow this setup guide: https://github.com/dvonthenen/enterprise-conversation-application/tree/main/docs/asynchronous-setup.md.

Asynchronous Conversation Processing.

Realtime and Asynchronous Conversation Process To deploy this configuration, follow each setup guide above. The setup is independent of each other and the only share components between these two configurations are the Neo4J Database and RabbitMQ Server.

More Information

If you are looking for a detailed description and even a video that walks through this architecture diagram, please look at this blog called Everything to Know About Enterprise Conversation Application for Conversation Aggregation.

Looking for more information about deployment strategies as they relate to storage, take a look at this blog post called Databases and Persistent Storage for Conversation Data.

Contact Information

You can reach out to the Community via: