This middleware plugin for Botkit allows you to seamlessly integrate Wit.ai natural language intent APIs into your Botkit bot.
Wit.ai provides a service that uses machine learning to help developers handle natural language input. The Wit API receives input from the user, and translates it into one or more "intents" which map to known actions or choices. The power of Wit is that it can continually be trained to understand more and more responses without changing the underlying bot code!
Create a Wit application here. Then, set up and train at least one intent.
From your app's settings page, snag the Server Access Token. You will need this to use Wit's API.
Add botkit-middleware-witai as a dependency to your Botkit bot!
npm install --save botkit-middleware-witai
Enable the middleware:
var wit = require('botkit-middleware-witai')({
token: <my_wit_token>
command: <my_wit_command> //use this option to pass only requests with <my_wit_command> to wit
api_version: <my_wit_api_version> //use this option to specify the api version of wit to use, don't specify to use the latest version.
minimum_confidence: <minimum_confidence> //use this option to specify the minimal confidence to accept the matched intent.
});
controller.middleware.receive.use(wit.receive);
controller.hears(['wit_entity_1','wit_entity_2'],'direct_message',wit.hears,function(bot, message) {
// ...
});
For a full example example_bot.js
Using the Wit receive middleware with Botkit causes every message that is
sent to your bot to be first sent to Wit.ai for processing. The
results of the call to Wit.ai are added into the incoming message
as message.entities
, and will match the results of this Wit.ai API call.
Using the Wit hears middleware tells Botkit to look for Wit.ai intents information, and match using this information instead of the built in pattern matching function.
You must make an intent
entity in the understandings area of wit.ai
and train it to register certain expressions.
I.e "intent" -> "weather"
Expression: "What is the weather?" and that maps to the weather intent.
Unless you want to directly access the information returned by wit,
you can use this transparently by enabling bot the receive
and hears
middlewares.