Console

Build Your First Console Bot

Import ConsoleBot from bottender package and create a bot instance:

const { ConsoleBot } = require('bottender');

const bot = new ConsoleBot();

Then, define your handler function:

bot.onEvent(async context => {
  if (context.event.isText) {
    await context.sendText('received text.');
  } else if (context.event.isPayload) {
    await context.sendText('received payload.');
  }
});

Call createRuntime to start the interactive mode:

bot.createRuntime();

Interaction

Sending Text

Send text to the bot. For example:

> MY_TEXT

Sending Payload

Send payload to the bot. For example:

> /payload THIS_IS_MY_COOL_PAYLOAD

Fallback Unsupported Methods

ConsoleBot only has native support for sendText. After setting fallbackMethods to true, you can call any methods on the context and display all of the response as text:

const bot = new ConsoleBot({
  fallbackMethods: true,
});

bot.onEvent(async context => {
  await context.sendText('Hello World');
  await context.sendImage('https://example.com/vr.jpg');
  await context.sendButtonTemplate('What do you want to do next?', [
    {
      type: 'web_url',
      url: 'https://petersapparel.parseapp.com',
      title: 'Show Website',
    },
    {
      type: 'postback',
      title: 'Start Chatting',
      payload: 'USER_DEFINED_PAYLOAD',
    },
  ]);
});

It will get responses like below:

Bot > Hello World
Bot > sendImage: ["https://example.com/vr.jpg"]
Bot > sendButtonTemplate: ["What do you want to do next?",[{"type":"web_url","url":"https://petersapparel.parseapp.com","title":"Show Website"},{"type":"postback","title":"Start Chatting","payload":"USER_DEFINED_PAYLOAD"}]]

It's helpful when you want to test bots of any platforms on the console.

Exit Runtime

To exit console runtime, just type /exit or /quit as message.

References