Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@vivocha/bot-sdk

Package Overview
Dependencies
Maintainers
12
Versions
83
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@vivocha/bot-sdk

Vivocha BOT SDK: TypeScript / JavaScript SDK to create Vivocha chatbots

  • 3.0.2
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
18
increased by63.64%
Maintainers
12
Weekly downloads
 
Created
Source

Vivocha Bot SDK

JavaScript / TypeScript SDK to create Bot Agents and Filters for the Vivocha platform

Logo

This SDK allows to write Vivocha Bot Agents integrating existing bots, built and trained using your preferred bot / NLP platform. E.g., Dialogflow, IBM Watson Assistant (formerly Conversation), Wit.ai, Microsoft Bot framework, etc... By creating a BotManager it is possible to register multi-platform bot implementations and let Vivocha communicate with them through a well-defined and uniform message-based API.


Node.js v8.x or v10.x is required.

To start with the Bot SDK it is recommended to:

  • install it from NPM: npm i @vivocha/bot-sdk

or

  • download the latest stable release from here

Table of Contents


Overview

The Vivocha platform provides out-of-the-box native support for chat bots built using IBM Watson Assistant (formerly Conversation), Dialogflow and Microsoft Bot Framework platforms. This means that it is possible to integrate these particular bot implementations with Vivocha simply using the Vivocha configuration app and specificing few settings, like authentication tokens, and following some, very simple, mandatory guidelines when building the bot, at design time. The first sections of this documentation focus on building custom Bot Agents using the Bot SDK, which allows to integrate them with the Vivocha system with ease and also provides a library to quickly write bots using the Wit.ai NLP platform.

The last sections of this guide are dedicated to the integration guidelines for chatbots built with the four supported platforms: IBM Watson Assistant (formerly Conversation), Dialogflow, Microsoft Bot Framework and Wit.ai and about how to transfer contacts from a bot to another agent.

The following picture shows an high-level overview of the Vivocha Bot SDK and its software components.

Overview
FIGURE 1 - Overview of the main modules of the Bot SDK

Quick Start, by Example

The examples folder contains some samples of Bot Managers, a Wit.ai Bot implementation and a Filter, along with some related HTTP requests to show how to call their APIs.

See:

  • sample: dead simple bot Agent and Manager plus a Bot Filter, read and use the examples/http-requests/sample.http file to learn more and to run them;
  • dummy-bot: a simple bot (Agent and Manager) able to understand some simple "commands" to return several types of messages, including quick replies and templates. You can run it and connect to Vivocha as a custom Bot Agent (read more here), then just send to the bot the fullhelp text message by chat to discover its capabilities.
  • sample-wit: a simple bot using the Wit.ai platform.

TIP: For a quick start learning about the format of requests, responses and messages body, including quick replies and templates, see the Dummy Bot code.

IMPORTANT: To learn how to connect a bot to the Vivocha Platform, start from the related Vivocha documentation.


BotAgents and Manager

TL;DR

A BotAgent represents and communicates with a particular Bot implementation platform. A BotManager exposes a Web API acting as a gateway to registered BotAgents.

Usually, the steps to use agents and managers are:

  1. Write a BotAgent for every Bot/NLP platform you need to support, handling / wrapping / transforming messages of BotRequest and BotResponse types;
  2. create a BotAgentManager instance;
  3. register the BotAgents defined in step 1) to the BotAgentManager, through the registerAgent(key, botAgent) method, where key (string) is the choosen bot engine (e.g, Dialogflow, Watson, ...) and agent is a BotAgent instance;
  4. run the BotAgentManager service through its listen() method, it exposes a Web API;
  5. call the Web API endpoints to send messages to the bot agents in a uniform way. The manager forwards the message to the right registered BotAgent thanks to the engine.type message property, used as key in step 3). The API is fully described by its Swagger specification, available at http://<BotAgentManager-Host>:<port>/swagger.json.

BotFilters

TL;DR

A BotFilter is a micro (web) service to filter/manipulate/enrich/transform BotRequests and/or BotResponses. For example, a BotFilter can enrich a request calling an external API to get additional data before sending it to a BotAgent, or it can filter a response coming from a BotAgent to transform data before forwarding it to the user chat.

Basically, to write a filter you have to:

  1. Instantiate a BotFilter specifying a BotRequestFilter or a BotResponseFilter. These are the functions containing your logic to manipulate/filter/enrich requests to bots and responses from them. Inside them you can call, for example, external web services, access to DBs, transform data and do whatever you need to do to achieve your application-specific goal. A BotFilter can provide a filter only for requests, only for responses or both;
  2. run the BotFilter service through its listen() method, it exposes a Web API; the API is fully described by its Swagger specification, available at http://<BotFilter-Host>:<port>/swagger.json.

BotAgent

A BotAgent represents an abstract Bot implementation and it directly communicates with a particular Bot / NLP platform (like Dialogflow, IBM Watson Assistant, Microsoft Bots, and so on...). In the Vivocha model, a Bot is represented by a function with the following signature:

In Typescript:

(request: BotRequest): Promise<BotResponse>

In JavaScript:

let botAgent = async (request) => {
    // the logic to interact with the particular bot implementation
    // goes here, then produce a BotResponse message...
    ...
    return response;
}

BotRequest

Requests are sent to BotAgents, BotManagers and BotFilters. A BotRequest is a JSON with the following properties (in bold the required properties):

PROPERTYVALUEDESCRIPTION
eventstring: start or continue or end or a custom stringstart event is sent to wake-up the Bot; continue tells the Bot to continue the conversation; end to set the conversation as finished; a custom string can be set for specific custom internal Bot functionalities.
message(optional) object, see BotMessage belowthe message to send to the BotAgent
language(optional) string. E.g., en, it, ...language string, mandatory for some Bot platforms.
data(optional) objectan object containing data to send to the Bot. Its properties must be of basic type. E.g., {"firstname":"Antonio", "lastname": "Smith", "code": 12345}
context(optional) objectOpaque, Bot specific context data
tempContext(optional) objectTemporary context, useful to store volatile data; i.e., in bot filters chains.
environment(optional) objectVivocha specific environment data sent by the platform. Currently, the environment object can have the following (optional) properties: host, acct, hmac, campaignId, channelId, entrypointId, engagementId, contactId, token.
settings(optional) BotSettings object (see below)Bot platform settings.
BotMessage

Some contents and definitions of the Vivocha Bot Messages are inspired by the Facebook Messenger messages specification, but adapted and extended as needed by the Vivocha Platform. Currently, messages' quick_replies and template properties are supported ONLY in BotResponses.

Notes: Generally speaking, while messages containing quick replies or templates have no particular constraints about the number of elements (and buttons, etc...), please take into consideration that Facebook Messenger have some contraints about them, i.e., in the number of quick replies or buttons per message; therefore, if you're supporting chats also through the Facebook Messenger channel, then you need to be compliant to its specification (more details about Messenger messages constraints can be found here). Anyway, in case of an exceeding number of elements, the Vivocha platform will trim them before sending to Messenger clients.

A BotMessage can be of three different types: Text Message, Postback Message, Attachment Message.

Text Message

A Text BotMessage can be used by a bot to send from simple, text-based messages to more complex messages containing quick replies and templates.

A Text Message has the following properties (required are in bold):

PROPERTYVALUEDESCRIPTION
codestring, value is always messageVivocha code type for Bot messages.
typestring, value is textVivocha Bot message type.
bodystringthe message text body.
payload(optional) stringa custom payload, usually used to send back the payload of a quick reply or of a postback button in a BotRequest, after the user clicks / taps the corresponding UI button.
quick_replies_orientation(optional) string: vertical or horizontalin case of a message with quick_replies it indicates the quick replies buttons group orientation to show in the client; default is horizontal. Orientation option is supported by the official Vivocha interaction.
quick_replies(optional) an array of MessageQuickReply objects (see below)an array of quick replies.
template(optional) a MessageTemplate objecta template object.

Postback Message

A Postback Message can be sent to a bot to convey a simple text content and, optionally, a custom payload. Its properties are (required are in bold):

PROPERTYVALUEDESCRIPTION
codestring, value is always messageVivocha code type for Bot messages.
typestring, set to postbackVivocha Bot message type.
bodystringthe message text body.
payload(optional) stringa custom payload, usually used to send back the payload of a postback button of a template.

Attachment Message

A message containing an attachment that can be sent/received to/from a bot to send files. See Sending Attachments section in this document for more details about sending attachments to/from a bot.

Its properties are (required are in bold):

PROPERTYVALUEDESCRIPTION
codestring, value is always messageVivocha code type for Bot messages.
typestring, value is attachmentVivocha Bot message type.
urlstringthe URL from which download the attachment.
metaan object of Attachment Metadata typethis object contains some metadata about the attachment being sent.

BotSettings

Bot platform settings object. Along with the engine property (see the table below), it is possible to set an arbitrarily number of properties. In case, it is responsability of the specific Bot implementation / platform to handle them.

PROPERTYVALUEDESCRIPTION
engine(optional) BotEngineSettings object (see below)Specific Bot/NLP Platform settings.
BotEngineSettings

Its properties are (required are in bold):

PROPERTYVALUEDESCRIPTION
typestringUnique bot engine identifier, i.e., the platform name, like: Watson, Dialogflow, WitAi, Microsoft, custom, ...
settings(optional) objectSpecific settings to send to the BOT/NLP platform. E.g. for Watson Assistant (formerly Conversation) is an object like {"workspaceId": "<id>" "username": "<usrname>", "password": "<passwd>"}; for a Dialogflow bot is something like: {"token": "<token>", "startEvent": "MyCustomStartEvent"}, and so on... You need to refer to the documentation of the specific Bot Platform used.
MessageQuickReply

Its properties are (required are in bold):

PROPERTYVALUEDESCRIPTION
content_typestring, accepted value: textType of the content of the quick reply
title(optional) stringtitle of the quick reply (usually is the text shown in the quick reply UI button)
payload(optional) a string or a numberapplication specific value, string or number related to the quick reply
image_url(optional) stringa URL of an image to be shown in the quick reply UI

Example 1: A BotResponse message containing three simple quick replies

{
    ...
    "messages": [
        {
            "code": "message",
            "type": "text",
            "body": "Just an example of quick replies... which color?",
            "quick_replies": [
                {
                    "content_type": "text",
                    "title": "Red",
                    "payload": "red 1"
                },
                {
                    "content_type": "text",
                    "title": "Blue",
                    "payload": "blue 2"
                },
                {
                    "content_type": "text",
                    "title": "White",
                    "payload": "white 3"
                }
            ]
        }
    ],
    "event": "continue",
    "data": {}
}

Which is rendered by the Vivocha interaction app like in the following screenshot:

A BotResponse containing a message with quick replies

Example 2: A BotResponse message containing three quick replies with vertical orientation

{
    ...
    "messages": [
        {
            "code": "message",
            "type": "text",
            "body": "Just an example of quick replies... which color?",
            "quick_replies": [
                {
                    "content_type": "text",
                    "title": "Red",
                    "payload": "red 1"
                },
                {
                    "content_type": "text",
                    "title": "Blue",
                    "payload": "blue 2"
                },
                {
                    "content_type": "text",
                    "title": "White",
                    "payload": "white 3"
                }
            ],
            "quick_replies_orientation": "vertical"
        }
    ],
    "event": "continue",
    "data": {}
}

Which is rendered by the Vivocha interaction app like in the following screenshot:

A BotResponse containing a message with quick replies with vertical orientation

Example 3: A BotResponse message containing some quick replies with images

{
    ...
    "messages": [
        {
            "code": "message",
            "type": "text",
            "body": "Choose a team member",
            "quick_replies": [
                {
                    "content_type": "text",
                    "title": "Federico",
                    "payload": "federico 1",
                    "image_url": "https://www.vivocha.com/wp-content/uploads/2017/03/team_federico.png"
                },
                {
                    "content_type": "text",
                    "title": "Andrea",
                    "payload": "andrea 2",
                    "image_url": "https://www.vivocha.com/wp-content/uploads/2017/03/team_andrea.png"
                },
                {
                    "content_type": "text",
                    "title": "Antonio",
                    "payload": "antonio 3",
                    "image_url": "https://www.vivocha.com/wp-content/uploads/2017/05/team-antonio.png"
                },
                {
                    "content_type": "text",
                    "title": "Marco",
                    "payload": "marco 4",
                    "image_url": "https://www.vivocha.com/wp-content/uploads/2017/03/Marco_Amadori.png"
                }
            ]
        }
    ],
    "event": "continue",
    "data": {}
}

Which is rendered by the Vivocha interaction app like in the following screenshot:

A BotResponse containing a message with some quick replies containing an image

MessageTemplate

Properties are (required are in bold):

PROPERTYVALUEDESCRIPTION
typestring, accepted values are: generic or listTemplate type, currently only generic and list types are supported
elements(optional) an array of generic template Elementselements defined by TemplateElement object specification
buttons(optional) only in case of a template where type == list, an array of Button objectsthe buttons to display in the bottom part of the template.
TemplateElement

In a Template Element only the property title is mandatory, but at least one optional property among the following must be set in addition to it.

PROPERTYVALUEDESCRIPTION
titlestringthe text to display as title in the template rendering
subtitle(optional) stringan optional subtitle to display in the template
image_url(optional) stringa valid URL for an image to display in the template
default_action(optional) DefaultAction objectan object representing the default action to execute when the template is clicked / tapped
buttons(optional) an array of Button objectsthe buttons to display in the template element.

Example 4: A BotResponse message containing a generic template

{
    ...
    "messages": [
        {
            "code": "message",
            "type": "text",
            "body": "Just an example of generic template:",
            "template": {
                "type": "generic",
                "elements": [
                    {
                        "title": "Meow!",
                        "image_url": "https://upload.wikimedia.org/wikipedia/commons/thumb/5/5d/Adult_Scottish_Fold.jpg/1920px-Adult_Scottish_Fold.jpg",
                        "subtitle": "We have the right cat for everyone.",
                        "default_action": {
                            "type": "web_url",
                            "url": "https://en.wikipedia.org/wiki/Cat"
                        },
                        "buttons": [
                            {
                                "type": "web_url",
                                "url": "https://en.wikipedia.org/wiki/Cat",
                                "title": "View Website"
                            },
                            {
                                "type": "postback",
                                "title": "OK",
                                "payload": "ok abcd 123"
                            }
                        ]
                    }
                ]
            }
        }
    ],
    "event": "continue",
    "data": {}
}

which is rendered by the Vivocha interaction app like in the following screenshot:

A BotResponse message containing only one generic template

Example 5: A BotResponse message containing a carousel of generic templates

{
    ...
    "messages": [
        {
            "code": "message",
            "type": "text",
            "body": "Just an example of generic template:",
            "template": {
                "type": "generic",
                "elements": [
                    {
                        "title": "Meow!",
                        "image_url": "https://upload.wikimedia.org/wikipedia/commons/thumb/5/5d/Adult_Scottish_Fold.jpg/1920px-Adult_Scottish_Fold.jpg",
                        "subtitle": "Scottish fold",
                        "default_action": {
                            "type": "web_url",
                            "url": "https://en.wikipedia.org/wiki/Cat"
                        },
                        "buttons": [
                            {
                                "type": "web_url",
                                "url": "https://en.wikipedia.org/wiki/Cat",
                                "title": "View Website"
                            },
                            {
                                "type": "postback",
                                "title": "OK",
                                "payload": "ok abcd 123"
                            }
                        ]
                    },
                    {
                        "title": "Meow!",
                        "image_url": "https://upload.wikimedia.org/wikipedia/commons/thumb/c/c0/Tajeschidolls_Beren_of_LoveLorien_Ragdoll_Seal_Mink_Lynx_Bicolor.jpg/1024px-Tajeschidolls_Beren_of_LoveLorien_Ragdoll_Seal_Mink_Lynx_Bicolor.jpg",
                        "subtitle": "Ragdoll",
                        "default_action": {
                            "type": "web_url",
                            "url": "https://en.wikipedia.org/wiki/Cat"
                        },
                        "buttons": [
                            {
                                "type": "web_url",
                                "url": "https://en.wikipedia.org/wiki/Cat",
                                "title": "View Website"
                            },
                            {
                                "type": "postback",
                                "title": "OK",
                                "payload": "ok abcd 123"
                            }
                        ]
                    }
                ]
            }
        }
    ],
    "event": "continue",
    "data": {}
}

Which is shown in the Vivocha web interaction app as in the following screenshot:

A BotResponse message containing a carousel of generic templates

Example 6: A BotResponse message containing a list template

{
    ...
    "messages": [
        {
            "code": "message",
            "type": "text",
            "body": "List template",
            "template": {
                "type": "list",
                "elements": [
                    {
                        "title": "Documentation part 1 - 2018",
                        "subtitle": "All documents about our products available in 2018. Advertisement, User's guides, technical info...",
                        "default_action": {
                            "type": "web_url",
                            "url": "https://www.vivocha.com"
                        }
                    },
                    {
                        "title": "Documentation part 2 - 2017",
                        "subtitle": "All documents about our products available in 2017. Advertisement, User's guides, technical info...",
                        "default_action": {
                            "type": "web_url",
                            "url": "https://www.vivocha.com"
                        }
                    },
                    {
                        "title": "Documentation part 3 - 2011-2016",
                        "subtitle": "All deprecated documents about old products no more available...",
                        "default_action": {
                            "type": "web_url",
                            "url": "https://www.vivocha.com"
                        }
                    }
                ],
                "buttons": [
                    {
                        "type": "postback",
                        "title": "More",
                        "payload": "view_more"
                    }
                ]
            }
        }
    ],
    "event": "continue",
    "data": {}
}

Which is rendered by the Vivocha interaction app like in the following screenshot:

A BotResponse message containing a list template

Example 7: A BotResponse message containing a list template with links (buttons)

{
    ...
   "messages": [
        {
            "code": "message",
            "type": "text",
            "body": "list template",
            "template": {
                "type": "list",
                "elements": [
                    {
                        "title": "Visit our website",
                        "subtitle": "All our products in one place. News, plans, tips, prices.",
                        "default_action": {
                            "type": "web_url",
                            "url": "https://www.pintux.it"
                        },
                        "buttons": [
                            {
                                "title": "View",
                                "type": "web_url",
                                "url": "https://www.pintux.it"
                            }
                        ]
                    },
                    {
                        "title": "Technical documentation",
                        "subtitle": "Technical info, API documentation, tutorials and more...",
                        "default_action": {
                            "type": "web_url",
                            "url": "https://www.lensculture.com"
                        },
                        "buttons": [
                            {
                                "title": "OK",
                                "type": "postback",
                                "payload": "OK-123"
                            }
                        ]
                    }
                ],
                "buttons": [
                    {
                        "type": "postback",
                        "title": "More",
                        "payload": "view_more"
                    }
                ]
            }
        }
    ],
    "event": "continue",
    "data": {}
}

Which is rendered by the Vivocha interaction app like in the following screenshot:

A BotResponse message containing a list template with links (buttons)

DefaultAction

Properties are (required are in bold):

PROPERTYVALUEDESCRIPTION
typestring, admitted value is only web_urldefault action type, it always refers to a web URL
urlstringa valid URL to open in the browser when executing the default action

Button

A Button object can be one of the following types: PostbackButton, WebURLButton or a CustomEventButton

PostbackButton

A postback button is used to send back to the bot a response made of a title and a payload.

Properties are (required are in bold):

PROPERTYVALUEDESCRIPTION
typestring, always set to postbackthe postback button type
titlestringthe button text to display and to send back in the message body
payloadstringa custom payload to send back to the bot
WebURLButton

A WebURL button is used to open a web page at the specified URL.

Properties are (required are in bold):

PROPERTYVALUEDESCRIPTION
typestring, always set to web_urlthe WebURL button type
titlestringthe button text to display
urlstringthe URL of the page to open when the button is pressed
CustomEventButton

This button allows to fire a custom event in the website page where the Vivocha interaction app / chat is running. In order to work, a contact-custom-event must be configured in the particular Vivocha Campaign.

Properties are (required are in bold):

PROPERTYVALUEDESCRIPTION
typestring, a custom type string excluding web_url and page_eventthe custom type
titlestringthe button text to display

BotRequest Example

Example of a request sent to provide the name in a conversation with a Wit.ai based Bot.

{
    "language": "en",
    "event": "continue",
    "message": {
        "code": "message",
        "type": "text",
        "body": "my name is Antonio Watson"
    },
    "settings": {
       "engine": {
          "type": "WitAi",
          "settings": {
            "token": "abcd-123"
          }
        }
    },
    "context": {
        "contexts": [
            "ask_for_name"
        ]
    }
}

Attachment Metadata

Attachment metadata object.

Properties are (required are in bold):

PROPERTYVALUEDESCRIPTION
mimetypestringMIME Type of the attachment
originalUrl(optional) stringthe original URL of the attachment. It could be different than the attachment url property value in case the attachment is being served by a CDN or remote storage
originalUrlHash(optional) stringa hash related to the attachment, it will be automatically "calculated" by Vivocha platform
originalId(optional) stringunique Id, automatically assigned by Vivocha when uploaded using the BotAgentManager.uploadAttachment() method
originalName(optional) stringthe original file name of the attachment
desc(optional) stringbrief description of the attachment
size(optional) numberattachment size, as in normal HTTP Content-Length header
ref(optional) stringA reference ID to correlate the attachment message. It can be used by the client to avoid showing the attachment message twice in the user chat widget.

BotResponse

Responses are sent back by BotAgents, BotManagers and BotFilters to convey a Bot platform reply back to the Vivocha platform.

A BotResponse is a JSON with the following properties and it is similar to a BotRequest, except for some fields (in bold the required properties):

PROPERTYVALUEDESCRIPTION
eventstring: continue or endcontinue event is sent back to Vivocha to continue the conversation, in other words it means that the bot is awaiting for the next user message; end is sent back with the meaning that Bot finished its tasks.
messages(optional) an array of BotMessage objects (same as BotRequest)the messages sent back by the BotAgent including quick replies and templates with images, buttons, etc...
language(optional) string. E.g., en, it, ...language string code
data(optional) objectan object containing data collected or computed by the Bot. Its properties must be of simple type. E.g., {"firstname":"Antonio", "lastname": "Smith", "code": 12345, "availableAgents": 5}
context(optional) objectOpaque, Bot specific context data. The Vivocha platform will send it immutated to the Bot in the next iteration.
tempContext(optional) objectTemporary context, useful to store volatile data, i.e., in bot filters chains.
raw(optional) objectraw, platform specific, unparsed bot response. The bot can fill it with arbitrary data or with the original response from a specific bot platform, for example. The raw property it will never be forwarded to the client (i.e., the Vivocha interaction app) but it can be used, for example, by response bot filters chains.
BotResponse Examples

An example of text response sent back by a Wit.ai based Bot. It is related to the request in the BotRequest sample above in this document.

{
  "event": "continue",
  "messages": [
    {
      "code": "message",
      "type": "text",
      "body": "Thank you Antonio Watson, do you prefer to be contacted by email or by phone?"
    }
  ],
  "data": {
    "name": "Antonio Watson"
  },
  "context": {
    "contexts": [
      "recontact_by_email_or_phone"
    ]
  },
  "raw": {
    "_text": "my name is Antonio Watson",
    "entities": {
      "contact": [
        {
          "suggested": true,
          "confidence": 0.9381,
          "value": "Antonio Watson",
          "type": "value"
        }
      ],
      "intent": [
        {
          "confidence": 0.9950627479,
          "value": "provide_name"
        }
      ]
    },
    "msg_id": "0ZUymTwNbUPLh6xp6"
  }
}

Another BotResponse example, including three quick replies:

{
    "event": "continue",
    "messages": [
        {
            "code": "message",
            "type": "text",
            "body": "Hello Alice, please choose a color...",
            "quick_replies": [
                {
                    "content_type": "text",
                    "title": "Red",
                    "payload": "red"
                },
                {
                    "content_type": "text",
                    "title": "Blue",
                    "payload": "blue"
                },
                {
                    "content_type": "text",
                    "title": "White",
                    "payload": "white"
                }
            ]
        }
    ],
    "data": {
      "name": "Alice"
    }
}

A BotResponse including a List Template:

{
    "event": "continue",
    "messages": [{
                    "code": "message",
                    "type": "text",
                    "body": "A list template",
                    "template": {
                        "type": "list",
                        "elements": [
                            {
                                "title": "Item 1",
                                "subtitle": "This is the subtitle for the item number one linked to the Vivocha website",
                                "default_action": {
                                    "type": "web_url",
                                    "url": "https://www.vivocha.com"
                                }
                            },
                            {
                                "title": "Item 2",
                                "subtitle": "This is the subtitle for the item number two linked to the Vivocha Tech blog",
                                "default_action": {
                                    "type": "web_url",
                                    "url": "http://tech.vivocha.com",
                                }
                            },
                            {
                                "title": "Item 3",
                                "subtitle": "This is the subtitle for the item number three linked to the Vivocha Team webpage",
                                "default_action": {
                                    "type": "web_url",
                                    "url": "https://www.vivocha.com/team"
                                }
                            }
                        ],
                        "buttons": [
                            {
                                "type": "postback",
                                "title": "More",
                                "payload": "view_more"
                            }
                        ]
                    }
                }
    ],
    "data": {
      "name": "Alice"
    }
}

BotManager

A BotManager is a bot registry microservice, which basically provides two main functionalities:

  1. it allows to register an undefined number of BotAgents;
  2. it exposes a web API to send messages and receive responses to/from BotAgents, acting as a gateway using a normalized interface.

Registering a Bot Agent

In the code contained in the examples directory it is possible to read in detail how to create and register Bot Agents. Briefly, to register a BotAgent, BotManager provides a registerAgent() method:

const manager = new BotAgentManager();
manager.registerAgent('custom', async (msg: BotRequest): Promise<BotResponse> => {

    // Bot Agent application logic goes here
    // I.e., call the specific Bot implementation APIs (e.g., Watson, Dialogflow, etc...)
    // adapting requests and responses.
    ...
}

The BotManager allows to register several BotAgents by specifying different type parameters (first param in registerAgent() method. E.g., Watson, Dialogflow, WitAi, custom, ecc... ). In this way it is possible to have a multi-bot application instance, the BotManager will forward the requests to the correct registered bot, matching the registered BotAgent type with the settings.engine.type property in incoming BotRequests.

BotManager Web API

The BotManager listen() method starts a Web server microservice, exposing the following API endpoint:

POST /bot/message - Sends a BotRequest and replies with a BotResponse.

After launching a BotManager service, the detailed info, and a Swagger based API description, are always available at URL:

http(s)://<Your-BotAgentManager-Host>:<port>/swagger.json


Bot Filters

BotFilters are Web (micro)services to augment or adapt or transform BotRequests before reaching a Bot, and/or to augment or adapt or transform BotResponses coming from a Bot before returning back them to the Vivocha platform. It is also possible to chain several BotFilters in order to have specialized filters related to the application domain.

Next picture shows an example of a BotFilters chain:

BotFilters Chain
FIGURE 2 - An example of a BotFilters chain configured using Vivocha

The same BotFilter instance can act as a filter for requests, as a filter for responses or both. See BotFilter class constructor to configure it as you prefer.

Figure 2 shows an example of a BotFilter chain: BotFilters A, B and C are configured to act as request filters; in other words they receive a BotRequest and return the same BotRequest maybe augmented with more data or transformed as a particular application requires. For example, BotFilter A may add data after reading from a DB, BotFilter B may call an API or external service to see if a given user has a premium account (consequentially setting in the request a isPremium boolean property), and so on... When it's time to send a request to a BotAgent (through a BotManager), the Vivocha platform will sequentially call all the filters in the request chain before forwarding the resulting request to the Bot.

BotFilter D is a response filter and notice that BotFilter A is also configured to be a response filter; thus, when a response comes from the Bot, Vivocha sequentially calls all the response BotFilters in the response chain before sending back to a chat the resulting response. For example: a response BotFilter can hide or encrypt data coming from a Bot or it can on-the-fly convert currencies, or format dates or call external services and APIs to get useful additional data to send back to users.

As an example, refer to examples/sample.ts(.js) files where it is defined a runnable simple BotFilter.

BotFilter Web API

The BotFilter listen() method runs a Web server microservice, exposing the following API endpoints:

POST /filter/request - For a request BotFilter, it receives a BotRequest and returns a BotRequest.

POST /filter/response - For a response BotFilter, it receives a BotResponse and returns a BotResponse.

After launching a BotFilter service, the detailed info, and a Swagger based API description, are always available at URL:

http(s)://<Your-BotFilter-Host>:<port>/swagger.json


About Vivocha Bots and Transfers to Human Agents

In the Vivocha model, a Bot is just like a "normal" agent, able to handle contacts, chat with users and also able to transfer a particular current contact to another agent (a human agent or, maybe, to another Bot). Configuring a Bot to fire a transfer to other agents in Vivocha is a quite straightforward process.

  1. using the Vivocha console, configure the bot to manage transfers. A transfer can be of two types: transfer to tag and transfer to agent. The former will fire a transfer to other agents having a specified tag where the latter only to a specific agent by (nick)name. Therefore, creating a transfer rule involves specifying a data key (a property name) to be found in a BotResponse and its corresponding value to check, plus the agents tag or nick name to transfer to. For example, the next picture shows a transfer to tag Bot configuration which will be fired anytime the BotResponse data object contains a sub-property named transferToAgent set to sales in order to transfer the contact to an agent tagged with sales.
A contact transfer configuration example
FIGURE 4 - Vivocha Bots can transfer contacts to other agents (human agents or, why not?, to another Bot) when necessary. This picture shows a transfer to tag Bot configuration fired anytime the BotResponse data object contains a sub-property named transferToAgent set to sales, in order to transfer the contact to another agent tagged with sales
  1. when a transfer is required, the particular Bot implementation must return a BotResponse with: the event property set to end AND the data property containing the configured transfer sub-property (as transferToAgent in the previous example) set to the specified value. The following JSON snippet shows a BotResponse for the transfer configuration described in step 1)
{
  "event": "end",
  "messages": [ {
    "code": "message",
    "type": "text",
    "body": "OK I'm transferring you to a sales agent. Bye! 😊"
  } ],
  "settings": {
    "engine": {
        "type": "custom",
        "settings": {...}
     }
  },
  "data": {
    "firstname": "Daenerys",
    "lastname": "Targaryen",
    ...
    "transferToAgent": "sales"
  }
}

NOTES:

  • if your bot is built through the IBM Watson Assistant platform, and you're using the built-in Vivocha Watson integration, then set the transfer property directly as a context variable in the dialog node which ends the conversation and a transfer is required;

  • if the bot is developed through the Dialogflow platform, and you're using the built-in Vivocha Dialogflow integration, then set the transfer property in the parameters property of a returned context (i.e., using a Firebase Cloud Functions-based fulfillment);

  • if the bot is written using Wit.ai and the module provided by this SDK, just return the transfer property in the BotResponse data field (see examples/dummy-bot(.ts | .js) code for the transfer case).

  • if the bot is written using the Microsoft Bot Framework and you're using the built-in Vivocha driver, then see the dedicated Transfer to other agents chapter in the Microsoft Bots section of this document.


Sending Attachments

When a bot based on the Vivocha Bot SDK needs to send an attachment to a chat user, there are two available options, depending on the will to save the attachment in the Vivocha Secure Storage before sending it to the final user or not.

Sending Attachments using the Vivocha Secure Storage

This case is a two step process. To upload the attachment a token is needed. At first (and only the first time), start message (event === "start" in the BotRequest), Vivocha sends in the environment BotRequest property also an authentication token; Bot implementations, whishing to use this feature, MUST save the token, i.e, adding it to context property in the resulting BotResponse, for later use.

  1. upload the attachment to the Vivocha Secure Storage: the BotAgentmanager class provides the uploadAttachment() static method in order to save the attachment in the Vivocha Secure Storage. Its signature is as follows:
static async uploadAttachment(attachmentStream: Stream, attachmentMeta: AttachmentMeta, environment: EnvironmentInfo): Promise<Attachment>

where:

  • attachmentStream is a Node.js Stream from which read the attachment bytes. The Stream can be created from a file or from a remote URL, see examples/dummy-bot.ts (.js) for the code about these two cases;

  • attachmentMeta is an object of type Attachment Metadata. In this case it is enough to specify only the mimetype and desc properties, for example: { mimetype: 'image/jpeg', desc: 'Our 500 car in red color' };

  • environment, the environment object property sent by Vivocha to the bot in each BotRequest that MUST also include the token property. At first (and only the first time), start message (event === "start" in the BotRequest), Vivocha sends in the environment BotRequest property also a token; Bot implementations, whishing to use this feature, MUST save this token and, in order to properly call this method, include it in the BotRequest environment property. Then, an example of correct environment param to call this method is something like:

"environment": {
    "campaignId": "5bc...",
    "channelId": "web",
    "entrypointId": "1234",
    "engagementId": "5678",
    "contactId": "20166...ba",
    "host": "f11.vivocha.com",
    "acct": "acmecorp",
    "hmac": "bf51...b71",
    "token": "abcd.123.4567..."
}

The method will return a Promise containing an Attachment object. The Vivocha Attachment object has the following properties:

PROPERTYVALUEDESCRIPTION
urlstringthe URL from which download the attachment from the Vivocha Secure Storage
metaan object of Attachment Metadata typethis object contains metadata about the uploaded attachment.

N.B. Uploading an attachment to Vivocha Secure Storage doesn't automatically result in sending an Attachment Message to the user. Thus, the step 2 below is needed:

  1. prepare and send a Vivocha Attachment Message: using the Attachment object resulting from the BotAgentmanager.uploadAttachment() method invocation, compose and send an Attachment Message filling the required url and meta properties with the values of the corresponding properties in the Attachment object obtained from step 1.

Example 8: Composing an Attachment Message (related to an image uploaded to Vivocha Secure Storage) in a BotResponse:

    ...
    const fileURL = 'https://upload.wikimedia.org/wikipedia/commons/c/c9/Moon.jpg';
    const attachMeta = await BotAgentManager.uploadAttachment(request(fileURL) as Stream, { mimetype: 'image/jpeg', desc: 'Moon, not the dark side' }, environmentWithToken);
    const messages = [ {
        code: 'message',
        type: 'attachment',
        url: attachMeta.url,
        meta: attachMeta.meta
      } as AttachmentMessage
    ];
    const response: BotResponse = {
      messages,
      event: 'continue',
      context: {...},
      ...
    };
    
    // send back the BotResponse
    ...

In the example above, request is the homonymous Node.js module.

Sending Attachments directly, not using the Vivocha Secure Storage

When uploading the attachment to Vivocha Secure Storage is not required and it's ok to send it through its public URL, then just send an Attachment Message using the original attachment info to send.

Example 9: an Attachment Message (not being uploaded to Vivocha Secure Storage) in a BotResponse:

    ...
    "messages": [{
                    "code": "message",
                    "type": "attachment",
                    "url": "https://media.giphy.com/media/l1KsqYM8Zt3yG3tVS/giphy.gif",
                    "meta": {
                        "originalUrl": "",
                        "originalName": "Scream.gif",
                        "mimetype: 'image/gif"
                    }
              }];
    ...

Asynchronous Bot Responses

Generally, the Vivocha - Bots communication model is synchronous (request-response): Vivocha sends an HTTP request to a Bot(Manager, Agent) and it expects to receive a response within a standard HTTP timeout amount of time.

However, in some cases involving time-consuming long responses from a bot, it is needed to send back a BotResponse when available, following an asynchronous model. This mode works as follows:

  1. At first (and only the first time), start message (event === "start" in the BotRequest), Vivocha sends in the environment BotRequest property also a token; Bot implementations, whishing to use this feature, MUST save the token, i.e, adding it to context property in the resulting BotResponse.

Thus, an example of BotRequest environment for a start message could be:

"environment": {
    "campaignId": "5bc...",
    "channelId": "web",
    "entrypointId": "1234",
    "engagementId": "5678",
    "contactId": "20166...ba",
    "host": "f11.vivocha.com",
    "acct": "acmecorp",
    "hmac": "bf51...b71",
    "token": "abcd.123.4567..."
}
  1. At any time, when the bot implementation needs to send a BotResponse to Vivocha (then to the user), there are two options:

    2.1. Invoke the BotAgentManager.sendAsyncMessage() static method

    The method has the following signature:

    static async sendAsyncMessage(response: BotResponse, environment: EnvironmentInfo): Promise<http.FullResponse>
    

    where:

    • response is a complete BotResponse
    • environment is an environment object as above and MUST include the token property.

    And it returns a Promise with a http.FullResponse object containing the call result.

    2.2. Directly call the following Vivocha API endpoint:

    POST https://<HOST>/a/<ACCOUNT_ID>/api/v2/contacts/<CONTACT_ID>/bot-response
    

    with HTTP headers containing the authentication as:

    Authorization: Bearer <TOKEN>
    

    Where:

    • HOST is the environment.host property
    • ACCOUNT_ID is the environment.acct property
    • CONTACT_ID is the environment.contactId property
    • TOKEN is the environment.token property

    The body of the API call must contain a standard BotResponse.



Supported Bot and NLP Platforms

Next sections briefly provide some guidelines to integrate bots built by the three supported platforms and using the Vivocha native built-in drivers / settings.

N.B.: Vivocha can be integrated with any Bot Platform, if you're using a platform different than the supported you need to write a driver and a BotManager to use BotRequest / BotResponse messages and communicate with the particular, chosen, Bot Platform.

Dialogflow: integration guidelines

Dialogflow Bot Platform allows the creation of conversation flows using its nice Intents feature. Feel free to build your conversation flow as you prefer, related to the specific Bot application domain, BUT, in order to properly work with Vivocha taking advantage of the out-of-the-box support it provides, it is mandatory to follow some guidelines:

  1. Must exists in Dialogflow an intent configured to be triggered by a start event. The start event name configured in a Dialogflow intent must exactly match the start event configured in Vivocha; Default is: start.

  2. At the end of each conversation branch designed in Dialogflow, the bot MUST set a special context named (exactly) end, to tell to Vivocha that Bot's task is complete and to terminate the chat conversation.

  3. Data passed to the Bot through Vivocha drivers are always contained inside a special context named SESSION_MESSAGE_DATA_PAYLOAD_CONTEXT. Thus, the Dialogflow bot can access to data "stored" in that particular context in each intent that needs to get information; i.e., to extract real-time data coming from BotFilters. If the bot implementation needs to extract passed data/parameters, it can access to that context through (for example) the expression: #SESSION_MESSAGE_DATA_PAYLOAD_CONTEXT.my_parameter_name - see Dialogflow documentation).

  4. When a message request forwarded to the bot contains the payload property (like in the case when it is sent as a reaction to a postback button, for example) and it is sent through the default Vivocha drivers, then the message payload value will be passed to Dialogflow through the SESSION_MESSAGE_DATA_PAYLOAD_CONTEXT context, as the value of a property named VVC_MessagePayload. Therefore, it can be retrieved in the Dialogflow bot logic, inside an intent, through the expression: #SESSION_MESSAGE_DATA_PAYLOAD_CONTEXT.VVC_MessagePayload.

Vivocha Rich Messages and Dialogflow

Thanks to the Vivocha built-in support for Dialogflow, it is possible to send from this bot platform responses containing rich Vivocha-compliant bot messages (bot messages format is described in this section).

To send rich Vivocha messages as response from a Dialogflow Intent, just add a response with a Custom payload by its console and enter a valid JSON for the messages property.

For example, the following valid snippet is related to a response from Dialogflow with a custom payload for a Vivocha Bot message containing a template:

{
  "messages": [
    {
      "code": "message",
      "type": "text",
      "body": "Just an example of generic template",
      "template": {
        "type": "generic",
        "elements": [
          {
            "title": "Meow!",
            "image_url": "https://upload.wikimedia.org/wikipedia/commons/thumb/c/c0/Tajeschidolls_Beren_of_LoveLorien_Ragdoll_Seal_Mink_Lynx_Bicolor.jpg/1024px-Tajeschidolls_Beren_of_LoveLorien_Ragdoll_Seal_Mink_Lynx_Bicolor.jpg",
            "subtitle": "We have the right cat for everyone.",
            "default_action": {
              "type": "web_url",
              "url": "https://en.wikipedia.org/wiki/Cat"
            },
            "buttons": [
              {
                "type": "web_url",
                "url": "https://en.wikipedia.org/wiki/Cat",
                "title": "View Website"
              },
              {
                "type": "postback",
                "title": "OK",
                "payload": "OK"
              }
            ]
          },
          {
            "title": "Meow!",
            "image_url": "https://upload.wikimedia.org/wikipedia/commons/thumb/5/5d/Adult_Scottish_Fold.jpg/1920px-Adult_Scottish_Fold.jpg",
            "subtitle": "We have the right cat for everyone.",
            "default_action": {
              "type": "web_url",
              "url": "https://en.wikipedia.org/wiki/Cat"
            },
            "buttons": [
              {
                "type": "web_url",
                "url": "https://en.wikipedia.org/wiki/Cat",
                "title": "View Website"
              },
              {
                "type": "postback",
                "title": "OK",
                "payload": "OK"
              }
            ]
          }
        ]
      }
    }
  ]
}

Sending a well-formed message enables the Vivocha interaction apps and widgets to correctly show these rich messages to the customer.

Dialogflow Hints and Tips

In the Dialogflow console:

  • Use the embedded Firebase Cloud Functions editor to write complex and effective fulfillments (like calling external APIs from the bot, transforming data and so on...); return followUp events to jump to a particular intent node in your bot;
  • be careful using contexts, they are the only powerful and exclusive way to correlate intents and follow-up intents in a conversation;
  • use slot-filling / parameters to collect data from the user.

IBM Watson Assistant: integration guidelines

Watson Assistant (formerly Conversation) provides a tool to create conversation flows: Dialogs.

  1. Watson Assistant doesn't handle events, only messages, thus you must create an intent trained to understand the word start (simulating an event, in this case).

  2. To communicate that a conversation flow/branch is complete, in each leaf node of the Dialog node, set a specific context parameter to true named as specified by endEventKey property in the module constructor; Important: in order to use the default Vivocha driver, just set the dataCollectionComplete context parameter to true in each Watson Assistant Dialog leaf node; it can be set using the Watson Assistant JSON Editor for a particular dialog node; like in:

...
"context": {
    "dataCollectionComplete": true
}
...
  1. If you need to perfom data collection tasks, remember that you have to configure the bot slot-filling feature in the dedicated nodes of the Dialog section.

  2. When a message sent to the bot contains the payload property (like in the case when it is sent as a reaction to a postback button, for example) and it is sent through the default Vivocha drivers, then the message payload value will be passed to Watson Assistant as a context parameter named VVC_MessagePayload. Therefore, it can be retrieved and used as a variable or slot in the Watson Assistant bot logic.

Vivocha Rich Messages and Watson Assistant

Thanks to the Vivocha built-in support for IBM Watson Assistant, it is possible to send from this bot platform responses containing rich Vivocha-compliant bot messages (bot messages format is described in this section).

To send rich Vivocha messages as responses from the Watson platform, in its workspace console, Dialog tab, select the particular dialog node, and in the Then respond with section, open the embedded JSON Editor and just add a response with a valid JSON object for the messages property, just inside the predefined output object (as defined by the Watson Assistant responses format).

For example, the following valid snippet is related to a response from a Watson Assistant bot, with a custom payload for a Vivocha Bot message containing a body along with three quick replies:

{
  "output": {
    "messages": [
      {
        "body": "Hello from Watson, please choose an action",
        "code": "message",
        "type": "text",
        "quick_replies": [
          {
            "title": "help",
            "payload": "help",
            "content_type": "text"
          },
          {
            "title": "documents",
            "payload": "documents",
            "content_type": "text"
          },
          {
            "title": "exit",
            "payload": "exit",
            "content_type": "text"
          }
        ]
      }
    ]
  }
}

Sending a well-formed custom message enables the Vivocha interaction apps and widgets to correctly show these rich messages to the customer.

Watson Assistant Hints and Tips

Using the IBM Watson Assistant workspace:

  • Slot-filling and parameters can be defined for every node in the Dialog tab;

  • a slot-filling can be specified for every Dialog node and the JSON output can be configured using the related JSON Editor;

  • An Entity can be of type pattern: this allows to define regex-based entities. To save in the context the entered value for a pattern entity it should be used the following syntax: @NAME_OF_THE_ENTITY.literal.

E.g., for slot filling containing a pattern entity like:

Check for: @ContactInfo - Save it as: $email

configure the particular slot through Edit Slot > ... > Open JSON Editor as:

...
"context": {
    "email": "@ContactInfo.literal"
}
...
  • In a Dialog node, if you need to quickly check if an entered input is included within a predefined list of values, you can use the following condition expression:
'milan,cagliari,london,rome,berlin'.split(',').contains(input.text.toLowerCase());

Wit.ai, writing chat bots

Wit.ai is a pure Natural Language Processing (NLP) platform. Using the Web console it is not possible to design Bot's dialog flows or conversations, anymore. Therefore, all the bot application logic, conversation flows, contexts and so on... (in other words: the Bot itself) must be coded outside, calling Wit.ai APIs (mainly) to process natural language messages coming from the users. Through creating an App in Wit.ai and training the system for the specific application domain, it is possible to let it processing messages and extract information from them, like (but not only): user intents end entities, along with their confidence value.

Skipping platform-specific details, in order to create Wit.ai Chat Bots and integrate them with the Vivocha Platform you have to:

  1. Create and train a Wit.ai App, naming intents that will be used by the coded Bot;

  2. Write the code of your Bot subclassing the WitAiBot class provided by this SDK, mapping intents defined in 1) to handler functions;

  3. Run the coded Bot (Agent) using a BotManager and configure it using the Vivocha web console.

The next picture shows how this integration works:

Wit.ai bots integration
FIGURE 3 - The Vivocha - Wit.ai integration model: subclassing to provided WitAiBot class it is possible to quickly code bots using Wit.ai NLP tool without writing specific API calls.

Subclassing the WitAiBot allows writing Bots using Wit.ai NLP. Subclassing that class implies:

  1. defining a IntentsMap: it maps intents names as coming from Wit.ai to custom intent handler functions. E.g, in the following (TypeScript) snippet are defined the required intents mapping to handle a simple customer info collection;
export class SimpleWitBot extends WitAiBot {

    protected intents: IntentsMap = {
        provide_name: (data, request) => this.askEmailorPhone(data.entities, request),
        by_email: (data, request) => this.contactMeByEmail(data, request),
        by_phone: (data, request) => this.contactMeByPhone(data, request),
        provide_phone: (data, request) => this.providePhoneNumber(data.entities, request),
        provide_email: (data, request) => this.provideEmailAddress(data.entities, request),
        unknown: (data, request) => this.unknown(data, request)
    };
    ...

    // write intent handlers here...
}

Note that the unknown mapping is needed to handle all the cases when Wit.ai isn't able to extract an intent. For example, the associated handler function could reply with a message like the popular "Sorry I didn’t get that!" text ;)

  1. implementing the getStartMessage(request: BotRequest) which is called by Vivocha to start a bot instance only at the very beggining of a conversation with a user;

More details can be found in the dedicated examples/sample-wit.ts(.js) sample files.

Wit.ai with Vivocha Hint and Tips
  • use BotRequest/BotResponse context.contexts array property to set contexts, in order to drive your bot in taking decisions about which conversation flow branch follow and about what reply to the user. To check contexts, the WitAiBotclass provides the inContext() method. See the example to discover more;

  • in each intent mapping handler which decides to terminate the conversation, remember to send back a response with the event property set to end.


Microsoft Bots

Vivocha provides built-in native support also for bots implemented using the Microsoft Bot Framework version 3 and 4 and deployed on Azure.

In particular, the integration is based on the Microsoft Direct Line API 3.0 Channel.

Prerequisites
Configuration
  1. In the Microsoft Azure Bot Platform, for the target bot configure a Direct Line 3.0 Channel; specifying a Site name, thus two secret keys are generated and proposed
  2. In Vivocha Campaign Builder > Library, create a BotAgent, with the following settings:

Settings:

PROPERTYDESCRIPTION / VALUE
EngineSelect Microsoft
Direct Line Site IdSite Id / name as set for Direct Line Channel in Microsoft Azure service
Secret keyOne of the two Secret Keys generated by the Direct Line Channel configuration in Microsoft Azure service
Start messagethe message to send to the Bot as start message. N.B.: the Bot must be properly written / trained to understand it and, usually, to reply with a welcome message
Auto convert messagesif checked (default) the native driver will convert the incoming MS Bot Messages to Vivocha Messages, if supported. If not checked, no conversion is attempted. For detailed info see Supported Microsoft Bot Messages section below in this chapter
Transfer Key(Optional) the property key to expect in BotResponses data property to request a transfer to another agent. If not set, default is transferToAgent and it must be properly used in the Bot configuration in the Vivocha Agent Console. See Transfer to Another Agent section below in this chapter
Transfer value(Optional) the value of the configured Transfer Key property to expect in BotResponses data property to request a transfer to another agent. If not set, default is AGENT and it must be used in the Bot configuration in Agent Console. See the Transfer to Another Agent section below in this document

Using the Bot Framework version 4

The following documentation and guidelines apply if you are developing the bot using the Microsoft Bot Framework v. 4.x.

Messages

Sending messages from a MS Bot to Vivocha can be achieved in three ways:

  1. sending simple text messages from the Microsoft Bot;
  2. sending more complex messages through the attachments property in MS Bot messages;
  3. sending messages already expressed in the Vivocha Bot Message format, set directly inside the channelData property of the Microsoft Bot messages.

Example: sending Vivocha Messages from the Bot using the channelData property in Microsoft Bot messages:

const chDataReply = { type: ActivityTypes.Message };
chDataReply.channelData = {
                      "messages": [ {
                      "code": "message",
                      "type": "text",
                      "body": "Just an example of generic template",
                      "template": {
                        "type": "generic",
                        "elements": [
                          {
                            "title": "Meow!",
                            "image_url": "https://upload.wikimedia.org/wikipedia/commons/thumb/c/c0/Tajeschidolls_Beren_of_LoveLorien_Ragdoll_Seal_Mink_Lynx_Bicolor.jpg/1024px-Tajeschidolls_Beren_of_LoveLorien_Ragdoll_Seal_Mink_Lynx_Bicolor.jpg",
                            "subtitle": "We have the right cat for everyone.",
                            "default_action": {
                              "type": "web_url",
                              "url": "https://en.wikipedia.org/wiki/Cat"
                            },
                            "buttons": [
                              {
                                "type": "web_url",
                                "url": "https://en.wikipedia.org/wiki/Cat",
                                "title": "View Website"
                              },
                              {
                                "type": "postback",
                                "title": "OK",
                                "payload": "OK"
                              }
                            ]
                          },
                          {
                            "title": "Meow!",
                            "image_url": "https://upload.wikimedia.org/wikipedia/commons/thumb/5/5d/Adult_Scottish_Fold.jpg/1920px-Adult_Scottish_Fold.jpg",
                            "subtitle": "We have the right cat for everyone.",
                            "default_action": {
                              "type": "web_url",
                              "url": "https://en.wikipedia.org/wiki/Cat"
                            },
                            "buttons": [
                              {
                                "type": "web_url",
                                "url": "https://en.wikipedia.org/wiki/Cat",
                                "title": "View Website"
                              },
                              {
                                "type": "postback",
                                "title": "OK",
                                "payload": "OK"
                              }
                            ]
                          }
                        ]
                      }
                    }
                  ]
};
await turnContext.sendActivity(chDataReply);

Example: sending Vivocha Messages from the MS Bot using the channelData property in Microsoft Bot messages, also sending an end of conversation:

const chEndDataReply = { type: ActivityTypes.EndOfConversation };
chEndDataReply.channelData = {
                            "messages": [ {
                            "code": "message",
                            "type": "text",
                            "body": "Just an example of generic template",
                            "template": {
                              "type": "generic",
                              "elements": [
                                {
                                  "title": "Meow!",
                                  "image_url": "https://upload.wikimedia.org/wikipedia/commons/thumb/c/c0/Tajeschidolls_Beren_of_LoveLorien_Ragdoll_Seal_Mink_Lynx_Bicolor.jpg/1024px-Tajeschidolls_Beren_of_LoveLorien_Ragdoll_Seal_Mink_Lynx_Bicolor.jpg",
                                  "subtitle": "We have the right cat for everyone.",
                                  "default_action": {
                                    "type": "web_url",
                                    "url": "https://en.wikipedia.org/wiki/Cat"
                                  },
                                  "buttons": [
                                    {
                                      "type": "web_url",
                                      "url": "https://en.wikipedia.org/wiki/Cat",
                                      "title": "View Website"
                                    },
                                    {
                                      "type": "postback",
                                      "title": "OK",
                                      "payload": "OK"
                                    }
                                  ]
                                },
                                {
                                  "title": "Meow!",
                                  "image_url": "https://upload.wikimedia.org/wikipedia/commons/thumb/5/5d/Adult_Scottish_Fold.jpg/1920px-Adult_Scottish_Fold.jpg",
                                  "subtitle": "We have the right cat for everyone.",
                                  "default_action": {
                                    "type": "web_url",
                                    "url": "https://en.wikipedia.org/wiki/Cat"
                                  },
                                  "buttons": [
                                    {
                                      "type": "web_url",
                                      "url": "https://en.wikipedia.org/wiki/Cat",
                                      "title": "View Website"
                                    },
                                    {
                                      "type": "postback",
                                      "title": "OK",
                                      "payload": "OK"
                                    }
                                  ]
                                }
                              ]
                            }
                          }
                        ]
};
await turnContext.sendActivity(chEndDataReply);

Supported Microsoft Bot Messages

If autoConvertMessages property is checked in settings, the Vivocha Bot Driver will attempt to convert the messages coming from the bot and expressed in Microsoft Messages format to the Vivocha Bot messages specific format, if supported. Then, the driver will act as follows:

Case 1: Messages Auto-convert is ON (checked)

The following table lists auto convert support current status of MS Bot messages:

Microsoft Message TypeAutomatic ConversionConverted to VVC Message
Adaptive CardNo-
Animation CardYesGeneric Template
Hero CardYesGeneric Template
Thumbnail CardYesGeneric Template
Receipt CardNo-
Signin CardYesGeneric Template
Video CardNo-
Message with ActionsYesMessage with Quick Replies
Message with CarouselsYesMessage with multimple templates

If the Bot sends an attachment with an unsupported Microsoft Message Type, then it is converted to a special Vivocha template element, which type is ms_raw and has the following properties:

{
  "title": "Unsupported Microsoft Bot message type, you need to write a custom renderer. See the element property in raw JSON.",
  "type": "ms_raw",
  "element": < ORIGINAL RAW body of the Microsoft Bot Message Attachment >
}

In this way, the Vivocha interaction app can be customized to parse and render the specific ms_raw template element.

Example: A full Vivocha Message resulting from converting an unsupported Microsoft Bot message attachment along with a supported one

{
  "messages": [
    {
      "code": "message",
      "type": "text",
      "template": {
        "type": "generic",
        "elements": [
          {
            "title": "Unsupported Microsoft Bot message type, you need to write a custom renderer. See the element property in raw JSON.",
            "type": "ms_raw",
            "element": {
              "contentType": "application/vnd.microsoft.card.video",
              "content": {
                "title": "Video",
                "subtitle": "No way.",
                "text": "not supported video card",
                "media": [{ "url": "https://media.giphy.com/media/eTdN7L04C6puE/giphy.gif" }],
                "buttons": [{ "type": "openUrl", "title": "Search GIFs", "value": "http://giphy.com" }],
                "shareable": false,
                "autoloop": false,
                "autostart": false
              }
            }
          },
          {
            "title": "Mia... rhjlkmyu",
            "subtitle": "glitch. Just new modern cat GIFs",
            "image_url": "https://media.giphy.com/media/ktvFa67wmjDEI/giphy.gif",
            "buttons": [{ "type": "web_url", "title": "Search GIFs", "url": "http://giphy.com" }]
          }
        ]
      }
    }
  ],
  "event": "continue",
  "data": {},
  "context": { "conversationId": "JOrLGNyvift87iQ1opfAJo" },
  "raw": {
    "activities": [
      {
        "type": "message",
        "id": "JOrLGNyvift87iQ1opfAJo|0000005",
        "timestamp": "2018-11-09T17:16:48.9957975Z",
        "localTimestamp": "2018-11-09T17:16:48.872+00:00",
        "channelId": "directline",
        "from": { "id": "vvc-echo-bot", "name": "vvc-echo-bot" },
        "conversation": { "id": "JOrLGNyvift87iQ1opfAJo" },
        "inputHint": "acceptingInput",
        "attachments": [
          {
            "contentType": "application/vnd.microsoft.card.video",
            "content": {
              "title": "Video",
              "subtitle": "No way.",
              "text": "not supported video card",
              "media": [{ "url": "https://media.giphy.com/media/eTdN7L04C6puE/giphy.gif" }],
              "buttons": [{ "type": "openUrl", "title": "Search GIFs", "value": "http://giphy.com" }],
              "shareable": false,
              "autoloop": false,
              "autostart": false
            }
          },
          {
            "contentType": "application/vnd.microsoft.card.animation",
            "content": {
              "title": "Mia... rhjlkmyu",
              "subtitle": "glitch.",
              "text": "Just new modern cat GIFs",
              "media": [{ "url": "https://media.giphy.com/media/ktvFa67wmjDEI/giphy.gif" }],
              "buttons": [{ "type": "openUrl", "title": "Search GIFs", "value": "http://giphy.com" }],
              "shareable": false,
              "autoloop": false,
              "autostart": false
            }
          }
        ],
        "replyToId": "JOrLGNyvift87iQ1opfAJo|0000004"
      }
    ],
    "conversationId": "JOrLGNyvift87iQ1opfAJo"
  }
}

Case 2: Message Auto-convert is OFF (unchecked)

When auto-convert messages is switched OFF, the Vivocha driver will not convert any message coming from the bot. Instead, it generated a message with a special ms_raw template type containing the unparsed, raw, original Microsoft message.

The template format is as follows:

{
      "code": "message",
      "type": "text",
      "template": {
        "type": "ms_raw",
        "elements": [
          < ORIGINAL RAW JSON Microsoft Bot Message body as object >
        ]
      }

Like in the following example:

Example: a complete Vivocha message containing the ms_raw special template type when auto-convert of Microsoft messages is OFF

{
  "messages": [
    {
      "code": "message",
      "type": "text",
      "template": {
        "type": "ms_raw",
        "elements": [
          {
            "activities": [
              {
                "type": "message",
                "id": "8jiPwElwjZU49w8EMz1Zmb|0000003",
                "timestamp": "2018-11-09T17:35:46.5847969Z",
                "localTimestamp": "2018-11-09T17:35:46.448+00:00",
                "channelId": "directline",
                "from": { "id": "vvc-echo-bot", "name": "vvc-echo-bot" },
                "conversation": { "id": "8jiPwElwjZU49w8EMz1Zmb" },
                "inputHint": "acceptingInput",
                "attachments": [
                  {
                    "contentType": "application/vnd.microsoft.card.hero",
                    "content": {
                      "title": "Classic White T-Shirt",
                      "subtitle": "100% Soft and Luxurious Cotton",
                      "text": "Price is $25and carried in sizes (S, M, L, and XL)",
                      "images": [{ "url": "https://upload.wikimedia.org/wikipedia/commons/9/9a/Wikipedia-T-shirt.jpg" }],
                      "buttons": [{ "type": "imBack", "title": "Buy", "value": "Buy THIS" }]
                    }
                  }
                ],
                "replyToId": "8jiPwElwjZU49w8EMz1Zmb|0000002"
              }
            ],
            "conversationId": "8jiPwElwjZU49w8EMz1Zmb"
          }
        ]
      }
    }
  ],
  "event": "continue",
  "data": {},
  "context": { "conversationId": "8jiPwElwjZU49w8EMz1Zmb" },
  "raw": {
    "activities": [
      {
        "type": "message",
        "id": "8jiPwElwjZU49w8EMz1Zmb|0000003",
        "timestamp": "2018-11-09T17:35:46.5847969Z",
        "localTimestamp": "2018-11-09T17:35:46.448+00:00",
        "channelId": "directline",
        "from": { "id": "vvc-echo-bot", "name": "vvc-echo-bot" },
        "conversation": { "id": "8jiPwElwjZU49w8EMz1Zmb" },
        "inputHint": "acceptingInput",
        "attachments": [
          {
            "contentType": "application/vnd.microsoft.card.hero",
            "content": {
              "title": "Classic White T-Shirt",
              "subtitle": "100% Soft and Luxurious Cotton",
              "text": "Price is $25 and carried in sizes (S, M, L, and XL)",
              "images": [{ "url": "https://upload.wikimedia.org/wikipedia/commons/9/9a/Wikipedia-T-shirt.jpg" }],
              "buttons": [{ "type": "imBack", "title": "Buy", "value": "Buy THIS" }]
            }
          }
        ],
        "replyToId": "8jiPwElwjZU49w8EMz1Zmb|0000002"
      }
    ],
    "conversationId": "8jiPwElwjZU49w8EMz1Zmb"
  }
}


Data Collection with Microsoft Bot Framework 4

Data is collected by the Vivocha driver only, and only if:

  • the Microsoft Bot Message has the channelData.data property set (an object)

Example of sending a Microsoft Bot message with channelData set

// in the MS bot v4 implementation code
const activity = { type: ActivityTypes.EndOfConversation };
activity.channelData = {
                          "data": {
                                "transferToAgent": "AGENT",
                                "firstname": "Iggy",
                                "lastname": "Pop",
                                "email": "iguana@pop.com",
                                "issue": "Technical"
                          }
};
await turnContext.sendActivity(activity);

End of conversation messages and Vivocha end event

To end a conversation (thus, generating a "event": "end" in the resulting Vivocha BotResponse), the bot must return an activity with activity.type property set to endOfConversation in the Microsoft Bot message to be sent.


Transfer to other Agents

To request a transfer to another agent, the Microsoft Bot should return a text message with:

  • channelData.data property containing a sub property as in:
{
  ...
  <settings.transferKey>: <settings.transferValue>
}

where:

  • settings.transferKey is the related property key configured for the particular bot
  • settings.transferValue is the related property value configured for the particular bot

example:

{"tranferToAgent": "human"}

NB: whether an endOfConversation message is sent by the bot or not, when the configured settings.transferKey is found to be equal to the configured settings.transferValue, then in the resulting Vivocha BotResponse the event property is automatically always set to end.


Using the Bot Framework version 3

The following documentation and guidelines apply if you are developing the bot using the Microsoft Bot Framework v. 3.0.

Messages

Sending messages from a MS Bot to Vivocha can be achieved in three ways:

  1. sending simple text messages from the Microsoft Bot;
  2. sending more complex messages through the attachments property in MS Bot messages;
  3. sending messages already expressed in the Vivocha Bot Message format, set directly inside the channelData property of the Microsoft Bot messages.

Example: sending Vivocha Messages from the Bot using the channelData property in Microsoft Bot messages:

let msg = {};
msg.text = 'Test custom channelData';
msg.channelData = {
                "messages": [ {
      "code": "message",
      "type": "text",
      "body": "Just an example of generic template",
      "template": {
        "type": "generic",
        "elements": [
          {
            "title": "Meow!",
            "image_url": "https://upload.wikimedia.org/wikipedia/commons/thumb/c/c0/Tajeschidolls_Beren_of_LoveLorien_Ragdoll_Seal_Mink_Lynx_Bicolor.jpg/1024px-Tajeschidolls_Beren_of_LoveLorien_Ragdoll_Seal_Mink_Lynx_Bicolor.jpg",
            "subtitle": "We have the right cat for everyone.",
            "default_action": {
              "type": "web_url",
              "url": "https://en.wikipedia.org/wiki/Cat"
            },
            "buttons": [
              {
                "type": "web_url",
                "url": "https://en.wikipedia.org/wiki/Cat",
                "title": "View Website"
              },
              {
                "type": "postback",
                "title": "OK",
                "payload": "OK"
              }
            ]
          },
          {
            "title": "Meow!",
            "image_url": "https://upload.wikimedia.org/wikipedia/commons/thumb/5/5d/Adult_Scottish_Fold.jpg/1920px-Adult_Scottish_Fold.jpg",
            "subtitle": "We have the right cat for everyone.",
            "default_action": {
              "type": "web_url",
              "url": "https://en.wikipedia.org/wiki/Cat"
            },
            "buttons": [
              {
                "type": "web_url",
                "url": "https://en.wikipedia.org/wiki/Cat",
                "title": "View Website"
              },
              {
                "type": "postback",
                "title": "OK",
                "payload": "OK"
              }
            ]
          }
        ]
      }
    }
  ]
};
session.send(msg);

Example: sending Vivocha Messages from the MS Bot using the channelData property in Microsoft Bot messages, also sending an end of conversation:

var cmsg = {};
cmsg.type = 'endOfConversation';
cmsg.text = 'Test custom channelData';
cmsg.channelData = {
      "messages": [ {
      "code": "message",
      "type": "text",
      "body": "Just an example of generic template VVC2",
      "template": {
        "type": "generic",
        "elements": [
          {
            "title": "Meow!",
            "image_url": "https://upload.wikimedia.org/wikipedia/commons/thumb/c/c0/Tajeschidolls_Beren_of_LoveLorien_Ragdoll_Seal_Mink_Lynx_Bicolor.jpg/1024px-Tajeschidolls_Beren_of_LoveLorien_Ragdoll_Seal_Mink_Lynx_Bicolor.jpg",
            "subtitle": "We have the right cat for everyone.",
            "default_action": {
              "type": "web_url",
              "url": "https://en.wikipedia.org/wiki/Cat"
            },
            "buttons": [
              {
                "type": "web_url",
                "url": "https://en.wikipedia.org/wiki/Cat",
                "title": "View Website"
              },
              {
                "type": "postback",
                "title": "OK",
                "payload": "OK"
              }
            ]
          },
          {
            "title": "Meow!",
            "image_url": "https://upload.wikimedia.org/wikipedia/commons/thumb/5/5d/Adult_Scottish_Fold.jpg/1920px-Adult_Scottish_Fold.jpg",
            "subtitle": "We have the right cat for everyone.",
            "default_action": {
              "type": "web_url",
              "url": "https://en.wikipedia.org/wiki/Cat"
            },
            "buttons": [
              {
                "type": "web_url",
                "url": "https://en.wikipedia.org/wiki/Cat",
                "title": "View Website"
              },
              {
                "type": "postback",
                "title": "OK",
                "payload": "OK"
              }
            ]
          }
        ]
      }
    }
  ]
};
session.endConversation(cmsg);

Supported Microsoft Bot Messages

If autoConvertMessages property is checked in settings, the Vivocha Bot Driver will attempt to convert the messages coming from the bot and expressed in Microsoft Messages format to the Vivocha Bot messages specific format, if supported. Then, the driver will act as follows:

Case 1: Messages Auto-convert is ON (checked)

The following table lists auto convert support current status of MS Bot messages:

Microsoft Message TypeAutomatic ConversionConverted to VVC Message
Adaptive CardNo-
Animation CardYesGeneric Template
Hero CardYesGeneric Template
Thumbnail CardYesGeneric Template
Receipt CardNo-
Signin CardYesGeneric Template
Video CardNo-
Message with ActionsYesMessage with Quick Replies
Message with CarouselsYesMessage with multimple templates

If the Bot sends an attachment with an unsupported Microsoft Message Type, then it is converted to a special Vivocha template element, which type is ms_raw and has the following properties:

{
  "title": "Unsupported Microsoft Bot message type, you need to write a custom renderer. See the element property in raw JSON.",
  "type": "ms_raw",
  "element": < ORIGINAL RAW body of the Microsoft Bot Message Attachment >
}

In this way, the Vivocha interaction app can be customized to parse and render the specific ms_raw template element.

Example: A full Vivocha Message resulting from converting an unsupported Microsoft Bot message attachment along with a supported one

{
  "messages": [
    {
      "code": "message",
      "type": "text",
      "template": {
        "type": "generic",
        "elements": [
          {
            "title": "Unsupported Microsoft Bot message type, you need to write a custom renderer. See the element property in raw JSON.",
            "type": "ms_raw",
            "element": {
              "contentType": "application/vnd.microsoft.card.video",
              "content": {
                "title": "Video",
                "subtitle": "No way.",
                "text": "not supported video card",
                "media": [{ "url": "https://media.giphy.com/media/eTdN7L04C6puE/giphy.gif" }],
                "buttons": [{ "type": "openUrl", "title": "Search GIFs", "value": "http://giphy.com" }],
                "shareable": false,
                "autoloop": false,
                "autostart": false
              }
            }
          },
          {
            "title": "Mia... rhjlkmyu",
            "subtitle": "glitch. Just new modern cat GIFs",
            "image_url": "https://media.giphy.com/media/ktvFa67wmjDEI/giphy.gif",
            "buttons": [{ "type": "web_url", "title": "Search GIFs", "url": "http://giphy.com" }]
          }
        ]
      }
    }
  ],
  "event": "continue",
  "data": {},
  "context": { "conversationId": "JOrLGNyvift87iQ1opfAJo" },
  "raw": {
    "activities": [
      {
        "type": "message",
        "id": "JOrLGNyvift87iQ1opfAJo|0000005",
        "timestamp": "2018-11-09T17:16:48.9957975Z",
        "localTimestamp": "2018-11-09T17:16:48.872+00:00",
        "channelId": "directline",
        "from": { "id": "vvc-echo-bot", "name": "vvc-echo-bot" },
        "conversation": { "id": "JOrLGNyvift87iQ1opfAJo" },
        "inputHint": "acceptingInput",
        "attachments": [
          {
            "contentType": "application/vnd.microsoft.card.video",
            "content": {
              "title": "Video",
              "subtitle": "No way.",
              "text": "not supported video card",
              "media": [{ "url": "https://media.giphy.com/media/eTdN7L04C6puE/giphy.gif" }],
              "buttons": [{ "type": "openUrl", "title": "Search GIFs", "value": "http://giphy.com" }],
              "shareable": false,
              "autoloop": false,
              "autostart": false
            }
          },
          {
            "contentType": "application/vnd.microsoft.card.animation",
            "content": {
              "title": "Mia... rhjlkmyu",
              "subtitle": "glitch.",
              "text": "Just new modern cat GIFs",
              "media": [{ "url": "https://media.giphy.com/media/ktvFa67wmjDEI/giphy.gif" }],
              "buttons": [{ "type": "openUrl", "title": "Search GIFs", "value": "http://giphy.com" }],
              "shareable": false,
              "autoloop": false,
              "autostart": false
            }
          }
        ],
        "replyToId": "JOrLGNyvift87iQ1opfAJo|0000004"
      }
    ],
    "conversationId": "JOrLGNyvift87iQ1opfAJo"
  }
}

Case 2: Message Auto-convert is OFF (unchecked)

When auto-convert messages is switched OFF, the Vivocha driver will not convert any message coming from the bot. Instead, it generated a message with a special ms_raw template type containing the unparsed, raw, original Microsoft message.

The template format is as follows:

{
      "code": "message",
      "type": "text",
      "template": {
        "type": "ms_raw",
        "elements": [
          < ORIGINAL RAW JSON Microsoft Bot Message body as object >
        ]
      }

Like in the following example:

Example: a complete Vivocha message containing the special template type when auto-convert of Microsoft messages is OFF

{
  "messages": [
    {
      "code": "message",
      "type": "text",
      "template": {
        "type": "ms_raw",
        "elements": [
          {
            "activities": [
              {
                "type": "message",
                "id": "8jiPwElwjZU49w8EMz1Zmb|0000003",
                "timestamp": "2018-11-09T17:35:46.5847969Z",
                "localTimestamp": "2018-11-09T17:35:46.448+00:00",
                "channelId": "directline",
                "from": { "id": "vvc-echo-bot", "name": "vvc-echo-bot" },
                "conversation": { "id": "8jiPwElwjZU49w8EMz1Zmb" },
                "inputHint": "acceptingInput",
                "attachments": [
                  {
                    "contentType": "application/vnd.microsoft.card.hero",
                    "content": {
                      "title": "Classic White T-Shirt",
                      "subtitle": "100% Soft and Luxurious Cotton",
                      "text": "Price is $25and carried in sizes (S, M, L, and XL)",
                      "images": [{ "url": "https://upload.wikimedia.org/wikipedia/commons/9/9a/Wikipedia-T-shirt.jpg" }],
                      "buttons": [{ "type": "imBack", "title": "Buy", "value": "Buy THIS" }]
                    }
                  }
                ],
                "replyToId": "8jiPwElwjZU49w8EMz1Zmb|0000002"
              }
            ],
            "conversationId": "8jiPwElwjZU49w8EMz1Zmb"
          }
        ]
      }
    }
  ],
  "event": "continue",
  "data": {},
  "context": { "conversationId": "8jiPwElwjZU49w8EMz1Zmb" },
  "raw": {
    "activities": [
      {
        "type": "message",
        "id": "8jiPwElwjZU49w8EMz1Zmb|0000003",
        "timestamp": "2018-11-09T17:35:46.5847969Z",
        "localTimestamp": "2018-11-09T17:35:46.448+00:00",
        "channelId": "directline",
        "from": { "id": "vvc-echo-bot", "name": "vvc-echo-bot" },
        "conversation": { "id": "8jiPwElwjZU49w8EMz1Zmb" },
        "inputHint": "acceptingInput",
        "attachments": [
          {
            "contentType": "application/vnd.microsoft.card.hero",
            "content": {
              "title": "Classic White T-Shirt",
              "subtitle": "100% Soft and Luxurious Cotton",
              "text": "Price is $25 and carried in sizes (S, M, L, and XL)",
              "images": [{ "url": "https://upload.wikimedia.org/wikipedia/commons/9/9a/Wikipedia-T-shirt.jpg" }],
              "buttons": [{ "type": "imBack", "title": "Buy", "value": "Buy THIS" }]
            }
          }
        ],
        "replyToId": "8jiPwElwjZU49w8EMz1Zmb|0000002"
      }
    ],
    "conversationId": "8jiPwElwjZU49w8EMz1Zmb"
  }
}


Data Collection with Microsoft Bot Framework 3.0

Data is collected by the Vivocha driver only, and only if:

  • the Microsoft Bot Message has the entities property set (an array)
  • the Microsoft Bot Message has the channelData.data property set (an object)

Example of sending a Microsoft Bot message with Entities

// inside the MS bot implementation code
let dmsg = new builder.Message(session);
dmsg.text('A message with entities');
dmsg.addEntity({color: 'RED', car: '500'});
session.send(dmsg);

Example of sending a Microsoft Bot message with channelData set

// inside the MS bot implementation code
var sdmsg = {};
sdmsg.text = 'A message custom data in channelData property, see JSON';
sdmsg.channelData = {
  "data":{
    "firstname": "Iggy",
    "lastname": "Pop",
    "nickname": "Iguana"
  }
};
session.send(sdmsg);

End of conversation messages and Vivocha end event

To end a conversation (thus, generating a "event": "end" in the resulting Vivocha BotResponse), the bot must return an activity with activity.type property set to endOfConversation in the Microsoft Bot message to be sent.


Transfer to other Agents

To request a transfer to another agent, the Microsoft Bot should return a text message with:

  • channelData.data property containing a sub property as in:
{
  ...
  <settings.transferKey>: <settings.transferValue>
}

OR

  • a message with an entity set to a JSON like:
{<settings.transferKey>: <settings.transferValue>}

where:

  • settings.transferKey is the related property key configured for the particular bot
  • settings.transferValue is the related property value configured for the particular bot

example:

{"tranferToAgent": "human"}

NB: whether an endOfConversation message is sent by the bot or not, when the configured settings.transferKey is found to be equal to the configured settings.transferValue, then in the resulting Vivocha BotResponse the event property is always set to end.



Running BotManagers and BotFilters as AWS Lambdas

Starting from version 2.6.0, the Vivocha Bot SDK supports running Bot Managers & Agents and Bot Filters as Lambda Functions in AWS Lambda, resulting in a great flexibility and scalability added by this serverless-applications platform.

In order to simplify the overall deployment process we use the Serverless Framework & Tools.

Prerequisites

  1. an Amazon Web Services (AWS) valid account
  2. your environment configured with AWS credentials (please see this page or this guide)
  3. the Serverless framework, thus install Serverless as global: npm i -g serverless

As a reference, the examples directory contains two Lambda functions:

  • lambda-bot-manager is a Lambda-deployable Bot Manager for a dummy bot accepting some commands
  • lambda-bot-filter is a BotFilter (same as in sample.(ts|js) file) deployable as AWS Lambda.

Writing a BotManager or a BotFilter as a Lambda Function

As a recap for the previous sections, to run a Vivocha BotManager or a BotFilter, once having written the code you can call their listen() method, which runs a web server, and you're done.

To run them as a Lambda Function, basically you have to:

  1. as always, install the @vivocha/bot-sdk and in your code, import serverless and toLambda from the Vivocha Bot SDK, like in the following snippet:
import {BotFilter, BotRequest, ..., toLambda, serverless } from '@vivocha/bot-sdk';
  1. Keep your existing BotManager and BotAgent or BotFilter code BUT DON'T invoke the listen() method, just add the following line at the end of the file:
module.exports.handler = serverless(toLambda(manager));

where, in this case, manager is your BotManager instance.

  1. In the project root directory, create a serverless.yaml file (or copy one those contained in the examples directory, mentioned before in this document). This file should have a configuration like the following (related to a BotFilter):
# serverless.yml
# the name of your service (manager or filter) as in package.json
service: lambda-bot-filter
provider:
  name: aws
  # we need Node.js AWS environment set to v8.10
  runtime: nodejs8.10
  # stage name, change as you prefer, i.e.: prod
  stage: dev
  # AWS region, change it as needed
  region: us-west-2
functions:
  # name of your Lambda function
  lambda-bot-filter:
    description: Lambda-based Vivocha Bot Filter sample
    # name of the file/handler where you put the module.exports.handler=... statement
    handler: dist/lambda-bot-filter.handler
    events:
      # Configuration related to the API HTTP Gateway, leave it as follows, if possible.
      - http: 'ANY /'
      - http: 'ANY {proxy+}'
  1. (optional) if you've written the code in TypeScript, then compile your code

  2. run the command:

sls deploy

If the deploy process is successful, you should have an output like the following:

service: lambda-bot-filter
stage: dev
region: us-west-2
stack: lambda-bot-filter-dev
api keys:
  None
endpoints:
  ANY - https://abcdef123kwc82.execute-api.us-west-2.amazonaws.com/dev
  ANY - https://abcdef123kwc82.execute-api.us-west-2.amazonaws.com/dev/{proxy+}
functions:
  lambda-bot-filter: lambda-bot-filter-dev-lambda-bot-filter

In the response above, AWS returned the endpoint base URL of our Lambda, thus this is not the complete URL.

Therefore, for our BotFilter example, the resulting complete filter endpoint URL to use in the Vivocha Bot configuration console will be:

https://abcdef123kwc82.execute-api.us-west-2.amazonaws.com/dev/filter/request

The process in case of a BotManager is the same.

Likewise, if you have deployed as Lambda a BotManager the complete endpoint URL to use will be something like the following:

https://abcdef567kwc82.execute-api.us-west-2.amazonaws.com/dev/bot/message

Done.



Running Tests

In order to run the tests you need a Wit.ai account.

Then, in your Wit.ai console:

  1. create a new app by importing the /test/data/witai-test-app.zip file, name it as you prefer;
  2. in app settings section, generate a Client Access Token, copy it;

Then, in the Bot SDK project:

  1. create a .env file in the root directory
  2. in the .env file add the following line:
WIT_TOKEN=<YOUR_CLIENT_ACCESS_TOKEN> 

Save it.

  1. run the tests with the command:
npm run test

OR (with coverage)

npm run cover

FAQs

Package last updated on 19 Dec 2018

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc