node-wit
is the Node.js SDK for Wit.ai.
In your Node.js project, run:
npm install --save node-wit
Run in your terminal:
node examples/template.js <your_token>
See examples
folder for more examples.
On 2016, May 11th, the /message API was updated to reflect the new Bot Engine model: intent are now entities.
We updated the SDK to the latest version: 20160516.
You can target a specific version by setting the env variable WIT_API_VERSION
.
{
"msg_id" : "e86468e5-b9e8-4645-95ce-b41a66fda88d",
"_text" : "hello",
"entities" : {
"intent" : [ {
"confidence" : 0.9753469589149633,
"value" : "greetings"
} ]
}
}
Version prior to 20160511 will return the old format:
{
"msg_id" : "722fc79b-725c-4ca1-8029-b7f57ff88f54",
"_text" : "hello",
"outcomes" : [ {
"_text" : "hello",
"confidence" : null,
"intent" : "default_intent",
"entities" : {
"intent" : [ {
"confidence" : 0.9753469589149633,
"value" : "greetings"
} ]
}
} ],
"WARNING" : "DEPRECATED"
}
The Wit module provides a Wit class with the following methods:
message
- the Wit message APIconverse
- the low-level Wit converse APIrunActions
- a higher-level method to the Wit converse APIinteractive
- starts an interactive conversation with your bot
The Wit constructor takes the following parameters:
token
- the access token of your Wit instanceactions
- the object with your actionslogger
- (optional) the object handling the logging.
The actions
object has action names as properties, and action implementations as values.
You need to provide at least an implementation for the special actions say
, merge
and error
.
A minimal actions
object looks like this:
const actions = {
say(sessionId, context, message, cb) {
console.log(message);
cb();
},
merge(sessionId, context, entities, message, cb) {
cb(context);
},
error(sessionId, context, error) {
console.log(error.message);
},
};
A custom action takes the following parameters:
sessionId
- a unique identifier describing the user sessioncontext
- the object representing the session statecb(context)
- a callback function to fire at the end of your action with the updated context.
Example:
const Wit = require('node-wit').Wit;
const client = new Wit(token, actions);
The logger
object should implement the methods debug
, log
, warn
and error
.
All methods take a single parameter message
.
For convenience, we provide a Logger
, taking a log level parameter (provided as logLevels
).
The following levels are defined: DEBUG
, LOG
, WARN
, ERROR
.
Example:
const Logger = require('node-wit').Logger;
const levels = require('node-wit').logLevels;
const Wit = require('node-wit').Wit;
const logger = new Logger(levels.DEBUG);
const client = new Wit(token, actions, logger);
The Wit message API.
Takes the following parameters:
message
- the text you want Wit.ai to extract the information fromcontext
- (optional) the object representing the session statecb(error, data)
- a callback function with the JSON response
Example:
const context = {};
client.message('what is the weather in London?', context, (error, data) => {
if (error) {
console.log('Oops! Got an error: ' + error);
} else {
console.log('Yay, got Wit.ai response: ' + JSON.stringify(data));
}
});
A higher-level method to the Wit converse API.
Takes the following parameters:
sessionId
- a unique identifier describing the user sessionmessage
- the text received from the usercontext
- the object representing the session statecb(error, context)
- a callback function with the updated contextmaxSteps
- (optional) the maximum number of actions to execute (defaults to 5)
Example:
const session = 'my-user-session-42';
const context0 = {};
client.runActions(session, 'what is the weather in London?', context0, (e, context1) => {
if (e) {
console.log('Oops! Got an error: ' + e);
return;
}
console.log('The session state is now: ' + JSON.stringify(context1));
client.runActions(session, 'and in Brussels?', context1, (e, context2) => {
if (e) {
console.log('Oops! Got an error: ' + e);
return;
}
console.log('The session state is now: ' + JSON.stringify(context2));
});
});
The low-level Wit converse API.
Takes the following parameters:
sessionId
- a unique identifier describing the user sessionmessage
- the text received from the usercontext
- the object representing the session statecb(error, data)
- a callback function with the JSON response
Example:
client.converse('my-user-session-42', 'what is the weather in London?', {}, (error, data) => {
if (error) {
console.log('Oops! Got an error: ' + error);
} else {
console.log('Yay, got Wit.ai response: ' + JSON.stringify(data));
}
});
Starts an interactive conversation with your bot.
Example:
client.interactive();
See the docs for more information.
This quickstart assumes that you have:
npm install body-parser express node-fetch
From here.
./ngrok http 8445
This will provide your_ngrok_domain
(the Forwarding
line).
export WIT_TOKEN=your_access_token
export FB_PAGE_ID=your_page_id
export FB_PAGE_TOKEN=your_page_token
export FB_VERIFY_TOKEN=any_token
node examples/messenger.js
Using your FB_VERIFY_TOKEN
and https://<your_ngrok_domain>/fb
as callback URL.
See the Messenger Platform docs.