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
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.
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.
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.
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.
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.
To get more information about how to get started in Bot Builder for Node and Dialogs please review the following resources: