Skip to content

Latest commit

 

History

History
 
 

core-State

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 

State API Bot Sample

A stateless sample bot tracking context of a conversation.

[![Deploy to Azure][Deploy Button]][Deploy State/Node] [Deploy Button]: https://azuredeploy.net/deploybutton.png [Deploy State/Node]: https://azuredeploy.net

Prerequisites

The minimum prerequisites to run this sample are:

  • Latest Node.js with NPM. Download it from here.
  • The Bot Framework Emulator. To install the Bot Framework Emulator, download it from here. Please refer to this documentation article to know more about the Bot Framework Emulator.
  • [Recommended] Visual Studio Code for IntelliSense and debugging, download it from here for free.

Code Highlights

The Bot Framework provides several ways of persisting data relative to a user or conversation. Bots built using Bot Builder are designed to be stateless so that they can easily be scaled to run across multiple compute nodes. Because of that you should generally avoid the temptation to save state using a global variable or function closure. Doing so will create issues when you want to scale out your bot. Instead leverage the data bags above to persist temporary and permanent state.

Field Use Cases
userData Stores information globally for the user across all conversations.
conversationData Stores information globally for a single conversation. This data is visible to everyone within the conversation so care should be used to what’s stored there. It’s disabled by default and needs to be enabled using the bots persistConversationData setting.
privateConversationData Stores information globally for a single conversation but its private data for the current user. This data spans all dialogs so it’s useful for storing temporary state that you want cleaned up when the conversation ends.
dialogData Persists information for a single dialog instance. This is essential for storing temporary information in between the steps of a waterfall.

NOTE: If you are planning to use conversationData, remember to instantiate the bot using the persistConversationData setting flag. Check out app.js as a reference:

var bot = new builder.UniversalBot(connector, {
    persistConversationData: true
});

Check out the use of session.conversationData in the root dialog to store a default search city. The conversationData object is shared for all users within a conversation.

bot.dialog('/', function (session) {

  // initialize default city
  if (!session.conversationData['City']) {
    session.conversationData['City'] = 'Seattle';
  }

  var defaultCity = session.conversationData['City'];
  session.send('Welcome to the Search City bot. I\'m currently configured to search for things in %s', defaultCity);

  session.beginDialog('/search');
});

Also, check out the use of session.privateConversationData in the search IntentDialog matching current city. Logic is included to override data stored in the conversationData object. privateConversationData is private to a specific user within a conversation.

var defaultCity = session.conversationData['City'];
var userCity = session.privateConversationData['City']
if (!!userCity) {
    session.send(
        'You have overridden the city. Your searches are for things in %s. The default conversation city is %s.',
        userCity, defaultCity);
    return;
} else {
    session.send('I\'m currently configured to search for things in %s.', defaultCity);
}

In contrast, check out the use of session.userData in the askUsername dialog to remember the user's name. userData is shared across all channels and conversations for this user.

bot.dialog('/askUserName', new builder.SimpleDialog(function (session, results) {
    if (results && results.response) {
        session.userData['UserName'] = results.response;
        ...
    }
}));

Additionally, dialogData field is persisted with this dialog on each message. It ensures that the dialogs state is properly maintained between each turn of the conversation. You can store anything you want into this field but should limit yourself to JavaScript primitives that can be properly serialized.

Outcome

The first time you run this sample it will display a welcome message and configure itself to issue search queries for the 'Seattle' city, storing this value in the conversationData bag. It will also prompt you for your name and store it in the userData bag and display a help message. Issuing the change my city command will allow you to change the search city for this conversation only and just for your user, storing the value in the privateConversationData bag.

Sample Outcome

Subsequently, you can start a new conversation (In the Bot Framework Channel Emulator this can be done by using the 'ConversationNames - New' button) and this time the bot will remember you name but will forget the city override we executed in the previous conversation. Using the change city command this can be changed for all the users in the conversation.

Sample Outcome

When a another user arrives to the conversation (In the Bot Framework Emulator this is done by editing the 'User' field) the bot will remember its name (Or prompt for the user name depending on any previous conversation) and maintain the previous search city set.

Sample Outcome

More Information

To get more information about how to get started in Bot Builder for Node and Dialogs please review the following resources: